vue3后台管理框架之将模拟Mock接口替换成真实接口

news2024/12/30 3:12:10

首先配置跨域代理

替换接口

由于请求数据格式是表单格式

我们需要下载qs 件请求数据序列化变成表单格式

安装依赖

pnpm i qs

引入

import * as qs from 'qs'

//统一管理咱们项目用户相关的接口
import * as qs from 'qs'
import request from '@/utils/request'

import type { loginForm, loginResponseData, userInfoReponseData } from './type'

//项目用户相关的请求地址

enum API {
  LOGIN_URL = '/admin/user/login',

  USERINFO_URL = '/admin/user/userinfo'
}
//登录接口
export const reqLogin = (data: loginForm) => request.post<any, loginResponseData>(API.LOGIN_URL, qs.stringify(data))
//获取用户信息

export const reqUserInfo = () => request.get<any, userInfoReponseData>(API.USERINFO_URL)

其实可以封装post请求,让所有的post请求中的data请求格式变成表单格式,后面在封装吧

然后我们根据接口数据类型,定义请求和响应数据

// 登录需要携带参数ts类型
export interface loginForm {
  username: string
  password: string
}
interface dataType {
  id: number
  avatar: string
  username: string
  password: string
  gender: string
  age: number
  emial: string
  userId: number
  created_time: string
  status: number
}
// 登录接口返回数据类型
export interface loginResponseData {
  status: number
  token?: string
  message?: string
  data: dataType
}
interface userInfo {
  id: number
  avatar: string
  username: string
  realname: string
  age: number
  email: string
}
// interface user {
//   checkUser: userInfo
// }
// 用户信息返回数据类型
export interface userInfoReponseData {
  status: number
  message?: string
  data: userInfo
}

路由守卫

没有弄懂路由守卫的

//路由鉴权:鉴权,项目当中路由能不能被的权限的设置(某一个路由什么条件下可以访问、什么条件下不可以访问)
import router from '@/router'
import setting from './setting'
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
//@ts-expect-error
import nprogress from 'nprogress'
//引入进度条样式
import 'nprogress/nprogress.css'
nprogress.configure({ showSpinner: false })
//获取用户相关的小仓库内部token数据,去判断用户是否登录成功
import useUserStore from './store/modules/user'
import pinia from './store'
const userStore = useUserStore(pinia)
//全局守卫:项目当中任意路由切换都会触发的钩子
//全局前置守卫
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
//@ts-expect-error
router.beforeEach(async (to: any, from: any, next: any) => {
  document.title = `${setting.title} - ${to.meta.title}`
  //to:你将要访问那个路由
  //from:你从来个路由而来
  //next:路由的放行函数
  // console.log(userStore.token, '000')

  nprogress.start()
  //获取token,去判断用户登录、还是未登录
  const token = userStore.token
  //获取用户名字
  const username = userStore.username
  console.log(username, token)

  //用户登录判断
  if (token) {
    //登录成功,访问login,不能访问,指向首页
    if (to.path == '/login') {
      next({ path: '/' })
    } else {
      //登录成功访问其余六个路由(登录排除)
      //有用户信息
      if (username) {
        //放行
        next()
      } else {
        //如果没有用户信息,在守卫这里发请求获取到了用户信息再放行
        try {
          //获取用户信息
          await userStore.userInfo()
          //放行
          //万一:刷新的时候是异步路由,有可能获取到用户信息、异步路由还没有加载完毕,出现空白的效果
          next({ ...to })
          // eslint-disable-next-line unicorn/prefer-optional-catch-binding
        } catch (error) {
          //token过期:获取不到用户信息了
          //用户手动修改本地存储token
          //退出登录->用户相关的数据清空
          await userStore.userLogout()
          next({ path: '/login', query: { redirect: to.path } })
        }
      }
    }
  } else {
    //用户未登录判断
    if (to.path == '/login') {
      next()
    } else {
      next({ path: '/login', query: { redirect: to.path } })
    }
  }
})
//全局后置守卫
router.afterEach(() => {
  nprogress.done()
})

//第一个问题:任意路由切换实现进度条业务 ---nprogress
//第二个问题:路由鉴权(路由组件访问权限的设置)
//全部路由组件:登录|404|任意路由|首页|数据大屏|权限管理(三个子路由)|商品管理(四个子路由)

//用户未登录:可以访问login,其余六个路由不能访问(指向login)
//用户登录成功:不可以访问login[指向首页],其余的路由可以访问

这段代码解释如下

  1. 首先,引入了必要的依赖,包括Vue Router、项目设置、NProgress(用于显示进度条)、用户存储相关的小仓库,以及一些配置。
  2. router.beforeEach 是全局前置守卫,它会在每次路由切换之前执行。在它的回调函数中,执行以下操作:
    • 设置文档标题,通常是根据路由的元数据和项目设置生成的。
    • 获取用户的 token 和用户名。
    • 根据用户的登录状态和访问的路由进行路由鉴权。
  1. 路由鉴权的逻辑如下:
    • 如果用户已登录(存在 token),则检查目标路由 to 的路径。
    • 如果用户已登录但试图访问登录页面 /login,则将其重定向到首页 /。
    • 如果用户已登录且有用户名信息,表示已获取用户信息,放行访问其他路由。
    • 如果用户已登录但没有用户名信息,表示需要先获取用户信息,这里使用 await userStore.userInfo() 异步获取用户信息,获取成功后再继续路由导航,以避免空白的效果。
    • 如果获取用户信息时出现错误,通常是因为 token 过期或用户手动修改了本地存储的 token,此时执行退出登录操作并重定向到登录页面,同时在 query 参数中传递当前访问路径,以便用户登录后可以跳回原本的页面。
  1. 如果用户未登录(没有 token),则检查目标路由 to 的路径。
    • 如果目标路由是登录页面 /login,则放行。
    • 否则,将用户重定向到登录页面,并在 query 参数中传递当前访问的路径,以便登录后可以跳回原本的页面。
  1. router.afterEach 是全局后置守卫,它在路由切换完成后执行,这里用于结束 NProgress 进度条。

修改登录和获取用户请求

因为我们将用户数据存储在store

所以我们需要将store下的user中登录和获取用户信息的操作进行修改将username,token,avatar进行状态管理

async userLogin(data: loginForm) {
      // 登录请求
      const res: loginResponseData = await reqLogin(data)
      // console.log(res, 'loginResponseData')
      if (res.status === 0) {
        this.token = res.token as string

        SET_TOKEN(res.token as string)
        return 'ok'
      } else {
        return Promise.reject(new Error(res.message))
      }
    },
    // 获取用户信息
    async userInfo() {
      const res: userInfoReponseData = await reqUserInfo()
      console.log(res, 'userInfoReponseData')

      if (res.status == 0) {
        this.username = res.data.username
        this.avatar = res.data.avatar
      }
      console.log(this.username, '111')
    },

 一定要看看token和用户信息是否进行状态管理,在路由守卫那里是否能得到token,username

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1148586.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【java学习—十】抛出异常(3)

文章目录 1. 声明抛出异常2. 重写方法声明抛出异常的原则3. 人工抛出异常4. 创建用户自定义异常类 1. 声明抛出异常 声明抛出异常是 Java 中处理异常的第二种方式&#xff1a; • 如果一个方法 ( 中的语句执行时 ) 可能生成某种异常&#xff0c;但是并不能确定如何处理这种异常…

目标检测与图像识别分类的区别?

目标检测与图像识别分类的区别 目标检测和图像识别分类是计算机视觉领域中两个重要的任务&#xff0c;它们在处理图像数据时有一些区别。 目标检测是指在图像中定位和识别多个目标的过程。其主要目标是确定图像中每个目标的边界框位置以及对应的类别标签。目标检测任务通常涉…

AS/400-对象管理-01

对象管理 对象对象构图 AS/400中的库命令Display Library List (DSPLIBL)Create Library (CRTLIB)Display library (DSPLIB)Edit Library List (EDTLIBL) Source physical file 物理文件创建物理文件的命令 &#xff1a; CRTSRCPF 物理文件查看所有物理文件的源文件创建源文件…

计算机毕业设计选题推荐-戏曲文化苑微信小程序/安卓APP-项目实战

✨作者主页&#xff1a;IT研究室✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

案例分析真题-Web系统

案例分析真题-Web系统 2011 年真题 【问题1】 骚戴理解&#xff1a;还是要学会分析&#xff0c;首先要先看题目在看文字内容描述&#xff0c;不然看完了也不知道看了个啥&#xff0c;根据“其中互联网上用户对公司产品信息的访问情况需要借助两种不同的第三方 Web 分析软件进行…

登录rabbitMQ管理界面时浏览器显示要求进行身份验证,与此站点连接不安全解决办法

问题描述 最近在黑马学习rabbitMQ的过程中&#xff0c;在使用docker部署好rabbitMQ后&#xff0c;使用账号为&#xff1a;itcast&#xff0c;密码为&#xff1a;123321 登录的时候浏览器显示了这个问题&#xff0c;如图所示&#xff1a; 当时以为自己需要输入自己的浏览…

14个最实用的WordPress SEO插件推荐

在这篇文章中&#xff0c;将为你推荐最有利于网站SEO的WordPress插件&#xff0c;这里介绍这些插件的主要功能及使用技巧&#xff0c;合理使用它们将有助于网站SEO排名。无论你是一个刚刚开始的博客作者&#xff0c;还是一个经验丰富的企业网站管理员&#xff0c;我们都将帮助你…

Android使用Hilt依赖注入,让人看不懂你代码

前言 之前接手的一个项目里有些代码看得云里雾里的&#xff0c;找了半天没有找到对象创建的地方&#xff0c;后来才发现原来使用了Hilt进行了依赖注入。Hilt相比Dagger虽然已经比较简洁&#xff0c;但对初学者来说还是有些门槛&#xff0c;并且网上的许多文章都是搬自官网&…

微信小程序设计之页面文件pages

一、新建一个项目 首先&#xff0c;下载微信小程序开发工具&#xff0c;具体下载方式可以参考文章《微信小程序开发者工具下载》。 然后&#xff0c;注册小程序账号&#xff0c;具体注册方法&#xff0c;可以参考文章《微信小程序个人账号申请和配置详细教程》。 在得到了测…

day05 语法基础——CG语法 23.10.29

1.ShaderLabVS Pro插件安装(仅vs全家可用) 2.CG语句写在哪里 3.基础数据类型 4.特殊数据类型 5.Swizzle操作符 6.运算符相关 7.流程控制语句 8.函数 9.顶点/片元着色器基本结构 10.语义 11.顶点/片元着色器传递更多参数 12.ShaderLab属性类型和CG变量类型的匹配关系 13.CG内置…

亚信科技发布“电信级”核心交易数据库AntDB7.0,助力政企“信”创未来!

昨日&#xff0c;亚信科技AntDB数据库 7.0产品线上发布会成功举办&#xff0c;数千位关注亚信科技、关注国产数据库&#xff0c;致力于推动数据库行业变革的专家、客户热情参与&#xff0c;并对发布会及产品给予高度评价。 新增两大技术特性 作为我国最早一批独立研发的通用型…

动静分离技术

一、HAproxy 动静分离 1、概念&#xff1a; HAproxy 动静分离技术是一种用于优化 Web 服务器性能和提高用户体验的策略&#xff0c;它通过将动态内容和静态内容分别路由到不同的后端服务器来实现&#xff0c;减轻服务器负载&#xff0c;提高网站的响应速度。 动态内容包括由…

2023年双十一如何选购最新fl studio 21多少钱?有FL Studio21中文解锁版下载

如果你一直梦想制作自己的音乐(无论是作为一名制作人还是艺术家)&#xff0c;你可能会想你出生在这个时代是你的幸运星。这个水果圈工作室和上一版之间的改进水平确实令人钦佩。这仅仅是FL Studio 21所提供的皮毛。你的音乐项目的选择真的会让你大吃一惊。你以前从未有过这样的…

6G关键新兴技术- 智能超表面(RIS)技术演进

摘要&#xff1a; 根据欧盟5G公私联盟协会定义&#xff0c;可重构智慧表面技术是由能够任意塑造电磁波面的材料组成&#xff0c;几乎是被动设备&#xff0c;可以适应或改变发射器和接收器之间的无线电信号。 一、产品定义及范围 根据欧盟5G公私联盟协会(5G Infrastructure P…

USART HMI串口屏+单片机通讯上手体验

USART HMI串口屏单片机通讯上手体验 &#x1f516;本文采用淘晶驰4.3寸IPS串口屏实物验证&#xff0c;HMI串口屏经简单配置即可快速实现&#xff0c;串口通讯效果。串口屏上手简单&#xff0c;有独立的开发套件&#xff0c;容易上手&#xff0c;驱动显示和功能代码独立。本文仅…

能源管理数据:为企业打造绿色动力,引领可持续发展新篇章

随着全球能源结构的转变&#xff0c;绿色、清洁、可再生能源已成为关注的焦点。在这个大背景下&#xff0c;企业如何有效管理和利用能源数据&#xff0c;提高能源利用效率&#xff0c;降低碳排放&#xff0c;已成为当今社会的重要议题。本文将为你揭示能源管理数据的重要性和应…

计算机毕业设计选题推荐-周边美食推荐微信小程序/安卓APP-项目实战

✨作者主页&#xff1a;IT毕设梦工厂✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Py…

1.spark standalone环境安装

概述 环境是spark 3.2.4 hadoop版本 3.2.4&#xff0c;所以官网下载的包为 spark-3.2.4-bin-hadoop3.2.tgz 在具体安装部署之前&#xff0c;需要先下载Spark的安装包&#xff0c;进到 spark的官网&#xff0c;点击download按钮 使用Spark的时候一般都是需要和Hadoop交互的&a…

8.Scala面向对象编程

概述 在这里主要了解Scala中的类、对象和接口 Scala中类和java中的类基本是类似的Scala中的对象是需要定义的&#xff0c;而java中的对象是通过class new出来的Scala中的接口是trait&#xff0c;java中的接口是interface 相关链接 阅读之前&#xff0c;可以浏览一下 scala相关…

chat gpt 在开发当中的应用

chatgpt 出来已经有一段时间了&#xff0c;本人在开发的过程中也是有去使用。 经常使用的是讯飞大模型和通义千问&#xff0c;在使用的过程中&#xff0c;个人感觉讯飞大模型在写代码方面会比较智能。 比如问一个 sqlser 单表 数据量 几个亿如何处理的问题&#xff0c;讯飞会给…