user.js 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. import { login, getUserInfo, setSelfInfo,login2 } from '@/api/user'
  2. import { jsonInBlacklist } from '@/api/jwt'
  3. import router from '@/router/index'
  4. import { ElLoading, ElMessage } from 'element-plus'
  5. import { defineStore } from 'pinia'
  6. import { ref, computed, watch } from 'vue'
  7. import { useRouterStore } from './router'
  8. import { getMachineMac } from "@/api/jixiaoguanli/jitairibaobiao";
  9. export const useUserStore = defineStore('user', () => {
  10. const loadingInstance = ref(null)
  11. const userInfo = ref({
  12. uuid: '',
  13. nickName: '',
  14. headerImg: '',
  15. authority: {},
  16. sideMode: 'dark',
  17. activeColor: 'var(--el-color-primary)',
  18. baseColor: '#fff'
  19. })
  20. const token = ref(window.localStorage.getItem('token') || '')
  21. const setUserInfo = (val) => {
  22. userInfo.value = val
  23. }
  24. const setToken = (val) => {
  25. token.value = val
  26. }
  27. const NeedInit = () => {
  28. token.value = ''
  29. window.localStorage.removeItem('token')
  30. localStorage.clear()
  31. router.push({ name: 'Init', replace: true })
  32. }
  33. const ResetUserInfo = (value = {}) => {
  34. userInfo.value = {
  35. ...userInfo.value,
  36. ...value
  37. }
  38. }
  39. /* 获取用户信息*/
  40. const GetUserInfo = async() => {
  41. const res = await getUserInfo()
  42. if (res.code === 0) {
  43. setUserInfo(res.data.userInfo)
  44. }
  45. return res
  46. }
  47. /* 登录*/
  48. const LoginIn = async(loginInfo) => {
  49. loadingInstance.value = ElLoading.service({
  50. fullscreen: true,
  51. text: '登录中,请稍候...',
  52. })
  53. try {
  54. const res = await login(loginInfo)
  55. console.log(loginInfo)
  56. console.log(res)
  57. if (res.code === 0) {
  58. setUserInfo(res.data.user)
  59. setToken(res.data.token)
  60. const routerStore = useRouterStore()
  61. await routerStore.SetAsyncRouter()
  62. const asyncRouters = routerStore.asyncRouters
  63. asyncRouters.forEach(asyncRouter => {
  64. router.addRoute(asyncRouter)
  65. })
  66. if (!router.hasRoute(userInfo.value.authority.defaultRouter)) {
  67. ElMessage.error('请联系管理员进行授权')
  68. } else {
  69. await router.replace({ name: userInfo.value.authority.defaultRouter })
  70. }
  71. loadingInstance.value.close()
  72. const isWin = ref(/windows/i.test(navigator.userAgent))
  73. if (isWin.value) {
  74. window.localStorage.setItem('osType', 'WIN')
  75. } else {
  76. window.localStorage.setItem('osType', 'MAC')
  77. }
  78. return true
  79. }
  80. } catch (e) {
  81. loadingInstance.value.close()
  82. }
  83. loadingInstance.value.close()
  84. }
  85. const LoginIn2 = async(loginInfo) => {
  86. loadingInstance.value = ElLoading.service({
  87. fullscreen: true,
  88. text: '登录中,请稍候...',
  89. })
  90. try {
  91. const res = await login2(loginInfo)
  92. console.log(loginInfo)
  93. console.log(res)
  94. if (res.code === 0) {
  95. setUserInfo(res.data.user)
  96. setToken(res.data.token)
  97. const routerStore = useRouterStore()
  98. await routerStore.SetAsyncRouter()
  99. const asyncRouters = routerStore.asyncRouters
  100. asyncRouters.forEach(asyncRouter => {
  101. router.addRoute(asyncRouter)
  102. })
  103. // A4-B1-C1-D4-74-02
  104. const response = await getMachineMac({ addr:MAC});
  105. console.log(response)
  106. if(response.data===null){
  107. ElMessage.error('请输入账号密码')
  108. }else{
  109. if (!router.hasRoute(userInfo.value.authority.defaultRouter)) {
  110. ElMessage.error('请联系管理员进行授权')
  111. } else {
  112. await router.replace({ name: userInfo.value.authority.defaultRouter })
  113. }
  114. loadingInstance.value.close()
  115. const isWin = ref(/windows/i.test(navigator.userAgent))
  116. if (isWin.value) {
  117. window.localStorage.setItem('osType', 'WIN')
  118. } else {
  119. window.localStorage.setItem('osType', 'MAC')
  120. }
  121. return true;
  122. }
  123. }
  124. } catch (e) {
  125. loadingInstance.value.close()
  126. }
  127. loadingInstance.value.close()
  128. }
  129. let MAC=ref()
  130. const GetAddr = () => {
  131. var xmlhttp = null;
  132. var res;
  133. if (window.XMLHttpRequest) {
  134. xmlhttp = new XMLHttpRequest();
  135. } else if (window.ActiveXObject) {
  136. xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
  137. }
  138. // 设置回调函数
  139. xmlhttp.onreadystatechange = function () {
  140. if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
  141. res = eval("(" + xmlhttp.response + ")");
  142. let result = "";
  143. for (let i = 0; i < res.macAddress.length; i++) {
  144. if (i % 2 === 0 && i !== 0) {
  145. result += "-"; // 根据实际需求修改分隔符
  146. }
  147. result += res.macAddress[i];
  148. }
  149. MAC=result
  150. // console.log(result);
  151. // 68-ED-A4-26-5F-37
  152. }
  153. };
  154. // 打开一个连接
  155. xmlhttp.open("get", "http://127.0.0.1:8090/init");
  156. // 发送请求
  157. xmlhttp.send();
  158. };
  159. GetAddr()
  160. const GetMachineMac = async (addr) => {
  161. const response = await getMachineMac({ addr: '68-ED-A4-26-5F-37' });
  162. console.log(response)
  163. if(response.data===null){
  164. LoginOut()
  165. }else{
  166. }
  167. // console.log(loginFormData2)
  168. }
  169. /* 登出*/
  170. const LoginOut = async() => {
  171. const res = await jsonInBlacklist()
  172. if (res.code === 0) {
  173. token.value = ''
  174. sessionStorage.clear()
  175. localStorage.clear()
  176. router.push({ name: 'Login', replace: true })
  177. window.location.reload()
  178. }
  179. }
  180. /* 清理数据 */
  181. const ClearStorage = async() => {
  182. token.value = ''
  183. sessionStorage.clear()
  184. localStorage.clear()
  185. }
  186. /* 设置侧边栏模式*/
  187. const changeSideMode = async(data) => {
  188. const res = await setSelfInfo({ sideMode: data })
  189. if (res.code === 0) {
  190. userInfo.value.sideMode = data
  191. ElMessage({
  192. type: 'success',
  193. message: '设置成功'
  194. })
  195. }
  196. }
  197. const mode = computed(() => userInfo.value.sideMode)
  198. const sideMode = computed(() => {
  199. if (userInfo.value.sideMode === 'dark') {
  200. return '#191a23'
  201. } else if (userInfo.value.sideMode === 'light') {
  202. return '#fff'
  203. } else {
  204. return userInfo.value.sideMode
  205. }
  206. })
  207. const baseColor = computed(() => {
  208. if (userInfo.value.sideMode === 'dark') {
  209. return '#fff'
  210. } else if (userInfo.value.sideMode === 'light') {
  211. return '#191a23'
  212. } else {
  213. return userInfo.value.baseColor
  214. }
  215. })
  216. const activeColor = computed(() => {
  217. return 'var(--el-color-primary)'
  218. })
  219. watch(() => token.value, () => {
  220. window.localStorage.setItem('token', token.value)
  221. })
  222. return {
  223. userInfo,
  224. token,
  225. NeedInit,
  226. ResetUserInfo,
  227. GetUserInfo,
  228. LoginIn,
  229. LoginIn2,
  230. LoginOut,
  231. changeSideMode,
  232. mode,
  233. sideMode,
  234. setToken,
  235. baseColor,
  236. activeColor,
  237. loadingInstance,
  238. ClearStorage
  239. }
  240. })