登录注册完整流程
来源:SegmentFault
2023-01-29 10:43:22
0浏览
收藏
你在学习数据库相关的知识吗?本文《登录注册完整流程》,主要介绍的内容就涉及到MySQL、前端、Node.js、vue.js,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
开发场景描述:
当准备从零开始做一个项目时,此时前后台同时开发,由于后台可能会由于时间问题不能提供数据,此时就需要前端人员模拟数据,例如Mock。在外面的Vue中,同样可以实现mock的操作模拟数据。
需要对 JWT (Json Web Token) 和 token 有一定认知。
· 首先打开Apache 和 MySQL
实现登录部分
- 第一步 :搭建vue基本项目框架,前端安装 npm i --save axios ,创建一个登录页面 Login
<template><div> 账号:<input type="text" placeholder="账号" v-model="username"> 密码:<input type="text" placeholder="密码" v-model="password"><button>登录</button> </div> </template><script> export default { data(){ return{ username:"", password:"" } }, methods:{ myLogin(){ //登录流程 } } } </script>
- 第二步 :将Login引入路由并配置
- 第三步:用 mock 模拟后台数据,在项目根目录下创建一个 mock 文件夹,打开终端安装 npm i --save express axios ,mock下分别创建两个文件index.js 和 router.js
index.js文件 const express = require("express"); const app = express(); const router = require("./router") const bodyParser = require("body-parser"); app.use(bodyParser.urlencoded({ extended:true })) app.use("/api",router) app.listen(3000,() =>{ console.log("服务器运行在3000端口上"); })
router.js文件 const express = require("express"); const router = express.Router(); router.post('/login',(req,res)=>{ const username = req.body.username; const password = req.body.password; if(username && password){ res.send({ msg:"登录成功", code:200 }) }else{ res.send({ msg:"登录失败", code:400 }) } }) module.exports = router;
- 先用 postman 测试,这样容易分别是前端出错还是后台出错,如果可以获取成功后执行下一步
- 回到前台,创建 utils 文件夹,里边创建 request.js 并配置
//封装网络请求:Axios import axios from "axios" import qs from "query-string" // 错误信息的响应方法 const errorHandle = (status,other) => { switch(status){ case 400: // 请求头和服务器的限制 console.log(" 服务器不理解请求的语法"); break; case 401: // token验证失败,用户身份验证失败 console.log("(未授权) 请求要求身份验证"); break; case 403: // 用户身份过期了,服务器请求限制 console.log("(禁止) 服务器拒绝请求"); break; case 404: // 网络请求地址错误 console.log("(未找到) 服务器找不到请求的网页。"); break; default: console.log(other); break; } } // 创建axios对象 const instance = axios.create({ timeout:5000 // 请求超时 }) // 全局配置 instance.defaults.baseUrl = "http://iwenwiki.com"; // instance.defaults.headers.common['Authorization'] = AUTH_TOKEN; instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'; // 创建请求拦截和响应拦截操作 instance.interceptors.request.use(config =>{ // 配置 if(config.method === 'post'){ config.data = qs.stringify(config.data); } return config; }, error => Promise.reject(error) ) instance.interceptors.response.use( // 成功 /** * 成功和失败的判断: * 1.请求成功和请求失败 * 2.请求成功:结果的成功和结果的失败 * * 真正好的代码: * 1.可读性高 * 2.可维护性强 * 不是流水账的代码!!! * 面向对象的思维方式:OOP */ response => response.status === 200 ? Promise.resolve(response) : Promise.reject(response), // 我们自己封装的,所以为了代码的清晰可读性,我们需要增Promise // response => response, error => { const { response } = error; // ES6的解构赋值 /** * response包含的信息: * status * data */ if(response){ // 给出开发者具体的错误信息 errorHandle(response.status,response.data); return Promise.reject(response); }else{ console.log("请求中断或者断网了"); } } ) export default instance;
再创建一个 api 文件夹,里边分别创建 base.js 用来存储路径;index.js 来存储封装的网络请求
//base.js文件 const base = { baseUrl:'/api', login:'/api/login' } export default base;
//index.js文件 import base from './base' import axios from '../utils/request' const api = { // 登录接口 getLogin(params){ return axios.post(base.baseUrl + base.login,params) } } export default api;
- 解决跨域问题:在项目根目录下创建一个vue.config.js配置文件并设置配置项:
//vue.config.js文件 module.exports = { devServer:{ proxy:{ "/api":{ target:"http://localhost:3000/", pathRewrite:{ //重写路径 "^/api":"" }, changeOrigin:true //允许跨域 } } } }
- 在Login组件中获取数据
methods:{ myLogin(){ this.$api.getLogin({ username:this.username, password:this.password }).then(res=>{ console.log(res); }) } }
实现登录验证部分
场景:点击进入 about 页面验证用户是否登录,如果登录成功则可以进入 about 页面,如果用户未登录或者登录不成功则自动跳转到 Login 登录页面。这里有两个知识点 token 和 jwt(json web token)
- 第一步:给 about组件设置路由元信息。
{ path: '/about', name: 'About', meta:{ isLogin:true }, component: () => import('../views/About.vue') }
- 第二步:后台生成 token。在mock文件中创建一个 config.js 并配置
module.exports = { jwtSecret:"somesecrtekeyforjsonwebtoken" //真实项目中是后台负责的 }
- 第三步:后台配置路由。后台安装 npm i --save jsonwebtoken 并且在router.js 中配置
const config = require("./config"); const jwt = require("jsonwebtoken"); //生成token const token = jwt.sign({ username: username, password: password }, config.jwtSecret); res.send({ ... token:token, username:username })
- 第四步:此时前台浏览器就能打印拿到token,然后将它保存到本地,
修改Login组件:
<template><div> <div v-if="token_username.length <= 0"> <input placeholder="用户名" type="text" v-model="username"><input placeholder="密码" type="text" v-model="password"><button>登陆</button> </div> <div v-else> {{ token_username }} </div> </div> </template><script> export default { name: "Login", data() { return { username: "", password: "", token_username:"" }; }, created(){ if(localStorage.getItem("token")){ this.token_username = localStorage.getItem("username"); } }, methods: { loginHandle() { // 登陆流程 this.$api.getLogin({ username: this.username, password: this.password }).then(res => { if(res.data.code == 400){ alert("用户名密码错误"); }else{ this.token_username = res.data.username; localStorage.setItem("token", res.data.token); localStorage.setItem("username",res.data.username) } }); }, logoutHandle(){ localStorage.removeItem("token"); localStorage.removeItem("username"); this.token_username = ""; //让页面刷新 this.$router.push("/login"); } } }; </script>
- 第五步:前台路由就可以读取token值了,编辑
router.beforeEach((to,from,next) =>{ if(to.meta.isLogin){ // token:令牌 var token = localStorage.getItem("token"); if(token){ next(); }else{ next({ path:"/login" }) } }else{ next(); } })
实现登录服务器端验证部分
- 第一步:新创建一个mysql数据库,创建表,插入数据:username : joe和password : 8888。
- 第二步:打开后台终端安装数据库 npm i --save mysql
- 第三步:在 mock 文件夹下创建一个 SQLConnect.js 文件用来连接数据库
const mysql = require("mysql"); const MySQLObj = { host:"localhost", user:"root", password:"", database:"web1910" //库名 } const client = mysql.createConnection(MySQLObj); function SQLConnect(sql,arr,callback){ client.query(sql,arr,(error,result)=>{ if(error){ console.log(error); return; } callback(result); }) } module.exports = SQLConnect;
- 后台路由引入并且配置
const SQLConnect = require("./SQLConnect"); const sql = "select * from user where username=? and password=?"; const arr = [username, password]; SQLConnect(sql, arr, result => { if (result.length > 0) { const token = jwt.sign({ username: username, password: password }, config.jwtSecret); res.send({ msg: "登陆成功", code: 200, token: token, username: username }) } else { res.send({ msg: "登陆失败", code: 400 }) } })
- 成功实现登录验证。当点击 About 页面时,验证用户是否登录,如果登录则进入 About 页面;如果没有登录则跳转到 Login 登录页面。在 Login 页面用户输入账号密码点击登录时,再次验证输入的账号密码是否正确,如果正确则进入到 Login 页面,此时可以被允许进入 About 页面了;如果账号或者密码错误则显示提示消息。当点击 退出登录 按钮时,清除存储在本地 localStorage 里边的数据,并且通过将存储的用户名更改为空字符串来实现页面刷新的效果 this.token_username = " "; 通过 this.$router.push("/login") 回到初始化的 Login 登录页面
- 下面附上部分文件完整的代码
//mock后台路由router.js文件 const express = require("express"); const router = express.Router(); const config = require("./config"); const jwt = require("jsonwebtoken"); const SQLConnect = require("./SQLConnect"); router.post("/login", (req, res) => { const username = req.body.username; const password = req.body.password; const sql = "select * from user where username=? and password=?"; const arr = [username, password]; SQLConnect(sql, arr, result => { if (result.length > 0) { const token = jwt.sign({ username: username, password: password }, config.jwtSecret); res.send({ msg: "登陆成功", code: 200, token: token, username: username }) } else { res.send({ msg: "登陆失败", code: 400 }) } }) }) module.exports = router;
//src文件下前端路由router.js文件 import Vue from 'vue' import VueRouter from 'vue-router' import Home from '../views/Home.vue' import Login from "../views/Login" Vue.use(VueRouter) const routes = [ { path: '/', name: 'Home', component: Home }, { path:"/login", component:Login }, { path: '/about', name: 'About', meta:{ isLogin:true }, component: () => import('../views/About.vue') } ] const router = new VueRouter({ mode: 'history', base: process.env.BASE_URL, routes }) router.beforeEach((to,from,next) =>{ if(to.meta.isLogin){ // token:令牌 var token = localStorage.getItem("token"); if(token){ next(); }else{ next({ path:"/login" }) } }else{ next(); } }) export default router
今天带大家了解了MySQL、前端、Node.js、vue.js的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
版本声明
本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- Session的销毁方式到底有哪些?

- 下一篇
- 难以将MySQL数据转换为PostgreSQL?dbForge Studio for MySQL了解一下!
评论列表
-
- 阔达的路人
- 这篇文章内容出现的刚刚好,太细致了,很棒,已加入收藏夹了,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-02-07 02:54:58
-
- 欢呼的曲奇
- 很好,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享博文!
- 2023-02-06 00:40:39
查看更多
最新文章
-
- 数据库 · MySQL | 1天前 |
- MySQL设置中文界面,超简单教程来了!
- 332浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql 索引提示
- MySQL进阶必看!FORCE/USE/IGNOREINDEX用法大揭秘
- 182浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- 手把手教你写MySQL存储过程,小白也能轻松上手
- 163浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql group by
- MySQL分组查询优化:GROUPBY原理+索引优化超全解析
- 324浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL设置中文语言,轻松拥有中文界面
- 211浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL建库语句从入门到精通:创建数据库+设置字符集&排序规则(附实例)
- 176浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- 从零开始学MySQL数据库操作,小白轻松变大神!
- 496浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL插入日期到时间字段,轻松搞定日期格式
- 484浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql 数据压缩
- MySQL怎么实现高效压缩存储?表压缩+列式存储详细解读
- 272浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql JOIN优化
- MySQL优化JOIN操作:七大技巧教你提升关联查询速度
- 106浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL出现中文乱码?超详细解决方案一次性搞定
- 211浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL主从复制这样配!搞懂这些参数,replication稳了~
- 131浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 19次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 50次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 58次使用
-
- 稿定PPT
- 告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
- 53次使用
-
- Suno苏诺中文版
- 探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
- 57次使用
查看更多
相关文章
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览