main.js 1.9 KB

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