vue3项目接口调用--注册登录

1.配制pinia定义token

store/user.js

import { defineStore } from 'pinia'
import { ref } from 'vue'

// 用户模块
export const useUserStore = defineStore(
  'big-user',`在这里插入代码片`
  () => {
    const token = ref('') // 定义 token
    const setToken = (t) => (token.value = t) // 设置 token

    return { token, setToken }
  },
  {
    persist: true // 持久化
  }
)

2.封装axios模块

新建utils/request.js

import axios from "axios";
import router from "@/router";
import { ElMessage } from "element-plus";
import { useUserStore } from "@/stores/user";


const baseURL = 'http://big-event-vue-api-t.itheima.net' //请求地址
const instance = axios.create({
    // TODO 1.基础地址 超时时间
    baseURL,
    timeout: 100000
})

//请求拦截 
instance.interceptors.request.use(
    //config 请求拦截器的一个参数 
    //能拿到请求的一些信息,参数,请求头之类
 (config) => {
    // TODO 2.携带token
    const userStore = useUserStore()
    if(userStore.token){
        //通过设置config.headers.Authorization来传递身份验证信息
        config.headers.Authorization = userStore.token
    }
    return config
 },
 (err) => Promise.reject(err)
)
//响应拦截
instance.interceptors.response.use(
    (res) => {
        // TODO 3.处理业务失败
        // TODO 4.摘取核心响应数据
        //res.data 即为后端服务器返回的数据
        //res.data.code === 0 通常用来检查HTTP响应的状态码是否为0。在很多后端系统中
        //0通常表示请求成功,而非0的代码则表示出现了某种错误。
        if( res.data.code === 0){
            return res
        }
        ElMessage({ message:res.data.message ||  '服务异常', type: 'error'})     
        return Promise.reject(res.data)
    },
    (err) => {
        // TODO 5.处理401错误
        ElMessage({message: err.response.data.message || '服务异常', type: 'error' })
        console.log(err);
        if(err.response?.status === 401) {
            //后端返回401,就说明没登录 没token或者token已经过期
            router.push('/login')
        }
        return Promise.reject(err)
    }
)

export default instance
export {baseURL}

3.新建types文件夹定义数据类型

types/params
根据接口文档
在这里插入图片描述

//声明数据类型

// 注册校验数据类型
export type UserRegisterParamsType = {
    username: string
    password: string
    repassword: string
}

4.封装api接口

api/user.js
注册接口
记得引入request以及声明的数据类型

import request from '@/utils/request'
import type { 
    UserRegisterParamsType, 
    UserLoginParamsType 
  } from '@/types/params'
// 调用注册接口
export const userRegisterService = (params:UserRegisterParamsType) => {
    const { username, password, repassword  } = params
    return request.post('/api/reg', { username, password, repassword })
}

5.注册按钮点击事件

//注册之前进行校验 调用接口
const register = async () => {
  await reform.value.validate()
  console.log('开始注册请求');
  await userRegisterService(registerForm.value)
  ElMessage.success('注册成功')
  //切换到登录页
  isRegister.value = false
}

6.登录接口数据类型声明

//登录校验数据类型
export type UserLoginParamsType = {
    username: string
    password: string
}

7.调用登录接口

// 调用登录接口
export const userloginService = (params: UserLoginParamsType ) => {
    const { username, password } = params
    return request.post('/api/login', { username, password })
}

8.登录按钮点击事件

//调用方法将token存入pinia并自动持久化到本地
const userStore = useUserStore()
//调用路由
const router = useRouter()
//登录之前进行校验 调用接口
const login = async () => {
   await form.value.validate()
   console.log('开始登录');
   const res = await userloginService(loginForm.value)
   console.log(res)
   console.log(res.data.token);
   userStore.setToken(res.data.token)
   ElMessage.success('登录成功')
   router.push('/')
}

9.登录访问拦截

//前置路由导航 
//登录访问拦截 => 默认直接放行
//根据返回值绝定是放行还是拦截
//返回值:
//1.undefined / true 直接放行
//2.false拦回from的地址页面
//3.具体路劲 或 路径对象 拦截到对应地址
// '/login' { name: 'login'}
//在beforeEach函数中,参数传递的"to"表示将要访问的路径
router.beforeEach((to) => {
   //判断有无token 且访问的是非登录页 拦截到登录 其他情况正常放行
   // || 二选一
   // && 都要
   const useStore = useUserStore()
   if (!useStore.token && to.path !== '/login') {
    return '/login'
   } else {
    return true
   }
})
  • 6
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
首先,Vue3 是一种 JavaScript 框架,用于构建Web应用程序的前端。它可以与后端 API 集成,以实现登录和注册功能。在这里,我将介绍如何使用Vue3和Node.js创建一个简单的登录和注册系统。 首先,我们需要创建一个Vue3项目。可以使用Vue CLI来创建一个新项目。在命令行中输入以下命令: ``` vue create my-project ``` 这将创建一个新的Vue3项目。接下来,我们需要安装一些依赖项。在项目的根目录下运行以下命令: ``` npm install axios vue-router ``` `axios` 是一个用于发送 HTTP 请求的库,`vue-router` 是Vue3中用于路由的官方库。 接下来,我们需要创建一个后端API。我们将使用Node.js和Express框架来创建API。创建一个新的文件夹,并使用以下命令初始化一个新的Node.js项目: ``` npm init ``` 接下来,我们需要安装一些依赖项。在项目的根目录下运行以下命令: ``` npm install express body-parser cors bcrypt jsonwebtoken ``` 这些依赖项分别是: - `express`:用于创建API的框架。 - `body-parser`:用于解析 HTTP 请求体的库。 - `cors`:用于解决浏览器跨域问题的库。 - `bcrypt`:用于密码哈希的库。 - `jsonwebtoken`:用于生成和验证 JSON Web Tokens 的库。 接下来,我们需要创建一个 `server.js` 文件,并在其中编写我们的API。 首先,我们需要引入我们的依赖项: ```javascript const express = require('express'); const bodyParser = require('body-parser'); const cors = require('cors'); const bcrypt = require('bcrypt'); const jwt = require('jsonwebtoken'); ``` 然后,我们需要创建一个新的Express应用程序,并使用中间件来解析HTTP请求体和处理跨域请求: ```javascript const app = express(); app.use(bodyParser.json()); app.use(cors()); ``` 接着,我们需要定义一些路由来处理用户注册和登录请求。我们将使用一个内存中的数组来保存已注册的用户信息。在实际应用中,应该将这些信息保存在数据库中。 ```javascript const users = []; app.post('/register', (req, res) => { const { username, password } = req.body; // Check if user already exists const userExists = users.find(user => user.username === username); if (userExists) { return res.status(400).json({ message: 'User already exists' }); } // Hash the password const hashedPassword = bcrypt.hashSync(password, 10); // Add the user to the array const newUser = { username, password: hashedPassword }; users.push(newUser); res.status(201).json({ message: 'User created successfully' }); }); app.post('/login', (req, res) => { const { username, password } = req.body; // Find the user by username const user = users.find(user => user.username === username); if (!user) { return res.status(401).json({ message: 'Invalid username or password' }); } // Check the password const passwordMatch = bcrypt.compareSync(password, user.password); if (!passwordMatch) { return res.status(401).json({ message: 'Invalid username or password' }); } // Generate a JWT token const token = jwt.sign({ username }, 'my-secret-key'); res.status(200).json({ token }); }); ``` 这些路由分别用于处理用户注册和登录请求。当用户注册时,我们将检查该用户是否已经存在。如果不存在,我们将对其密码进行哈希,并将其添加到用户数组中。当用户登录时,我们将检查提供的用户名和密码是否匹配,并生成一个 JSON Web Token 来表示该用户已经登录成功。 最后,我们需要启动我们的应用程序。在 `server.js` 文件底部添加以下代码: ```javascript const PORT = 3000; app.listen(PORT, () => { console.log(`Server started on port ${PORT}`); }); ``` 现在,我们已经创建了一个具有简单注册和登录功能的API。接下来,我们需要在Vue3应用程序中使用这些API。 在Vue3应用程序中,我们可以使用 `axios` 库来发送 HTTP 请求。我们需要创建一个 `AuthService` 来处理与后端的通信。 在项目的根目录下创建一个新的文件夹 `services`,并在其中创建一个新的文件 `auth.js`: ```javascript import axios from 'axios'; const API_URL = 'http://localhost:3000'; class AuthService { register(username, password) { return axios.post(`${API_URL}/register`, { username, password }); } login(username, password) { return axios.post(`${API_URL}/login`, { username, password }); } } export default new AuthService(); ``` 这个 `AuthService` 类定义了两个方法:`register` 和 `login`。这些方法分别用于向我们的后端 API 发送注册和登录请求。 现在,我们可以在Vue3组件中使用这些方法来处理用户注册和登录。例如,在登录页面中,我们可以编写以下代码: ```html <template> <div> <h1>Login</h1> <form @submit.prevent="login"> <label> Username: <input type="text" v-model="username" /> </label> <label> Password: <input type="password" v-model="password" /> </label> <button type="submit">Login</button> </form> </div> </template> <script> import AuthService from '@/services/auth'; export default { data() { return { username: '', password: '' }; }, methods: { async login() { try { const response = await AuthService.login(this.username, this.password); localStorage.setItem('token', response.data.token); this.$router.push('/'); } catch (error) { console.error(error); } } } }; </script> ``` 在这个组件中,我们使用 `AuthService` 来处理用户登录请求。当用户提交表单时,我们将调用 `login` 方法来发送 HTTP 请求。如果请求成功,我们将得到一个包含 JWT token 的响应,并将其存储在本地存储中。然后,我们将使用Vue3的路由功能将用户重定向到主页。如果请求失败,我们将在控制台上输出错误信息。 类似地,我们可以编写一个用于处理用户注册请求的组件。在这个组件中,我们将使用 `AuthService` 的 `register` 方法来发送 HTTP 请求。 这就是如何使用Vue3和Node.js创建一个简单的登录和注册系统。当然,这只是一个基本示例,实际应用中需要更多的安全考虑和验证。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值