登录注册完整流程
来源: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
账号: 密码:
- 第二步 :将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组件:
{{ token_username }}
- 第五步:前台路由就可以读取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 | 20小时前 | 索引 数据类型 字符集 存储引擎 CREATETABLE
- MySQL新建表操作指南与建表技巧
- 462浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 条件判断
- CASEWHEN条件判断的嵌套使用详解与实战场景分析
- 469浏览 收藏
-
- 数据库 · MySQL | 1个月前 | java php
- CSV文件批量导入MySQL的性能优化秘籍大揭秘
- 289浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- GaleraCluster多主集群配置与冲突解决攻略
- 239浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 窗口函数实战
- MySQL窗口函数实战案例深度剖析
- 315浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 自定义函数
- MySQL插件开发入门:自定义函数(UDF)编写指南
- 184浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- Windows系统MySQL8.0免安装版配置攻略
- 227浏览 收藏
-
- 数据库 · MySQL | 1个月前 | MySQL错误 数据库诊断
- 深度解析错误代码1045/1217/1205的根本原因及解决方案
- 202浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 16次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 24次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 30次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 42次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 35次使用
查看更多
相关文章
-
- 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浏览