main.js 2.3 KB

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