feat:增加https组件

This commit is contained in:
曾文豪
2022-05-20 15:16:01 +08:00
parent 3d667203c4
commit 5cc77cd612
4 changed files with 161 additions and 6 deletions

View File

@@ -21,15 +21,16 @@
},
"dependencies": {
"@umijs/plugin-helmet": "1.1.4",
"umi": "3.3.14"
"umi": "3.3.14",
"umi-request": "1.4.0"
},
"devDependencies": {
"@umijs/fabric": "2.10.2",
"eslint": "7.32.0",
"lint-staged": "10.5.4",
"prettier": "2.6.2",
"react": "16.14.0",
"react-dom": "16.14.0",
"yorkie": "2.0.0",
"@umijs/fabric": "2.10.2",
"prettier": "2.6.2",
"eslint": "7.32.0"
"yorkie": "2.0.0"
}
}

59
src/https/request.js Normal file
View 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
View 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
View 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,
}