vue+djiango实现登录功能
admin
2024-03-13 19:34:51
0

思路

1、前端输入用户名+密码发送登录请求给后端
2、后端接到请求后,验证用户名和密码准确性,验证通过返回状态和token给前端。
3、前端收到后端验证登录结果,进行跳转,并将后端返回token保存到本地localStorage
4、前端路由时检查本地token是否存在,不存在返回登录页面,存在的跳转
5、退出登录清除本地token
6、登录页开发一个忘记密码功能

login页面主要代码:

handleLogin() {this.loading = trueif ((this.loginForm.username !== '' && this.loginForm.password !== '')) {const jse = new JSEncrypt() // 实例化一个 jsEncrypt 对象jse.setPublicKey(assetConst.publickey) // 配置公钥const userAccount = jse.encrypt(this.loginForm.username) // 加密账号const passWord = jse.encrypt(this.loginForm.password) // 加密密码axios.post(platformBaseUrl + '/api/login/', { 'username': userAccount, 'password': passWord }).then(response => {console.log(response.data)this.loading = false// eslint-disable-next-line eqeqeqif (response.data.result.isLogin == 1) {// 存储token到本地console.log({ 'token': response.data.token, 'username': response.data.username })this.$store.commit('$_setToken', response.data.token)this.$store.commit('$_setUser', response.data.username)this.$message.success('登录成功')// 跳转到主页this.$router.push({ path: this.redirect || '/' })} else {this.$message.error('校验失败,用户名或者密码错误!')// return false}}).catch(err => {this.loading = falseconsole.log('请求异常! ', err)this.$message.error('咦!怎么报错了!我写的代码怎么会有问题,一定是环境问题!')})} else {this.loading = falsethis.$message.warning('用户名和密码不能为空')}
新建store目录,index.js写入保存缓存的代码```python
const store = new Vuex.Store({modules,getters,state: {// 登陆状态// token存储token: localStorage.getItem('token') ? localStorage.getItem('token') : ''},mutations: {$_setToken(state, value) { // 设置存储tokenstate.token = valuelocalStorage.setItem('token', value)},$_setUser(state, value) { // 设置存储tokenstate.token = valuelocalStorage.setItem('username', value)console.log(localStorage.getItem('username'))},$_removeStorage(_state, _value) { // 删除tokenlocalStorage.removeItem('token')}}
})
export default store

在main.js加入路由拦截功能

import axios from 'axios'
Vue.prototype.$http = axios
Vue.config.productionTip = falseVue.prototype.$http.defaults.baseURL = '/api'
// http request 拦截器
// 请求在到达服务器之前,先会调用use中的这个回调函数来添加请求头信息
axios.interceptors.request.use(config => {// 为请求头对象,添加token验证的Authorization字段var token = localStorage.getItem('token')var username = localStorage.getItem('username')if (username & token) {config.headers.token = tokenconfig.headers.username = username}return config
})// 登录拦截
router.beforeEach((to, from, next) => {console.log(to.meta.requireAuth)if (to.meta.requireAuth) {// requireAuth若为true,则该路由需要判断是否登录if (window.localStorage.token) {next()} else {next({ // 返回登录页面path: '/login',query: { redirect: to.fullPath }})}} else {next()}
})new Vue({axios,router,store,render: h => h(App)
}).$mount('#app')

前端基本就开发完成了。
后端需要开发一个登录接口
主要代码如下

 def login(self):param = self.bodyusername = param.get("username")password = param.get("password")#解密username=RSAUtils.decrypt(username, privateKey)password = RSAUtils.decrypt(password, privateKey)try:sql = f'select * from user where username="{username}"'user = DBmananger().callMysql(sql)[0]logger.info(f"password:{password}")logger.info(f"user.passwd:{user.get('password')}")except Exception as e:date = {'flag': 'login fail', "msg": f'{e}'}logger.error(e)self.data["result"] = datereturn self.dataif password == user.get('password'):date_msg = "登陆成功"isLogin = 1#获取tokenself.data['token']=create_token(username)self.data['username'] =usernameelse:date_msg = "密码输入错误"isLogin = 0self.data["result"] = {'isLogin': isLogin, 'msg': date_msg}return self.data

思路大概就是这个思路,但是初写肯定会有各种问题,主要看报错,缺什么补什么,按照思路来总会出现你想要的画面。
将源码贡献出来吧有需要的可自取:
https://download.csdn.net/download/kairui_guxiaobai/87234242

相关内容

热门资讯

linux入门---制作进度条 了解缓冲区 我们首先来看看下面的操作: 我们首先创建了一个文件并在这个文件里面添加了...
C++ 机房预约系统(六):学... 8、 学生模块 8.1 学生子菜单、登录和注销 实现步骤: 在Student.cpp的...
A.机器学习入门算法(三):基... 机器学习算法(三):K近邻(k-nearest neigh...
数字温湿度传感器DHT11模块... 模块实例https://blog.csdn.net/qq_38393591/article/deta...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
Redis 所有支持的数据结构... Redis 是一种开源的基于键值对存储的 NoSQL 数据库,支持多种数据结构。以下是...
win下pytorch安装—c... 安装目录一、cuda安装1.1、cuda版本选择1.2、下载安装二、cudnn安装三、pytorch...
MySQL基础-多表查询 文章目录MySQL基础-多表查询一、案例及引入1、基础概念2、笛卡尔积的理解二、多表查询的分类1、等...
keil调试专题篇 调试的前提是需要连接调试器比如STLINK。 然后点击菜单或者快捷图标均可进入调试模式。 如果前面...
MATLAB | 全网最详细网... 一篇超超超长,超超超全面网络图绘制教程,本篇基本能讲清楚所有绘制要点&#...
IHome主页 - 让你的浏览... 随着互联网的发展,人们越来越离不开浏览器了。每天上班、学习、娱乐,浏览器...
TCP 协议 一、TCP 协议概念 TCP即传输控制协议(Transmission Control ...
营业执照的经营范围有哪些 营业执照的经营范围有哪些 经营范围是指企业可以从事的生产经营与服务项目,是进行公司注册...
C++ 可变体(variant... 一、可变体(variant) 基础用法 Union的问题: 无法知道当前使用的类型是什...
血压计语音芯片,电子医疗设备声... 语音电子血压计是带有语音提示功能的电子血压计,测量前至测量结果全程语音播报࿰...
MySQL OCP888题解0... 文章目录1、原题1.1、英文原题1.2、答案2、题目解析2.1、题干解析2.2、选项解析3、知识点3...
【2023-Pytorch-检... (肆十二想说的一些话)Yolo这个系列我们已经更新了大概一年的时间,现在基本的流程也走走通了,包含数...
实战项目:保险行业用户分类 这里写目录标题1、项目介绍1.1 行业背景1.2 数据介绍2、代码实现导入数据探索数据处理列标签名异...
记录--我在前端干工地(thr... 这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前段时间接触了Th...
43 openEuler搭建A... 文章目录43 openEuler搭建Apache服务器-配置文件说明和管理模块43.1 配置文件说明...