main.js 2.4 KB

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