index.ts 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494
  1. import { createRouter, createWebHistory } from "vue-router";
  2. import AppLayout from "@/components/layout/AppLayout.vue";
  3. import { useTokenStore } from "@/stores/mytoken"; // 确保正确导入 useTokenStore
  4. // 定义路由配置
  5. const routes = [
  6. {
  7. path: "/login",
  8. name: "login",
  9. component: () => import("@/views/login/loginView.vue"), // 修复路径
  10. },
  11. {
  12. path: "/",
  13. name: "home",
  14. component: AppLayout,
  15. meta: { requiresAuth: true, title: "模型" },
  16. redirect: { name: "login" }, // 修改默认重定向为 login
  17. children: [
  18. {
  19. path: "/:catchAll(.*)",
  20. redirect: "/404", // 确保重定向到有效页面
  21. },
  22. {
  23. path: "select-city", // remove leading slash
  24. name: "selectCityAndCounty",
  25. component: () => import("@/views/User/selectCityAndCounty.vue"),
  26. meta: { title: "选择城市和县", fullScreen: true },
  27. },
  28. {
  29. path: "shuJuKanBan",
  30. name: "shuJuKanBan",
  31. component: () => import("@/views/User/shuJuKanBan/shuJuKanBan.vue"), // 修复路径
  32. meta: { title: "数据看板" },
  33. },
  34. {
  35. path: "SoilPro",
  36. name: "SoilPro",
  37. component: () => import("@/views/User/introduction/SoilPro.vue"), // 修复路径
  38. meta: { title: "软件简介" },
  39. },
  40. {
  41. path: "Overview",
  42. name: "Overview",
  43. component: () => import("@/views/User/introduction/Overview.vue"), // 修复路径
  44. meta: { title: "项目简介" },
  45. },
  46. {
  47. path: "ResearchFindings",
  48. name: "ResearchFindings",
  49. component: () =>
  50. import("@/views/User/introduction/ResearchFindings.vue"), // 修复路径
  51. meta: { title: "研究成果" },
  52. },
  53. {
  54. path: "Unit",
  55. name: "Unit",
  56. component: () => import("@/views/User/introduction/Unit.vue"), // 修复路径
  57. meta: { title: "团队信息" },
  58. },
  59. {
  60. path: "IntroductionUpdate",
  61. name: "IntroductionUpdate",
  62. component: () =>
  63. import("@/views/User/introduction/IntroductionUpdate.vue"), // 修复路径
  64. meta: { title: "更新介绍" },
  65. },
  66. {
  67. path: "Calculation",
  68. name: "Calculation",
  69. component: () => import("@/views/User/acidModel/Calculation.vue"), // 修复路径
  70. meta: { title: "反酸计算" },
  71. },
  72. {
  73. path: "AcidNeutralizationModel",
  74. name: "AcidNeutralizationModel",
  75. component: () =>
  76. import(
  77. "@/views/User/neutralizationModel/AcidNeutralizationModel.vue"
  78. ), // 修复路径
  79. meta: { title: "降酸计算" },
  80. },
  81. {
  82. path: "SoilAcidificationIterativeEvolution",
  83. name: "SoilAcidificationIterativeEvolution",
  84. component: () =>
  85. import(
  86. "@/views/User/neutralizationModel/SoilAcidificationIterativeEvolution.vue"
  87. ), // 修复路径
  88. meta: { title: "降酸模型显示" },
  89. },
  90. {
  91. path: "SoilAcidReductionIterativeEvolution",
  92. name: "SoilAcidReductionIterativeEvolution",
  93. component: () =>
  94. import(
  95. "@/views/User/acidModel/SoilAcidReductionIterativeEvolution.vue"
  96. ), // 修复路径
  97. meta: { title: "反酸模型显示" },
  98. },
  99. {
  100. path: "mapView",
  101. name: "mapView",
  102. component: () => import("@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/waterdata/tencentMapView.vue"), // 修复路径
  103. meta: { title: "地图展示" },
  104. },
  105. {
  106. path: "TotalCadmiumPrediction",
  107. name: "TotalCadmiumPrediction",
  108. component: () =>
  109. import("@/views/User/cadmiumPrediction/TotalCadmiumPrediction.vue"), // 修复路径
  110. meta: { title: "土壤镉的总含量预测" },
  111. },
  112. {
  113. path: "EffectiveCadmiumPrediction",
  114. name: "EffectiveCadmiumPrediction",
  115. component: () =>
  116. import(
  117. "@/views/User/cadmiumPrediction/EffectiveCadmiumPrediction.vue"
  118. ), // 修复路径
  119. meta: { title: "土壤镉有效态含量预测" },
  120. },
  121. {
  122. path: "CropCadmiumPrediction",
  123. name: "CropCadmiumPrediction",
  124. component: () =>
  125. import(
  126. "@/views/User/cadmiumPrediction/CropCadmiumPrediction.vue"
  127. ), // 修复路径
  128. meta: { title: "土壤镉作物态含量预测" },
  129. },
  130. {
  131. path: "cropRiskAssessment",
  132. name: "cropRiskAssessment",
  133. component: () =>
  134. import("@/views/User/cropRiskAssessment/cropRiskAssessment.vue"), // 修复路径
  135. meta: { title: "水稻镉污染风险" },
  136. },
  137. {
  138. path: "farmlandQualityAssessment",
  139. name: "farmlandQualityAssessment",
  140. component: () =>
  141. import(
  142. "@/views/User/farmlandQualityAssessment/farmlandQualityAssessment.vue"
  143. ), // 修复路径
  144. meta: { title: "韶关" },
  145. },
  146. {
  147. path: "SoilAcidReboundPrediction",
  148. name: "SoilAcidReboundPrediction",
  149. component: () =>
  150. import(
  151. "@/views/User/soilAcidificationPrediction/SoilAcidReboundPrediction.vue"
  152. ), // 修复路径
  153. meta: { title: "土壤反酸预测" },
  154. },
  155. {
  156. path: "SoilAcidReductionPrediction",
  157. name: "SoilAcidReductionPrediction",
  158. component: () =>
  159. import(
  160. "@/views/User/soilAcidificationPrediction/SoilAcidReductionPrediction.vue"
  161. ), // 修复路径
  162. meta: { title: "土壤降酸预测" },
  163. },
  164. {
  165. path: "TraditionalFarmingRisk",
  166. name: "TraditionalFarmingRisk",
  167. component: () =>
  168. import("@/views/User/scenarioSimulation/TraditionalFarmingRisk.vue"), // 修复路径
  169. meta: { title: "传统耕种习惯风险趋势" },
  170. },
  171. {
  172. path: "HeavyMetalCadmiumControl",
  173. name: "HeavyMetalCadmiumControl",
  174. component: () =>
  175. import(
  176. "@/views/User/scenarioSimulation/HeavyMetalCadmiumControl.vue"
  177. ), // 修复路径
  178. meta: { title: "重金属镉污染治理" },
  179. },
  180. {
  181. path: "SoilAcidificationControl",
  182. name: "SoilAcidificationControl",
  183. component: () =>
  184. import(
  185. "@/views/User/scenarioSimulation/SoilAcidificationControl.vue"
  186. ), // 修复路径
  187. meta: { title: "土壤酸化治理" },
  188. },
  189. {
  190. path: "DetectionStatistics",
  191. name: "DetectionStatistics",
  192. component: () =>
  193. import("@/views/User/dataStatistics/DetectionStatistics.vue"), // 修复路径
  194. meta: { title: "检测信息统计" },
  195. },
  196. {
  197. path: "FarmlandPollutionStatistics",
  198. name: "FarmlandPollutionStatistics",
  199. component: () =>
  200. import("@/views/User/dataStatistics/FarmlandPollutionStatistics.vue"), // 修复路径
  201. meta: { title: "耕地污染信息统计" },
  202. },
  203. {
  204. path: "PlantingRiskStatistics",
  205. name: "PlantingRiskStatistics",
  206. component: () =>
  207. import("@/views/User/dataStatistics/PlantingRiskStatistics.vue"), // 修复路径
  208. meta: { title: "种植风险信息统计" },
  209. },
  210. {
  211. path: "soilAcidReductionData",
  212. name: "soilAcidReductionData",
  213. component: () =>
  214. import("@/views/Admin/dataManagement/Soil Acidification and Acid Reduction Data Management/soilAcidReductionData.vue"), // 修复路径
  215. meta: { title: "降酸数据" },
  216. },
  217. {
  218. path: "soilAcidificationData",
  219. name: "soilAcidificationData",
  220. component: () =>
  221. import("@/views/Admin/dataManagement/Soil Acidification and Acid Reduction Data Management/soilAcidificationData.vue"), // 修复路径
  222. meta: { title: "反酸数据" },
  223. },
  224. {
  225. path: "AdminRegionData",
  226. name: "AdminRegionData",
  227. component: () =>
  228. import("@/views/Admin/dataManagement/Administrative Area Data Management/AdminRegionData.vue"), // 修复路径
  229. meta: { title: "行政区域数据" },
  230. },
  231. {
  232. path: "SoilAssessmentUnitData",
  233. name: "SoilAssessmentUnitData",
  234. component: () =>
  235. import("@/views/Admin/dataManagement/SoilAssessmentUnitData/SoilAssessmentUnitData.vue"),
  236. meta: { title: "土壤评估单元格数据" },
  237. },
  238. {
  239. path: "SoilHeavyMetalData",
  240. name: "SoilHeavyMetalData",
  241. component: () =>
  242. import("@/views/Admin/dataManagement/Soil Heavy Metal Sampling Data Management/SoilHeavyMetalData.vue"),
  243. meta: { title: "土壤重金属采集数据" },
  244. },
  245. {
  246. path: "CropHeavyMetalData",
  247. name: "CropHeavyMetalData",
  248. component: () =>
  249. import("@/views/Admin/dataManagement/Crop Heavy Metal Sampling Data Management/CropHeavyMetalData.vue"),
  250. meta: { title: "农作物重金属采集样数据" },
  251. },
  252. {
  253. path: "LandUseTypeData",
  254. name: "LandUseTypeData",
  255. component: () =>
  256. import("@/views/Admin/dataManagement/Land Use Type Data Management/LandUseTypeData.vue"),
  257. meta: { title: "用地类型数据" },
  258. },
  259. {
  260. path: "SoilAcidificationData",
  261. name: "SoilAcidificationData",
  262. component: () =>
  263. import("@/views/Admin/dataManagement/Soil Acidification Sampling Data Management/SoilAcidificationData.vue"),
  264. meta: { title: "土壤酸化采样数据" },
  265. },
  266. {
  267. path: "ClimateInfoData",
  268. name: "ClimateInfoData",
  269. component: () =>
  270. import("@/views/Admin/dataManagement/Climate Information Data Management/ClimateInfoData.vue"),
  271. meta: { title: "气候信息数据" },
  272. },
  273. {
  274. path: "GeographicEnvInfoData",
  275. name: "GeographicEnvInfoData",
  276. component: () =>
  277. import("@/views/Admin/dataManagement/Geographic Environmental Information Management/GeographicEnvInfoData.vue"),
  278. meta: { title: "地理环境信息" },
  279. },
  280. {
  281. path: "ModelSelection",
  282. name: "ModelSelection",
  283. component: () =>
  284. import("@/views/Admin/modelManagement/AcidReductionModel/ModelSelection.vue"),
  285. meta: { title: "模型选择" },
  286. },
  287. {
  288. path: "thres",
  289. name: "thres",
  290. component: () => import("@/views/Admin/modelManagement/AcidReductionModel/thres.vue"),
  291. meta: { title: "阈值选择" },
  292. },
  293. {
  294. path: "ModelTrain",
  295. name: "ModelTrain",
  296. component: () => import("@/views/Admin/modelManagement/AcidReductionModel/ModelTrain.vue"),
  297. meta: { title: "模型训练" },
  298. },
  299. {
  300. path: "UserRegistration",
  301. name: "UserRegistration",
  302. component: () =>
  303. import("../views/Admin/userManagement/UserRegistration.vue"),
  304. meta: { title: "普通用户" },
  305. },
  306. {
  307. path: "UserManagement",
  308. name: "UserManagement",
  309. component: () =>
  310. import("@/views/Admin/userManagement/UserManagement.vue"),
  311. meta: { title: "用户信息管理" },
  312. },
  313. {
  314. path: "CadmiumPredictionModel",
  315. name: "CadmiumPredictionModel",
  316. component: () =>
  317. import("@/views/Admin/modelManagement/Soil Cadmium Content Prediction Model Management/CadmiumPredictionModel.vue"),
  318. meta: { title: "土壤镉含量预测模型" },
  319. },
  320. {
  321. path: "EffectiveCadmiumModel",
  322. name: "EffectiveCadmiumModel",
  323. component: () =>
  324. import("@/views/Admin/modelManagement/EffectiveCadmiumModel.vue"),
  325. meta: { title: "土壤有效态镉预测模型" },
  326. },
  327. {
  328. path: "RiceRiskModel",
  329. name: "RiceRiskModel",
  330. component: () =>
  331. import("@/views/Admin/modelManagement/Rice Cadmium Pollution Risk Model Management/RiceRiskModel.vue"),
  332. meta: { title: "水稻镉污染风险模型" },
  333. },
  334. {
  335. path: "WheatRiskModel",
  336. name: "WheatRiskModel",
  337. component: () =>
  338. import("@/views/Admin/Wheat Cadmium Pollution Risk Model Management/WheatRiskModel.vue"),
  339. meta: { title: "小麦镉污染风险模型" },
  340. },
  341. {
  342. path: "VegetableRiskModel",
  343. name: "VegetableRiskModel",
  344. component: () =>
  345. import("@/views/Admin/modelManagement/Vegetable Cadmium Pollution Risk Model Management/VegetableRiskModel.vue"),
  346. meta: { title: "蔬菜镉污染风险模型" },
  347. },
  348. {
  349. path: "/irrigationWater",
  350. name: "irrigationWater",
  351. component: () =>
  352. import(
  353. "@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/irrigationWater.vue"
  354. ),
  355. meta: { title: "灌溉水" },
  356. children: [
  357. {
  358. path: "info",
  359. name: "irrigationWaterInfo",
  360. component: () => import("@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/waterdata/rivermessage.vue"),
  361. meta: { title: "采样过程" }
  362. },
  363. {
  364. path: "point",
  365. name: "irrigationWaterPoint",
  366. component: () => import("@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/waterdata/point.vue"),
  367. meta: { title: "采样点展示" }
  368. },
  369. {
  370. path:"river",
  371. name:"irrigationWaterRiver",
  372. component: () =>import("@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/waterdata/rivertencentMapView.vue"),
  373. meta:{title:"断面展示"}
  374. },
  375. ]
  376. },
  377. {
  378. path: "agriculturalProductInput",
  379. name: "agriculturalProductInput",
  380. component: () =>
  381. import(
  382. "@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/agriculturalProductInput.vue"
  383. ),
  384. meta: { title: "农产品投入" },
  385. },
  386. {
  387. path: "atmosphericDryWetDeposition",
  388. name: "atmosphericDryWetDeposition",
  389. component: () =>
  390. import(
  391. "@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/atmosphericDryWetDeposition.vue"
  392. ),
  393. meta: { title: "大气干湿沉降" },
  394. children: [
  395. {
  396. path: "atmpulltionmap",
  397. name: "atmosphericDryWetDepositionAtmpulltionmap",
  398. component: () => import("@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/atmospheredata/atmtencentMap.vue"),
  399. meta: { title: "大气污染地图展示" }
  400. },
  401. {
  402. path:"atmpulltioncompanymap",
  403. name:"atmosphericDryWetDepositionAtmosphericDryWetDeposition",
  404. component: () =>import("@/views/User/heavyMetalFluxCalculation/inputFluxCalculation/atmospheredata/atmcompany.vue"),
  405. meta:{title:"排污企业"}
  406. },
  407. ]
  408. },
  409. {
  410. path: "surfaceRunoff",
  411. name: "surfaceRunoff",
  412. component: () =>
  413. import(
  414. "@/views/User/heavyMetalFluxCalculation/outputFluxCalculation/surfaceRunoff.vue"
  415. ),
  416. meta: { title: "地表径流" },
  417. },
  418. {
  419. path: "cropRemoval",
  420. name: "cropRemoval",
  421. component: () =>
  422. import(
  423. "@/views/User/heavyMetalFluxCalculation/outputFluxCalculation/cropRemoval.vue"
  424. ),
  425. meta: { title: "农作物移除" },
  426. },
  427. {
  428. path: "subsurfaceFlow",
  429. name: "subsurfaceFlow",
  430. component: () =>
  431. import(
  432. "@/views/User/heavyMetalFluxCalculation/outputFluxCalculation/subsurfaceFlow.vue"
  433. ),
  434. meta: { title: "地下渗流" },
  435. },
  436. {
  437. path: "about",
  438. name: "about",
  439. component: () => import("@/views/AboutView.vue"),
  440. },
  441. {
  442. path: "/:pathMatch(.*)*",
  443. name: "ErrorPage",
  444. component: () => import("@/views/ErrorPage.vue"),
  445. },
  446. ],
  447. },
  448. ];
  449. const router = createRouter({
  450. history: createWebHistory(import.meta.env.BASE_URL),
  451. routes,
  452. });
  453. router.beforeEach(async (to, from, next) => {
  454. const tokenStore = useTokenStore();
  455. console.log('[路由导航] 从:', from.path, '到:', to.path, '是否需要认证:', to.matched.some(r => r.meta.requiresAuth));
  456. try {
  457. // 情况1: 用户已登录但访问登录页,重定向到主页
  458. if (to.name === "login" && tokenStore.token.userid) {
  459. console.log('[路由导航] 用户已登录,重定向到主页');
  460. next({ name: "selectCityAndCounty" });
  461. return;
  462. }
  463. // 情况2: 访问需要认证的路由
  464. if (to.matched.some(r => r.meta.requiresAuth)) {
  465. // 检查用户是否已登录
  466. if (!tokenStore.token.userid) {
  467. console.log('[路由导航] 未登录,重定向到登录页');
  468. next({ name: "login" });
  469. return;
  470. }
  471. console.log('[路由导航] 已登录,允许访问需要认证的路由');
  472. next();
  473. return;
  474. }
  475. // 情况3: 不需要认证的路由直接放行
  476. console.log('[路由导航] 不需要认证,直接放行');
  477. next();
  478. } catch (error) {
  479. console.error('[路由导航错误]', error);
  480. next({ name: "login" }); // 发生错误时重定向到登录页
  481. }
  482. });
  483. router.afterEach((to) => {
  484. console.log('[路由完成] 当前路径:', to.path)
  485. })
  486. export default router;