|  |  |  | 
|---|
|  |  |  | import Vue from 'vue'; | 
|---|
|  |  |  | import App from './App.vue'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Vue.config.productionTip = false; | 
|---|
|  |  |  | import ElementUI from 'element-ui'; | 
|---|
|  |  |  | import 'element-ui/lib/theme-chalk/index.css'; | 
|---|
|  |  |  | 
|---|
|  |  |  | import axios from 'axios'; | 
|---|
|  |  |  | import VueCookies from 'vue-cookies'; | 
|---|
|  |  |  | import echarts from 'echarts'; | 
|---|
|  |  |  | import VCharts from 'v-charts'; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import VueClipboard from 'vue-clipboard2' | 
|---|
|  |  |  | import VueClipboard from 'vue-clipboard2'; | 
|---|
|  |  |  | import {Notification} from 'element-ui'; | 
|---|
|  |  |  | import Fingerprint2 from 'fingerprintjs2'; | 
|---|
|  |  |  | import VueClipboards from 'vue-clipboards'; | 
|---|
|  |  |  | import Contextmenu from "vue-contextmenujs" | 
|---|
|  |  |  | import userService from "./components/service/UserService" | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import md5 from 'js-md5' | 
|---|
|  |  |  | Vue.prototype.$md5 = md5 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Vue.use(VueClipboard) | 
|---|
|  |  |  | // 生成唯一ID | 
|---|
|  |  |  | Fingerprint2.get(function (components) { | 
|---|
|  |  |  | const values = components.map(function (component, index) { | 
|---|
|  |  |  | if (index === 0) { //把微信浏览器里UA的wifi或4G等网络替换成空,不然切换网络会ID不一样 | 
|---|
|  |  |  | return component.value.replace(/\bNetType\/\w+\b/, ''); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return component.value; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | //console.log(values)  //使用的浏览器信息npm | 
|---|
|  |  |  | // 生成最终id | 
|---|
|  |  |  | let port = window.location.port; | 
|---|
|  |  |  | console.log(port); | 
|---|
|  |  |  | const fingerPrint = Fingerprint2.x64hash128(values.join(port), 31) | 
|---|
|  |  |  | Vue.prototype.$browserId = fingerPrint; | 
|---|
|  |  |  | console.log("唯一标识码:" + fingerPrint); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Vue.use(VueClipboard); | 
|---|
|  |  |  | Vue.use(ElementUI); | 
|---|
|  |  |  | Vue.use(VueCookies); | 
|---|
|  |  |  | Vue.use(VueClipboards); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Vue.prototype.$notify = Notification; | 
|---|
|  |  |  | Vue.use(Contextmenu); | 
|---|
|  |  |  | Vue.use(VCharts); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | axios.defaults.baseURL = (process.env.NODE_ENV === 'development') ? process.env.BASE_API : (window.baseUrl ? window.baseUrl : ""); | 
|---|
|  |  |  | axios.defaults.withCredentials = true; | 
|---|
|  |  |  | // api 返回401自动回登陆页面 | 
|---|
|  |  |  | axios.interceptors.response.use((response) => { | 
|---|
|  |  |  | // 对响应数据做点什么 | 
|---|
|  |  |  | let token = response.headers["access-token"]; | 
|---|
|  |  |  | if (token) { | 
|---|
|  |  |  | userService.setToken(token) | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return response; | 
|---|
|  |  |  | }, (error) => { | 
|---|
|  |  |  | // 对响应错误做点什么 | 
|---|
|  |  |  | if (error.response.status === 401) { | 
|---|
|  |  |  | console.log("Received 401 Response") | 
|---|
|  |  |  | router.push('/login'); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return Promise.reject(error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | axios.interceptors.request.use( | 
|---|
|  |  |  | config => { | 
|---|
|  |  |  | if (userService.getToken() != null && config.url !== "/api/user/login") { | 
|---|
|  |  |  | config.headers['access-token'] = `${userService.getToken()}`; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return config; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | error => { | 
|---|
|  |  |  | return Promise.reject(error); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Vue.prototype.$axios = axios; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | axios.defaults.baseURL = (process.env.NODE_ENV === 'development') ? process.env.BASE_API : ""; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Vue.prototype.$cookies.config(60*30); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | new Vue({ | 
|---|
|  |  |  | router: router, | 
|---|
|  |  |  | render: h => h(App), | 
|---|
|  |  |  | router: router, | 
|---|
|  |  |  | render: h => h(App), | 
|---|
|  |  |  | }).$mount('#app') | 
|---|