【pure-admin】pureadmin的登录对接后端

pureadmin的登录对接后端

在这个项目中,登录对接后端的路由主要通过以下几个部分实现:

1. 路由获取入口 - initRouter函数

登录成功后获取后端路由的核心函数是 initRouter(),它定义在:

ts:src/router/utils.ts 复制代码
function initRouter() {
  if (getConfig()?.CachingAsyncRoutes) {
    // 开启动态路由缓存本地localStorage
    const key = "async-routes";
    const asyncRouteList = storageLocal().getItem(key) as any;
    if (asyncRouteList && asyncRouteList?.length > 0) {
      return new Promise(resolve => {
        handleAsyncRoutes(asyncRouteList);
        resolve(router);
      });
    } else {
      return new Promise(resolve => {
        getAsyncRoutes().then(({ data }) => {
          handleAsyncRoutes(cloneDeep(data));
          storageLocal().setItem(key, data);
          resolve(router);
        });
      });
    }
  } else {
    return new Promise(resolve => {
      getAsyncRoutes().then(({ data }) => {
        handleAsyncRoutes(cloneDeep(data));
        resolve(router);
      });
    });
  }
}

2. 后端路由API接口定义

获取后端路由的API调用定义在:

ts:src/api/routes.ts 复制代码
export const getAsyncRoutes = () => {
  return http.request<Result>("get", "/get-async-routes");
};

这里调用了后端的 /get-async-routes 接口来获取用户有权限的路由信息。

3. 登录流程中的路由获取触发

在登录页面的登录处理函数中,当登录成功后会调用 initRouter() 函数:

ts:src/views/login/index.vue 复制代码
const onLogin = async (formEl: FormInstance | undefined) => {
  // ... 登录验证逻辑 ...
  useUserStoreHook()
    .loginByUsername({/* 登录数据 */})
    .then(res => {
      if (res.success) {
        // 获取后端路由
        return initRouter().then(() => {
          // 跳转到顶级菜单页面
          router.push(getTopMenu(true).path)
          // ... 其他处理 ...
        });
      }
    });
};

4. 后端路由处理与添加

获取到后端路由后,通过 handleAsyncRoutes() 函数进行处理并添加到路由实例中:

ts:src/router/utils.ts 复制代码
function handleAsyncRoutes(routeList) {
  if (routeList.length === 0) {
    usePermissionStoreHook().handleWholeMenus(routeList);
  } else {
    formatFlatteningRoutes(addAsyncRoutes(routeList)).map(
      (v: RouteRecordRaw) => {
        // 防止重复添加路由
        if (router.options.routes[0].children.findIndex(
            value => value.path === v.path
          ) !== -1) {
          return;
        } else {
          // 添加路由
          router.options.routes[0].children.push(v);
          ascending(router.options.routes[0].children);
          if (!router.hasRoute(v?.name)) router.addRoute(v);
          // ... 其他处理 ...
        }
      }
    );
    usePermissionStoreHook().handleWholeMenus(routeList);
  }
  // ... 其他处理 ...
}

5. 路由权限存储

处理后的路由会存储在 permission store 中,供菜单渲染和权限控制使用:

ts:src/store/modules/permission.ts 复制代码
/** 组装整体路由生成的菜单 */
handleWholeMenus(routes: any[]) {
  this.wholeMenus = filterNoPermissionTree(
    filterTree(ascending(this.constantMenus.concat(routes)))
  );
  this.flatteningRoutes = formatFlatteningRoutes(
    this.constantMenus.concat(routes) as any
  );
}

整体流程总结

  1. 用户在登录页面输入账号密码,点击登录
  2. 调用 userStore 中的 loginByUsername 方法,向后端发送登录请求
  3. 登录成功后,调用 initRouter() 函数获取后端路由
  4. initRouter() 函数通过 getAsyncRoutes() 调用后端 /get-async-routes 接口
  5. 获取到后端路由后,通过 handleAsyncRoutes() 函数处理并添加到路由实例中
  6. 最后将处理后的路由存储在 permission store 中,用于菜单渲染和权限控制
  7. 登录成功后跳转到获取的顶级菜单页面

这种设计实现了前端动态路由加载,根据用户权限显示不同的菜单和页面。

相关推荐
暗冰ཏོ2 天前
《2026 Vue2 + Vue3 完整学习指南:基础语法、路由缓存、登录拦截、项目实战与面试题》
前端·vue.js·vue·vue3·vue2
曲幽2 天前
写页面时别再把 Element Plus 整个搬进来啦!Vue3按需加载的坑我帮你踩平了
vue3·web·vite·icon·element plus·vs code·import·unplugin
小云小白4 天前
若依-vue3 把深色版本改成天蓝色-含登录页
vue3·若依·天蓝色
曲幽5 天前
FastApiAdmin 后端接口开发好了,前端管理界面怎么调用与显示?
python·vue3·api·fastapi·web·ant design·view·menu·frontend
曲幽8 天前
我用了FastApiAdmin后,连夜把踩过的坑都整理出来了
redis·python·postgresql·vue3·fastapi·web·sqlalchemy·admin·fastapiadmin
Liu.7749 天前
vue3bug收录
vue3
小云小白18 天前
高性能 v-html 弹窗实现:Vue3 + Element Plus 最佳实践
vue3·弹窗·v-html
xun-ming19 天前
SpringBoot和Vue3实战阿里百炼大模型极简版
spring boot·ai·vue3·智能体·百炼大模型
哆啦A梦158819 天前
20, Springboot3+vue3实现前台轮播图和详情页的设计
javascript·数据库·spring boot·mybatis·vue3
小盼江19 天前
基于Springboot3+Vue3的协同过滤鲜花商城推荐系统
vue3·springboot3·鲜花商城