123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292 |
- import Vue from "vue";
- import axios from "axios";
- import router from "../router";
- import { loadProgressBar } from "axios-progress-bar";
- const ERROR_MSG_CONFIG = require("./errorMsgConfig").default;
- // Full config: https://github.com/axios/axios#request-config
- // axios.defaults.baseURL = process.env.baseURL || process.env.apiUrl || '';
- // axios.defaults.headers.common['Authorization'] = AUTH_TOKEN;
- // axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
- let config = {
- // baseURL: process.env.baseURL || process.env.apiUrl || ""
- timeout: 60 * 1000, // Timeout
- withCredentials: true // Check cross-site Access-Control
- };
- const _$httpWith500Msg = axios.create(config);
- const _$http = axios.create(config); // no auto 500 error UI
- /**
- * A. token lifecycle
- * 1. /login UI => localStorage.removeItem('token') && localStorage.setItem('token')
- * 2. non /login UI => axios if(!wk_token) wk_token = window.sessionStorage.getItem("token"), send request
- * 3. if axios request fail with 401/403, wk_token = null, redirect to /login removeItem('token')
- * 4. logout to /login, before send request, invalidate wk_token
- * */
- let wk_token, wk_key;
- let wk_orgId;
- function getRootOrgId() {
- if (location.hostname.includes("qmth.com.cn")) {
- return "";
- } else {
- return "?orgId=" + (wk_orgId === undefined ? "" : wk_orgId);
- }
- }
- _$httpWith500Msg.interceptors.request.use(
- function(config) {
- // Do something before request is sent
- if (
- config.url.includes("/login") === false &&
- config.url.includes("/auth/thirdPartyAccess") === false
- ) {
- if (!wk_token) {
- const user = JSON.parse(window.sessionStorage.getItem("user"));
- if (!user) {
- Vue.prototype.$alert("登录失效,请重新登录!", "提示", {
- confirmButtonText: "确定",
- callback: () => {
- // if (process.env.NODE_ENV !== "production") {
- // router.push("/login/" + "?orgId=" + wk_orgId);
- // } else {
- // router.push("/login");
- // }
- router.push("/login/" + getRootOrgId());
- }
- });
- return;
- }
- wk_token = user.token;
- wk_key = user.key;
- wk_orgId = user.rootOrgId;
- }
- if (wk_token && config.headers.common["token"] == null) {
- config.headers.common["token"] = wk_token;
- config.headers.common["key"] = wk_key;
- }
- } else {
- wk_token = null;
- }
- return config;
- },
- function(error) {
- // Do something with request error
- Vue.prototype.$notify({
- showClose: true,
- message: error,
- type: "error"
- });
- return Promise.reject(error);
- }
- );
- _$http.interceptors.request.use(
- // no auto 500 error UI
- function(config) {
- // Do something before request is sent
- if (config.url.includes("/login") === false) {
- if (!wk_token) {
- const user = JSON.parse(window.sessionStorage.getItem("user"));
- if (!user) {
- Vue.prototype.$alert("登录失效,请重新登录!", "提示", {
- confirmButtonText: "确定",
- callback: () => {
- router.push("/login/" + getRootOrgId());
- }
- });
- return;
- }
- wk_token = user.token;
- wk_key = user.key;
- wk_orgId = user.rootOrgId;
- }
- if (wk_token && config.headers.common["token"] == null) {
- config.headers.common["token"] = wk_token;
- config.headers.common["key"] = wk_key;
- }
- } else {
- wk_token = null;
- }
- return config;
- },
- function(error) {
- // Do something with request error
- Vue.prototype.$notify({
- showClose: true,
- message: error,
- type: "error"
- });
- return Promise.reject(error);
- }
- );
- // Add a response interceptor
- _$httpWith500Msg.interceptors.response.use(
- response => {
- return response;
- },
- error => {
- console.log(error);
- if (!error.response) {
- // "Network Error" 网络不通,直接返回
- Vue.prototype.$notify({
- showClose: true,
- message: "网络连接异常,请检查网络设置。",
- type: "error"
- });
- return Promise.reject(error);
- }
- // 这里是返回状态码不为200时候的错误处理
- let status = error.response.status;
- // 登录失效 跳转登录页面
- if (status == 403 || status == 401) {
- Vue.prototype.$alert("登录失效,请重新登录!", "提示", {
- confirmButtonText: "确定",
- callback: () => {
- router.push("/login/" + getRootOrgId());
- }
- });
- return Promise.reject(error);
- } else if (status == 405) {
- Vue.prototype.$alert("没有权限!", "提示", {
- confirmButtonText: "确定",
- callback: () => {
- router.push("/login/" + getRootOrgId());
- }
- });
- return Promise.reject(error);
- } else if (status == 502) {
- Vue.prototype.$alert("服务器异常!", "提示", {
- confirmButtonText: "确定"
- });
- return Promise.reject(error);
- }
- if (status != 200) {
- const data = error.response.data;
- if (ERROR_MSG_CONFIG.map(v => v.code).includes(data.code)) {
- const MSG = ERROR_MSG_CONFIG.find(v => v.code === data.code);
- if (MSG.display) {
- Vue.prototype.$notify({
- showClose: true,
- message: MSG.message,
- type: "error"
- });
- }
- } else {
- if (data && data.desc) {
- Vue.prototype.$notify({
- showClose: true,
- message: data.desc,
- type: "error"
- });
- } else {
- Vue.prototype.$notify({
- showClose: true,
- message: "未定义异常: " + JSON.stringify(data, 2),
- type: "error"
- });
- }
- }
- return Promise.reject(error);
- }
- }
- );
- // Add a response interceptor
- _$http.interceptors.response.use(
- // no auto 500 error UI
- response => {
- return response;
- },
- error => {
- if (!error.response) {
- Vue.prototype.$notify({
- showClose: true,
- message: "网络连接异常,请检查网络设置。",
- type: "error"
- });
- return Promise.reject(error);
- }
- // 这里是返回状态码不为200时候的错误处理
- let status = error.response.status;
- // 登录失效 跳转登录页面
- if (status == 403 || status == 401) {
- Vue.prototype.$alert("登录失效,请重新登录!", "提示", {
- confirmButtonText: "确定",
- callback: () => {
- router.push("/login/" + getRootOrgId());
- }
- });
- return Promise.reject(error);
- } else if (status == 405) {
- Vue.prototype.$alert("没有权限!", "提示", {
- confirmButtonText: "确定",
- callback: () => {
- router.push("/login/" + getRootOrgId());
- }
- });
- return Promise.reject(error);
- } else if (status == 502) {
- Vue.prototype.$alert("服务器异常!", "提示", {
- confirmButtonText: "确定"
- });
- return Promise.reject(error);
- }
- if (status != 200) {
- return Promise.reject(error);
- }
- }
- );
- Plugin.install = function(Vue) {
- Vue.$http = _$http; // no auto 500 error UI
- Object.defineProperties(Vue.prototype, {
- $http: {
- get() {
- return _$http; // no auto 500 error UI
- }
- }
- });
- Vue.$httpWithMsg = _$httpWith500Msg;
- Object.defineProperties(Vue.prototype, {
- $httpWithMsg: {
- get() {
- return _$httpWith500Msg;
- }
- }
- });
- // for below request
- // config.url.includes("/api/ecs_ques/paper/") === false &&
- // config.url.includes("/api/ecs_ques/questionAudio") === false
- const _a = axios.create(config);
- Vue.$httpWithoutAuth = _a;
- Object.defineProperties(Vue.prototype, {
- $httpWithoutAuth: {
- get() {
- return _a;
- }
- }
- });
- };
- Vue.use(Plugin);
- loadProgressBar({}, Vue.$http);
- loadProgressBar({}, Vue.$httpWithMsg);
- loadProgressBar({}, Vue.$httpWithoutAuth);
- import "axios-progress-bar/dist/nprogress.css";
- export default Plugin;
|