第二节:Vben Admin 登录逻辑梳理和对接后端准备

news/2024/7/10 1:17:24 标签: anti-design-vue, 前端框架, vue

系列文章目录

上一节:第一节:Vben Admin介绍和初次运行


文章目录

  • 系列文章目录
  • 前言
  • 项目路径的概述
  • 一、登录逻辑梳理
    • loginApi接口
    • 查看Mock
  • 二、后端程序对接准备
    • 关闭Mock
  • 总结


前言

第一节,我们已经配置了前端环境,运行起来了我们的Vben Admin的项目。
本节内容,我们先熟悉下项目的目录和文件,然后开始准备对接后端程序


项目路径的概述

路由在 src/router
页面在 sr/views

一、登录逻辑梳理

首先我们前端运行的url是http://127.0.0.1:5173/#/login
通过路由/login,可以定位登录文件是views/sys/login/Login.vue
通过/login的路由
调用的链路:

Login.vue => LoginForm.vue => 登录按钮(handleLogin)=> userStore.login =>
loginApi

我们先分析loginApi

loginApi接口

loginApi就是前端向后端请求的接口
src/api/sys/user.ts
在这里插入图片描述
这个接口,需要的参数是LoginParams, 期望的返回是LoginResultModel 具体结构,可以在api/sys/model/userModel.ts 文件查询
在这里插入图片描述
分析到这里,我们已经基本了解了,登录接口的要求,后端只要满足loginAPI的传参和返回,应该就没有问题。

查看Mock

现在我们看下,在没有后端支持的情况下,Vben Admin是如何通过Mock模拟登录的。
在项目启动后,我们点击登录按钮,我们的前端控制台输出是这样婶儿的。
在这里插入图片描述
登录调用了 mock/sys/user.ts 文件里面的/basic-api/login
在这里插入图片描述
这里逻辑,是如果登录通过用户和密码查询到用户信息,就返回用户信息,如果未查询到就返回报错。同时成功是返回 resultSuccess 失败是返回 resultError 格式。
在文件mock/_utils.ts中可以看到

export function resultSuccess<T = Recordable>(result: T, { message = 'ok' } = {}) {
  return {
    code: ResultEnum.SUCCESS,
    result,
    message,
    type: 'success',
  };
}

export function resultError(
  message = 'Request failed',
  { code = ResultEnum.ERROR, result = null } = {},
) {
  return {
    code,
    result,
    message,
    type: 'error',
  };
}

二、后端程序对接准备

关闭Mock

.env.development文件里修改
这里 VITE_USE_MOCK 改成 false
VITE_GLOB_API_URL 改成 api
在这里插入图片描述

项目再次启动,再次登录,这次登录已经报错了
在这里插入图片描述
404,说明我们请求的http://127.0.0.1:5173/api/login url不存在,下一步,我们就要对接后端的/api/login 接口。

总结

本节前端登录逻辑梳理完成了,后端只要在/api/login 接口编写返回逻辑,前后段就可以打通了,具体详情我们下一节介绍


http://www.niftyadmin.cn/n/5393900.html

相关文章

【FPGA】VHDL:小型出勤系统设计

附源代码&#xff0c;一定能实现&#xff01; 目录 EDA设计练习题&#xff1a; 实验要求如下&#xff1a; 思路分析&#xff1a; 代码 99进制计数器 码转换 顶层文件 特别注意 测试 编译通过 结果展示 RTL视图 技术映射视图 软件&#xff1a;Quartus II 13.0 (64…

C++:非静态成员默认初始化

C11之前只有常静态成员变量才能进行默认初始化&#xff0c;其它变量初始化时总要进行繁琐的过程 class A{int a; public:A():a(10){} };C11开始支持非静态成员的默认初始化&#xff0c;默认初始化和初始化参数列表同时初始化一个变量时会使用初始化参数列表&#xff0c;不进行…

代码随想录训练营第41天| 卡码网46. 携带研究材料、416. 分割等和子集

46. 携带研究材料 题目链接&#xff1a;题目页面 (kamacoder.com) 二维dp数组&#xff1a; import java.util.*; public class Main{public static void main(String[] args) {Scanner sc new Scanner(System.in);int m sc.nextInt();int n sc.nextInt();int[] space ne…

Qt RGB三色灯上位机

今天突发奇想做一个Qt RGB三色灯上位机&#xff0c;刚好手上有一个RGB三色灯和arduion开发板。 我是想实现一个颜色选择器界面然后鼠标点击颜色区域就可以发出rgb的值&#xff0c;然后把这个值通过串口线发送给arduion,arduion再解析出数据发送给RGB三色灯。 实现界面如下&…

成都直播产业园进行时!发挥直播电商优势 赋能优势产业发展

在当今数字化的时代&#xff0c;直播电商已经成为一种新型的商业模式&#xff0c;为优势产业的发展带来了巨大的机遇。通过直播电商&#xff0c;优势产业能够更好地展示自身特色和优势&#xff0c;扩大渠道&#xff0c;提升品牌影响力&#xff0c;从而实现产业的升级和转型。天…

C++面试 -操作系统-代码能力:磁盘文件系统、虚拟文件系统与文件缓存

目录 磁盘文件系统&#xff08;Disk File System&#xff09; 1. NTFS&#xff08;New Technology File System&#xff09; 2. EXT4&#xff08;Fourth Extended File System&#xff09; 3. HFS&#xff08;Hierarchical File System Plus&#xff09; 虚拟文件系统&…

3dmax效果图后期补光的万能技巧分享

效果图渲染好了后&#xff0c;有时候我们是需要对它做个补光处理&#xff0c;会显得更加真实。 今天给大家分享一个小技巧&#xff0c;感兴趣的朋友可以去试试&#xff0c;感受感受。 ①用PS打开效果图&#xff0c;创建一个空白的图层&#xff0c;混合模式改为颜色减淡 ②双击…

Spring Cloud项目合规性注册之-(单元集成测试报告)

用于合规性注册&#xff0c;本文章仅提供模板 这个大纲涵盖了从单元测试到集成测试&#xff0c;再到自动化和持续集成的全方位测试过程。 一、引言 1. 项目概述 "xxxxxx"是一个先进的数据管理和展示平台&#xff0c;旨在提供高效、可靠的数据服务。该平台通过集成各…