main.js 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. import Vue from 'vue';
  2. import App from './App.vue';
  3. Vue.config.productionTip = false;
  4. import ElementUI from 'element-ui';
  5. import 'element-ui/lib/theme-chalk/index.css';
  6. import "./assets/index.css";
  7. import router from './router/index.js';
  8. import axios from './apiStore/axios';
  9. import VueCookies from 'vue-cookies';
  10. import echarts from 'echarts';
  11. import VCharts from 'v-charts';
  12. import VueClipboard from 'vue-clipboard2';
  13. import {Notification} from 'element-ui';
  14. import Fingerprint2 from 'fingerprintjs2';
  15. import VueClipboards from 'vue-clipboards';
  16. import Contextmenu from "vue-contextmenujs"
  17. import userService from "./components/service/UserService"
  18. // 生成唯一ID
  19. Fingerprint2.get(function (components) {
  20. const values = components.map(function (component, index) {
  21. if (index === 0) { //把微信浏览器里UA的wifi或4G等网络替换成空,不然切换网络会ID不一样
  22. return component.value.replace(/\bNetType\/\w+\b/, '');
  23. }
  24. return component.value;
  25. })
  26. //console.log(values) //使用的浏览器信息npm
  27. // 生成最终id
  28. let port = window.location.port;
  29. console.log(port);
  30. const fingerPrint = Fingerprint2.x64hash128(values.join(port), 31)
  31. Vue.prototype.$browserId = fingerPrint;
  32. console.log("唯一标识码:" + fingerPrint);
  33. });
  34. Vue.use(VueClipboard);
  35. Vue.use(ElementUI);
  36. Vue.use(VueCookies);
  37. Vue.use(VueClipboards);
  38. Vue.prototype.$notify = Notification;
  39. Vue.use(Contextmenu);
  40. Vue.use(VCharts);
  41. let _axios = axios.axios;
  42. _axios.defaults.baseURL = (process.env.NODE_ENV === 'development') ? process.env.BASE_API : (window.baseUrl ? window.baseUrl : "");
  43. _axios.defaults.withCredentials = true;
  44. // api 返回401自动回登陆页面
  45. _axios.interceptors.response.use((response) => {
  46. // 对响应数据做点什么
  47. let token = response.headers["access-token"];
  48. if (token) {
  49. console.log("更新token");
  50. userService.setToken(token)
  51. }
  52. return response;
  53. }, (error) => {
  54. // 对响应错误做点什么
  55. if (error.response.status === 401) {
  56. console.log("Received 401 Response")
  57. router.push('/login');
  58. }
  59. return Promise.reject(error);
  60. });
  61. _axios.interceptors.request.use(
  62. config => {
  63. if (userService.getToken() != null && config.url !== "/api/user/login") {
  64. config.headers['access-token'] = `${userService.getToken()}`;
  65. }
  66. return config;
  67. },
  68. error => {
  69. return Promise.reject(error);
  70. }
  71. );
  72. _axios.interceptors.request.use(config => {
  73. config.headers.withCredentials = true;
  74. // App.$message.info('test')
  75. config.changeOrigin= true
  76. config.credentials= true;
  77. config.secure= true
  78. return config
  79. },error =>{
  80. return Promise.reject(error)
  81. })
  82. Vue.prototype.$axios = axios;
  83. Vue.prototype.$cookies.config(60*30);
  84. new Vue({
  85. router: router,
  86. render: h => h(App),
  87. }).$mount('#app')