feat:增加https组件
This commit is contained in:
11
package.json
11
package.json
@@ -21,15 +21,16 @@
|
|||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@umijs/plugin-helmet": "1.1.4",
|
"@umijs/plugin-helmet": "1.1.4",
|
||||||
"umi": "3.3.14"
|
"umi": "3.3.14",
|
||||||
|
"umi-request": "1.4.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"@umijs/fabric": "2.10.2",
|
||||||
|
"eslint": "7.32.0",
|
||||||
"lint-staged": "10.5.4",
|
"lint-staged": "10.5.4",
|
||||||
|
"prettier": "2.6.2",
|
||||||
"react": "16.14.0",
|
"react": "16.14.0",
|
||||||
"react-dom": "16.14.0",
|
"react-dom": "16.14.0",
|
||||||
"yorkie": "2.0.0",
|
"yorkie": "2.0.0"
|
||||||
"@umijs/fabric": "2.10.2",
|
|
||||||
"prettier": "2.6.2",
|
|
||||||
"eslint": "7.32.0"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
59
src/https/request.js
Normal file
59
src/https/request.js
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
/**
|
||||||
|
* request 网络请求工具
|
||||||
|
* 更详细的 api 文档: https://github.com/umijs/umi-request
|
||||||
|
*/
|
||||||
|
import {extend} from "umi-request";
|
||||||
|
import Common from "@/utils/Common";
|
||||||
|
import Storage from "@/utils/Storage";
|
||||||
|
|
||||||
|
const codeMessage = {
|
||||||
|
200: "服务器成功返回请求的数据。",
|
||||||
|
201: "新建或修改数据成功。",
|
||||||
|
202: "一个请求已经进入后台排队(异步任务)。",
|
||||||
|
204: "删除数据成功。",
|
||||||
|
400: "发出的请求有错误,服务器没有进行新建或修改数据的操作。",
|
||||||
|
401: "用户没有权限(令牌、用户名、密码错误)。",
|
||||||
|
403: "用户得到授权,但是访问是被禁止的。",
|
||||||
|
404: "发出的请求针对的是不存在的记录,服务器没有进行操作。",
|
||||||
|
406: "请求的格式不可得。",
|
||||||
|
410: "请求的资源被永久删除,且不会再得到的。",
|
||||||
|
422: "当创建一个对象时,发生一个验证错误。",
|
||||||
|
500: "服务器发生错误,请检查服务器。",
|
||||||
|
502: "网关错误。",
|
||||||
|
503: "服务不可用,服务器暂时过载或维护。",
|
||||||
|
504: "网关超时。",
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 异常处理程序
|
||||||
|
*/
|
||||||
|
const errorHandler = error => {
|
||||||
|
const {response = {}} = error;
|
||||||
|
let res = {code: -1, message: "参数错误或服务器异常"};
|
||||||
|
if (!Common.isEmpty(res)) {
|
||||||
|
res = {code: response.status, message: codeMessage[response.status] || response.statusText};
|
||||||
|
}
|
||||||
|
return res;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 配置request请求时的默认参数
|
||||||
|
*/
|
||||||
|
const request = extend({
|
||||||
|
errorHandler, // 默认错误处理
|
||||||
|
credentials: "include", // 默认请求是否带上cookie,
|
||||||
|
requestType: "json", // 表单提交post请求
|
||||||
|
});
|
||||||
|
|
||||||
|
//请求拦截器
|
||||||
|
request.interceptors.request.use((url, options) => {
|
||||||
|
let newOptions = {...options};
|
||||||
|
|
||||||
|
// 请求头处理
|
||||||
|
newOptions.headers["token"] = Storage.getUserToken();
|
||||||
|
|
||||||
|
return {url, options: newOptions};
|
||||||
|
});
|
||||||
|
|
||||||
|
export default request;
|
||||||
76
src/utils/Common.js
Normal file
76
src/utils/Common.js
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
/**
|
||||||
|
* 获取Url中的参数
|
||||||
|
*/
|
||||||
|
const getParamFormUrl = (key, host) => {
|
||||||
|
let arr;
|
||||||
|
let reg = new RegExp("(^|&)" + key + "=([^&]*)(&|$)");
|
||||||
|
try {
|
||||||
|
let testHost = window.location.href;
|
||||||
|
if (host) {
|
||||||
|
testHost = host;
|
||||||
|
}
|
||||||
|
if ((arr = testHost.split("?")[1].match(reg))) {
|
||||||
|
return decodeURI(arr[2]);
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
}
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 是否为空
|
||||||
|
* @param value
|
||||||
|
* @returns {boolean}
|
||||||
|
*/
|
||||||
|
const isEmpty = (value) => {
|
||||||
|
return value === undefined || value === null || value === "";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 转换为json
|
||||||
|
* @param value
|
||||||
|
* @param def
|
||||||
|
*/
|
||||||
|
const parseJSON = (value, def = {}) => {
|
||||||
|
let obj;
|
||||||
|
try {
|
||||||
|
obj = JSON.parse(value);
|
||||||
|
} catch (e) {
|
||||||
|
}
|
||||||
|
if (!obj) {
|
||||||
|
obj = def;
|
||||||
|
}
|
||||||
|
return obj;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 将array中的某个key用seq连接起来
|
||||||
|
* @param array
|
||||||
|
* @param seq
|
||||||
|
* @param key
|
||||||
|
*/
|
||||||
|
const join = (array = [], seq = ",", key) => {
|
||||||
|
let joinArray = array;
|
||||||
|
if (key) {
|
||||||
|
joinArray = array.map(it => it[key]);
|
||||||
|
}
|
||||||
|
return joinArray.join(seq);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分割对象
|
||||||
|
* @param obj
|
||||||
|
* @param seq
|
||||||
|
*/
|
||||||
|
const split = (obj, seq = ",") => {
|
||||||
|
if (obj) {
|
||||||
|
return obj.split(seq);
|
||||||
|
}
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
export default {
|
||||||
|
getParamFormUrl, isEmpty, parseJSON, join, split,
|
||||||
|
}
|
||||||
19
src/utils/Storage.js
Normal file
19
src/utils/Storage.js
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
///////////////////////////////////////// 用户token
|
||||||
|
/**
|
||||||
|
* 保存用户token
|
||||||
|
* @param token
|
||||||
|
*/
|
||||||
|
const saveUserToken = (token) => {
|
||||||
|
sessionStorage.setItem("saveUserToken", token);
|
||||||
|
}
|
||||||
|
|
||||||
|
const getUserToken = () => {
|
||||||
|
return sessionStorage.getItem("saveUserToken") || ""
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
///////////////////////////////////////// 导出模块
|
||||||
|
|
||||||
|
export default {
|
||||||
|
saveUserToken, getUserToken,
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user