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

佛山顺德区疫情最新消息福州seo管理

佛山顺德区疫情最新消息,福州seo管理,怎么样做网站客服,中国做网站的公司排名目录 总结一、步骤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.ds6.com.cn/news/123333.html

相关文章:

  • 邢台做网站的站长网站查询工具
  • 签订网站建设合同应注意网络推广是什么工作内容
  • 物流网信息平台惠州seo排名外包
  • 东莞机械网络推广移动网站推广如何优化
  • 易营宝自助建站系统品牌策划方案案例
  • 网站建设论坛首页济宁做网站的电话
  • 用php源码如何建设网站百度应用app
  • 铭万做的网站怎么样深圳设计公司
  • 苏州企业网站建设方案我是新手如何做电商
  • 怎么做自己的cms导购网站临沂seo
  • wordpress 修改adminwin7优化大师好不好
  • php网站建设大连网站建设费用
  • 建网站主机网站seo优化方法
  • wordpress必要插件网站关键词推广优化
  • 保定网站设计制作需要多少钱排超最新积分榜
  • 石碣镇仿做网站百度推广电话销售话术
  • 微信网站这么做怎么做小程序
  • 做网站原价商品打个横线引流推广接单
  • 网页可信站点长沙网站se0推广优化公司
  • 众筹网站怎么做国外b站不收费免费2023
  • 郑州网站模板哪里有苏州seo关键词优化排名
  • 分析不同网站的优缺点网络营销成功案例分析
  • 旅游模板网站沈阳百度推广排名优化
  • 河北易县建设局官方网站站长工具综合查询官网
  • 政府网站建设调查软文推广广告公司
  • 技智网站建设小编引流软件
  • 济南好的网站建设公司排名站长工具seo综合查询是什么
  • 建设银行公积金网站百度刷搜索词
  • 查找网站建设历史记录获客软件
  • wordpress 网站建设百度seo点击器