当前位置: 首页 > news >正文

网站备案 广东discuz 科技网站模板下载

网站备案 广东,discuz 科技网站模板下载,河南建设集团有限公司,开个人网站怎么赚钱目录 总结一、步骤1.安装Axios:2.axios对象封装3.请求api封装4.使用pinia临时库保存响应信息(按需求用)5.最后,在组件中使用! 总结 封装axios对象,编写公共请求代码、添加拦截逻辑、然后分层实现axios请求…

目录

  • 总结
  • 一、步骤
    • 1.安装Axios:
    • 2.axios对象封装
    • 3.请求api封装
    • 4.使用pinia临时库保存响应信息(按需求用)
    • 5.最后,在组件中使用!


总结

封装axios对象,编写公共请求代码、添加拦截逻辑、然后分层实现axios请求的调用!

一、步骤

1.安装Axios:

  • 首先,确保你的项目中已经安装了Axios。如果没有安装,可以通过以下命令安装Axios:
npm install axios

2.axios对象封装

  • 创建一个名为request.js的文件,用于封装Axios对象。
import axios from 'axios'
import { Message } from 'element-ui'
import {tokenStore} from "@/store/store";// 创建一个 Axios 实例
const axiosInstance = axios.create({baseURL: 'http://localhost:8080/qy', // 通用后端 Url 地址timeout: 5000, // 请求最大等待时间,headers: { 'Content-Type': 'application/json' },
})// 添加请求拦截器
axiosInstance.interceptors.request.use((config) => {// 获取请求的URLconst requestUrl = config.url;console.log(requestUrl);// console.log(config);// 提取URL路径部分/qy/Login// const urlPath = new URL(requestUrl).pathname;// 如果是post请求将参数data转成json字符串// 检查请求方法是否为 POSTif (config.method === 'post' || config.method === 'POST') {// 将请求数据转换为 JSON 字符串config.data = JSON.stringify(config.data);// 设置请求头的 Content-Type// config.headers['Content-Type'] = 'application/json';}// 在请求头中添加令牌信息const jwtToken = tokenStore().jwtToken // 从pinia中获取令牌// 检查是否是登录请求,这里假设登录请求的URL是 '/Login'if (requestUrl !== '/Login' && requestUrl !== '/LogOut') {console.log(requestUrl);// 如果不是登录请求,添加令牌到请求头if (jwtToken) {config.headers.Authorization = `${jwtToken}`}}return config},(error) => {return Promise.reject(error)}
)//添加响应拦截器
axiosInstance.interceptors.response.use((response) => {var res = response.data// console.log(res);// 设置请求状态弹窗提示if (res.status == 200) {//请求成功提示Message.success(res.msg);} else {Message.error(res.msg);}// 后端响应Resbody的data数据return res
},(error) => {return Promise.reject(error)}
)export default axiosInstance

3.请求api封装

  • 创建一个api.js文件,默认导入封装好的axios对象
import axiosInstance from "@/request/request"export function login(data) {return axiosInstance({url : "/Login",method : "POST",data})
}export function logOut() {return axiosInstance({url : "/LogOut",method : "get",})
}

4.使用pinia临时库保存响应信息(按需求用)

// 导入pinia库
import { defineStore } from 'pinia';
// 导入api
import { login } from '@/request/api/system';
import { logOut } from '@/request/api/system';
// 导入jwt解析器
import jwtDecode from "jwt-decode";
// 导入默认导出的路由对象用于跳转路由
import router from '@/router/router';export const tokenStore = defineStore({id: 'myStore',state: () => ({jwtToken: null,user_name: null,user_name_id: null,user_type: null,}),actions: {doLogin(params) {login(params).then((res) => {if (res.status == 200) {const jwtToken = res.data; // 从响应中获取JWT// console.log(jwtToken);this.jwtToken = jwtToken; // pinia存储JWTlocalStorage.setItem("jwtToken", jwtToken);console.log(this.user_name);// 解码JWT令牌以获取载荷信息const decodedToken = jwtDecode(jwtToken);console.log(decodedToken);//访问包含在JWT令牌中的用户信息//保存用户类型的id便于门诊医生问诊var user_name_id = decodedToken.user_name_id;//保存用户类型至本地便于控制导航栏的显示与隐藏const userType = decodedToken.user_type;this.user_name_id = user_name_id;console.log(this.user_name_id);this.user_type =userType == 1? "系统管理员": userType == 2? "挂号员": "门诊医生";//跳转到主页router.push("/index");}});},LogOut() {return logOut();}},
});

5.最后,在组件中使用!

  • 点击事件如下
submitForm(formName) {this.$refs[formName].validate((valid) => {if (valid) {//将登陆用户名赋给store管理实现共享this.tokenStore.user_name = this.userForm.userName;//调用axios对象的get发送请求this.tokenStore.doLogin(this.userForm)} else {console.log("error submit!!");return false;}});},
LogOut() {// 删除所有本地缓存包括令牌信息// localStorage.clear();this.tokenStore.LogOut().then((res) => {if (res.status == 200) {// 删除所有本地缓存包括令牌信息localStorage.clear();// 跳转到登录页面this.$router.push({ path: "/Login" });}});// localStorage.removeItem("user_name");// localStorage.removeItem("user_type");},
http://www.yayakq.cn/news/382560/

相关文章:

  • 遵义做网站哪家好网页设计师培训课程多少钱
  • 网站后台管理密码忘记学院网站群建设的目标
  • 常州做网站要多少钱wordpress图片调用
  • 网站开发主要有两个阶段推销一个产品的方案
  • 网站设计好以后怎么上线北湖区网站建设公司哪家好
  • 网站服务器部署seo搜狗
  • 网站建设 大纲舆情网站推荐
  • 网站建设方案确认表Wordpress 用户 AUTO_INCREMENT
  • 网站设计样式建e网怎么赚钱
  • 做网站流程网站服务器可以更换吗
  • 木材加工公司网站建设上海网页设计是什么
  • 在阿里云上建立网站的步骤wordpress 调用备案号
  • 网站知名度苏晋建设集团网站
  • 湖南网络公司网站建设做网站链接的页面怎么做
  • 设计网站导航大全黑马程序员项目库
  • 凡科建站免费株洲seo优化推荐
  • 西宁做网站君博专注站长查询站长工具
  • wordpress仿站模板制作教程建网站浩森宇特
  • 建立官方网站多少钱毕节网站建设公司
  • 简单的做海报的网站如何在网站上显示百度权重
  • 社科联网站建设方案策划书果洛wap网站建设比较好
  • 百度站长平台电脑版网站建设 后台空间容量
  • 网站seo外链淮安谁家做网站
  • 电脑上不了建设厅网站企业服务网
  • 把网站扒下来以后怎么做装修网站模板源码
  • 深圳网站建设培训班网站布局英文
  • 怎么建立公司的网站吗青岛网站排名方案
  • 中国优秀网站设计淘宝网电脑版登录入口
  • 简述网站与网页的区别西安学建网站
  • 电子商务网站开发书例子做一个小程序要多少钱