JinPiKa
全球最大的代码托管平台
登录
其他登录方式
import axios from 'axios'
const requeset=axios.create({
baseURL: import.meta.env.BASE_URL, //基础路径
timeout:5000 //发请求超时时间为5s
})
//给request实例添加请求拦截器
request.interceptors.request.use((config)=>{
// config:配置对象:里面有个headers属性请求头,经常给服务器端通过请求头携带公共参数
return config
})
//配置响应拦截器
request.interceptors.response.use(
//成功响应:返回服务端的数据
(response)=>{
return response.data
},
//失败响应:会返回错误对象,用来处理http网络错误
(error)=>{
// 存储网络错误信息
let message = ''
// 根据http状态码判断网络错误
const status = error.response.status
switch (status) {
case 401:
message = '登录已过期,请重新登录'
break
case 403:
message = '没有权限,请联系管理员'
break
case 404:
message = '请求资源不存在'
break
case 500:
message = '服务器内部错误'
break
default:
// eslint-disable-next-line @typescript-eslint/no-unused-vars
message = '网络错误'
break
}
// 提示错误信息
ElMessage({
type: 'error',
message,
})
// 返回一个失败的promise对象
return Promise.reject(error)
}
)
// 引入 pinia
import { createPinia } from 'pinia'
// 创建大仓库
const pinia = createPinia()
// 对外暴露
export default pinia
// 引入仓库
import pinia from './store'
// 全局使用 pinia
app.use(pinia)
// 引入封装好的 request
import request from '@/plugins/request'
// 引入用户相关的 ts 类型检测
import { loginForm, loginResponseData } from './type'
//用户相关接口的请求地址
enum API{
//用户登录的请求地址:在接口文档中,去掉默认请求地址baseURL后剩下的部分
LOGIN='/admin/login'
}
//登录接口
export const reqLogin=(data:loginForm)=>{
request.post(API.LOGIN,data)
}
// 封装登录相关接口
import { loginForm } from '@/apis/user/type'
import request from '@/utils/request'
export function useLoginAPI(data: loginForm) {
return request({
url: 'http://monitor-spring.jinxinapp.cn/api/v1/admin/login',
method: 'POST',
data,
})
}
// 用户相关的小仓库
import { defineStore } from 'pinia'
//引入登录接口
import {reqLogin} from '@/api/user/index.ts'
const useUserStore=defineStore('user',{
state:()=>{
return{
token:localStorage.getItem('token'),
}
},
actions:{
//用户登录的方法,data是登录时传入的账号密码
async useLogin(data:loginForm){
//登录请求
const result=awiat reqLogin(data)
if(result.code==200){
this.token=result.data.token
localStorage.getItem('token',result.data.token)
return 'ok'
}else{
return Promise.reject(new Error(result.data.message))
}
}
},
getters:{}
})
export default useUserStore
const tologin=async ()=>{
try{
//调用仓库里的登录方法,传入的loginForm里面是账号密码
await useStore.userLogin(loginForm)
$router.push('/home') //登录成功跳转首页,
ElNotification({
title: '成功',
message: '登录成功',
type: 'success',
})
}catch(error){
ElNotification({
message: (error as Error).message,
type: 'error',
})
}
}