HotGo--登录处理

前端路由加载

1、静态路由,前端控制的路由,不涉及到后端,其中有登录路由、跟路由、异常页路由。在main.ts中加载

ts 复制代码
// main.ts
setupRouter(app);
ts 复制代码
// router/index.ts

//普通路由 无需验证权限
export const constantRouter: any[] = [LoginRoute, RootRoute, RedirectRoute];

const router = createRouter({
  history: createWebHashHistory(''),
  routes: constantRouter,
  strict: true,
  scrollBehavior: () => ({ left: 0, top: 0 }),
});

export function setupRouter(app: App) {
  app.use(router);
  // 创建路由守卫
  createRouterGuards(router);
}

/web/src/router/index.ts#L54

2、动态菜单路由,从服务端拿到路由数据,转换为菜单路由,这些路由经过了权限的过滤,是当前用户所在角色拥有的路由

const routes = await asyncRouteStore.generateRoutes(userInfo);

ts 复制代码
// store/modules/asyncRoute.ts
async generateRoutes(data) {
    // ...
    try {
        accessedRouters = await generatorDynamicRouter();
    } catch (error) {}
    // ...
}
ts 复制代码
// 动态生成菜单 web/src/router/generator-routers.ts
export const generatorDynamicRouter = (): Promise<RouteRecordRaw[]> => {
  return new Promise((resolve, reject) => {
    adminMenus()
      .then((result) => {
        const routeList = routerGenerator(result.list);
        asyncImportRoute(routeList);
        resolve(routeList);
      })
      .catch((err) => {
        reject(err);
      });
  });
};

/web/src/router/generator-routers.ts#L56

登录页面

从 router/index.ts 中可以看到,登录页面在 @/views/login/index.vue

通过vue的Component,来动态切换要显示的内容,是登录组件,还是注册组件

ts 复制代码
import LoginFrom from './login/index.vue';
import RegisterFrom from './register/index.vue';
  
// src/views/login/index.vue
// { key: 'register', label: '注册账号', component: RegisterFrom }
const activeModule = ref<LoginModule>({
    key: 'login',
    label: '账号登录',
    component: LoginFrom,
 });

登录请求与跳转,随着登录按钮的点击事件handleLogin,进入了登录请求,拿到数据,缓存到localStorage和内存中

ts 复制代码
// src/store/modules/user.ts
const ex = 30 * 24 * 60 * 60 * 1000;
storage.set(ACCESS_TOKEN, data.token, ex);
storage.set(CURRENT_USER, data, ex);
storage.set(IS_LOCKSCREEN, false);
this.setToken(data.token);
this.setUserInfo(data);

然后在处理完成以后,跳转到主页面

ts 复制代码
// src/views/login/login/form.vue
router.replace('/');

以后每次在路由切换的时候,都会通过路由守卫进行判断token,如果没有,跳转登录页

ts 复制代码
// src/router/router-guards.ts
const token = storage.get(ACCESS_TOKEN);
if (!token) {
   // 未登录处理
}

了解一个项目,就像了解一棵树一样,先了解主干,在看枝叶。具体其他函数和变量,再慢慢细究。

相关推荐
Irene19911 小时前
ElementPlus 与成熟后台框架对比:vue-element-plus-admin、vue-pure-admin等
前端·ui·框架·vue3
尘中客5 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
FreeBuf_6 小时前
Chrome 0Day漏洞遭野外利用
前端·chrome
小彭努力中6 小时前
199.Vue3 + OpenLayers 实现:点击 / 拖动地图播放音频
前端·vue.js·音视频·openlayers·animate
2501_916007476 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
前端大波6 小时前
Sentry 每日错误巡检自动化:设计思路与上手实战
前端·自动化·sentry
ZC跨境爬虫7 小时前
使用Claude Code开发校园交友平台前端UI全记录(含架构、坑点、登录逻辑及算法)
前端·ui·架构
慧一居士7 小时前
Vue项目中,何时使用布局、子组件嵌套、插槽 对应的使用场景,和完整的使用示例
前端·vue.js
Можно8 小时前
uni.request 和 axios 的区别?前端请求库全面对比
前端·uni-app
M ? A8 小时前
解决 VuReact 中 ESLint 规则冲突的完整指南
前端·react.js·前端框架