123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- import { useStores } from "@/store/modules/index";
- import configs from "@/config";
- import { getToken } from "@/utils/auth";
- import modal from "@/plugins/modal.plugins";
- import common from "@/plugins/common.plugins";
- let timeout = 10000;
- /**
- * @校验结果方法
- * @param {数据集} res
- * @param {结果抛出} resolve
- * @param {控制台打印} reject
- */
- function verification(res, resolve, reject) {
- const useStore = useStores();
- const data = typeof res.data === "string" ? JSON.parse(res.data) : res.data;
- const code = data.code || 200;
- if (code === 401) {
- // modal.confirm("登录状态已过期,您可以继续留在该页面,或者重新登录?").then((res) => {
- // if (res) {
- // useStore.LogOut().then((res) => {
- // uni.reLaunch({ url: "/pages/login" });
- // });
- // }
- // });
- uni.reLaunch({ url: "/pages/login" });
- modal.closeLoading();
- reject("无效的会话,或者会话已过期,请重新登录。");
- } else if (code === 404 || res.statusCode === 404) {
- if (data.msg.indexOf(":") !== -1) {
- modal.msg(data.msg.split(":")[1]);
- reject(data.msg.split(":")[1]);
- } else {
- modal.msg(data.msg);
- reject(data.msg);
- }
- modal.closeLoading();
- } else if (code === 500 || res.statusCode === 500 || code === 'BIZ-0000') {
- if (data.msg.indexOf(":") !== -1) {
- modal.msg(data.msg.split(":")[1]);
- reject(data.msg.split(":")[1]);
- } else {
- modal.msg(data.msg);
- reject(data.msg);
- }
- modal.closeLoading();
- } else if (code !== 200 && code !== "0") {
- reject(code);
- }
- resolve(data);
- }
- const request = (config) => {
- // 是否需要设置 token
- const isToken = (config.headers || {}).isToken === false;
- config.header = config.header || {};
- if (getToken() && !isToken) {
- config.header["Authorization"] = getToken();
- }
- // get请求映射params参数
- if (config.params) {
- let url = config.url + "?" + common.tansParams(config.params);
- url = url.slice(0, -1);
- config.url = url;
- }
- return new Promise((resolve, reject) => {
- uni
- .request({
- method: config.method || "get",
- timeout: config.timeout || timeout,
- url: config.baseUrl || configs.baseUrl + config.url,
- data: config.data,
- header: config.header,
- dataType: "json",
- })
- .then((res) => {
- if (res.error) {
- modal.msg("后端接口连接异常");
- reject("后端接口连接异常");
- return;
- }
- verification(res, resolve, reject);//调用校验结果方法
- })
- .catch((error) => {
- let { message } = error;
- if (!message) return;
- if (message === "Network Error") {
- message = "后端接口连接异常";
- } else if (message.includes("timeout")) {
- message = "系统接口请求超时";
- } else if (message.includes("Request failed with status code")) {
- message = "系统接口" + message.substr(message.length - 3) + "异常";
- }
- reject(error);
- });
- });
- };
- const uploads = (config) => {
- const useStore = useStores();
- // 是否需要设置 token
- const isToken = (config.headers || {}).isToken === false;
- config.header = config.header || {};
- if (getToken() && !isToken) {
- config.header["Authorization"] = getToken();
- }
- // get请求映射params参数
- if (config.params) {
- let url = config.url + "?" + common.tansParams(config.params);
- url = url.slice(0, -1);
- config.url = url;
- }
- return new Promise((resolve, reject) => {
- uni.uploadFile({
- timeout: config.timeout || timeout,
- url: configs.baseUrl + config.url,
- filePath: config.filePath,
- name: config.name || "file",
- header: config.header,
- formData: config.formData,
- success: (res) => {
- verification(res, resolve, reject);//调用校验结果方法
- },
- fail: (error) => {
- let { message } = error;
- if (message == "Network Error") {
- message = "后端接口连接异常";
- } else if (message.includes("timeout")) {
- message = "系统接口请求超时";
- } else if (message.includes("Request failed with status code")) {
- message = "系统接口" + message.substr(message.length - 3) + "异常";
- }
- reject(error);
- },
- });
- });
- };
- export {
- request,
- uploads
- };
|