main.js 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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 VueClipboard from 'vue-clipboard2';
  11. import { Notification } from 'element-ui';
  12. import Fingerprint2 from 'fingerprintjs2';
  13. import VueClipboards from 'vue-clipboards';
  14. // 生成唯一ID
  15. Fingerprint2.get(function(components) {
  16. const values = components.map(function(component,index) {
  17. if (index === 0) { //把微信浏览器里UA的wifi或4G等网络替换成空,不然切换网络会ID不一样
  18. return component.value.replace(/\bNetType\/\w+\b/, '');
  19. }
  20. return component.value;
  21. })
  22. //console.log(values) //使用的浏览器信息npm
  23. // 生成最终id
  24. let port = window.location.port;
  25. console.log(port);
  26. const fingerPrint = Fingerprint2.x64hash128(values.join(port), 31)
  27. Vue.prototype.$browserId = fingerPrint;
  28. console.log("唯一标识码:" + fingerPrint);
  29. });
  30. Vue.use(VueClipboard);
  31. Vue.use(ElementUI);
  32. Vue.use(VueCookies);
  33. Vue.use(VueClipboards);
  34. Vue.prototype.$axios = axios;
  35. Vue.prototype.$notify = Notification;
  36. axios.defaults.baseURL = (process.env.NODE_ENV === 'development') ? process.env.BASE_API : "";
  37. // api 返回401自动回登陆页面
  38. axios.interceptors.response.use(function (response) {
  39. // 对响应数据做点什么
  40. return response;
  41. }, function (error) {
  42. // 对响应错误做点什么
  43. if (error.response.status === 401) {
  44. console.log("Received 401 Response")
  45. router.push('/login');
  46. }
  47. return Promise.reject(error);
  48. });
  49. Vue.prototype.$cookies.config(60*30);
  50. new Vue({
  51. router: router,
  52. render: h => h(App),
  53. }).$mount('#app')