main.js 2.8 KB

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