第12天:前端集成与Django后端 - 用户认证与状态管理

第12天:前端集成与Django后端 - 用户认证与状态管理

目标

整合Django后端与Vue.js前端,实现用户认证和应用状态管理。

任务概览
  1. 设置Django后端用户认证
  2. 创建Vue.js前端应用
  3. 使用Vuex进行状态管理
  4. 实现前端与后端的用户认证流程
详细步骤
1. Django后端设置

确保Django后端具备用户认证和Token认证系统。

  • 配置REST_FRAMEWORKsettings.py中添加Token认证。
REST_FRAMEWORK = {'DEFAULT_AUTHENTICATION_CLASSES': ['rest_framework.authentication.TokenAuthentication',],
}
  • 创建用户认证相关的API端点(登录、登出、用户信息获取)。
2. Vue.js前端应用

使用Vue.js创建前端应用。

  • 使用Vue CLI创建新项目。
  • 设置Vue Router进行页面路由。
// Vue Router配置
const router = new VueRouter({routes: [{ path: '/login', component: Login },{ path: '/home', component: Home, meta: { requiresAuth: true } },// 其他路由...],
});
3. Vuex状态管理

在Vue.js中使用Vuex管理应用状态。

  • 安装Vuex并创建store。
npm install vuex@next --save
  • 配置Vuex store。
// store/index.jsimport { createStore } from 'vuex';export default createStore({state: {isAuthenticated: false,userData: null,},mutations: {setAuthState(state, { isAuthenticated, userData }) {state.isAuthenticated = isAuthenticated;state.userData = userData;},},actions: {login({ commit }, credentials) {// 实现登录逻辑},logout({ commit }) {// 实现登出逻辑},},
});
4. 用户认证流程

实现前端登录和登出逻辑,与Django后端交互。

  • 使用Fetch API与Django后端API通信。
// Vuex actions中实现登录login({ commit }, credentials) {fetch('/api/auth/login/', {method: 'POST',body: JSON.stringify(credentials),headers: { 'Content-Type': 'application/json' },}).then(response => response.json()).then(data => {commit('setAuthState', { isAuthenticated: true, userData: data.user });localStorage.setItem('authToken', data.token);});
},
  • 保护Vue路由,实现基于状态的导航守卫。
// Vue Router导航守卫router.beforeEach((to, from, next) => {const requiresAuth = to.matched.some(route => route.meta.requiresAuth);const isAuthenticated = store.state.isAuthenticated;if (requiresAuth && !isAuthenticated) {next('/login');} else {next();}
});
学习要点
  • Django后端用户认证系统的配置和使用。
  • Vue.js前端应用的创建和Vue Router的使用。
  • Vuex在状态管理中的应用。
  • 前后端用户认证流程的实现。
每日回顾
  • 确保Django后端API能够处理认证请求并返回正确的响应。
  • 测试Vue.js前端是否能够正确处理用户登录和登出,以及状态的更新。

通过今天的学习,你应该能够实现一个基本的用户认证流程,并通过Vuex管理用户认证状态。明天,我们将继续深入Vue.js和Vuex,学习如何实现更复杂的数据交互和状态管理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/32955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows无法启动redis-server

Warning: no config file specified, using the default config. In order to specify a config file use D:\Code_enve\Redis\redis-server.exe /path/to/redis.conf Creating Server TCP listening socket *:6379: bind: No such file or directory以上是问题的报错信息&…

AIGC-Animate Anyone阿里的图像到视频 角色合成的框架-论文解读

Animate Anyone: Consistent and Controllable Image-to-Video Synthesis for Character Animation 论文:https://arxiv.org/pdf/2311.17117 网页:https://humanaigc.github.io/animate-anyone/ MOTIVATION 角色动画的目标是将静态图像转换成逼真的视频,这在在线零…

vue.js获取body高度

在mounted生命周期钩子中获取: export default {mounted() {this.bodyHeight document.body.offsetHeight;},data() {return {bodyHeight: 0};} }; export default {data() {return {bodyHeight: 0};},mounted() {this.bodyHeight window.innerHeight;} };expor…

如何高效地为pip换源:详细操作指南

在Python开发中,pip是我们不可或缺的包管理工具。然而,默认的官方源下载速度较慢,尤其是在国内使用时可能会遇到网络问题。为了提高下载速度,我们可以通过更换国内的镜像源来解决这一问题。本文将详细介绍如何高效地为pip换源&…

计网:网络应用层【Email应用/SMTP协议】

Email应用与SMTP协议 Email应用层的构成 客户端服务器协议 用户代理 用于读写邮件消息;与服务器交互,收发邮件消息 常见的客户端:Outlook,Foxmail(这两个是需要下载的客户端),Web客户端&…

【论文复现|智能算法改进】一种基于多策略改进的鲸鱼算法

目录 1.算法原理2.改进点3.结果展示4.参考文献5.代码获取 1.算法原理 SCI二区|鲸鱼优化算法(WOA)原理及实现【附完整Matlab代码】 2.改进点 混沌反向学习策略 将混沌映射和反向学习策略结合,形成混沌反向学习方法,通过该方 法…

python中不同维度的Tensor向量为何可以直接相加——广播机制

文章目录 广播机制示例解释广播机制如何工作代码示例输出解释广播机制的本质 在矩阵加法中,如果两个张量的形状不同,但其中一个张量的形状可以通过广播机制扩展到与另一个张量的形状相同,则可以进行加法操作。广播机制在深度学习框架&#xf…

VB实现加法计算

textbox1失去焦点,检查输入的值是否为数字。 textbox2中按下Enter键,检查输入的值是否为数字。 textbox3获得焦点,计算textbox1和textbox2的和。 Public Class Form1Private Sub TextBox1_LostFocus(sender As Object, e As EventArgs) Hand…

计算机组成原理-第6章计算机的运算方法

6.1无符号数和有符号数 6.1.1无符号数 没有符号,在寄存器中的每一位均可用来存放数值。 6.1.2有符号数 1,机器数与真值:0表示正,1表示负。 把符号数字化的数称为机器数,而把带或-符号的数称为真值。 2&#xff0…

Python爬虫从入门到精通,大概需要多长时间的投入呢

从Python爬虫入门到精通所需的投入时间因个体差异而异,因为每个人的学习速度、背景知识和学习动力都有所不同。然而,我可以提供一个大致的时间框架和建议,帮助你规划你的学习路径。 入门阶段 时间估计:1-3个月 基础知识&#x…

React@16.x(38)路由v5.x(3)其他组件

目录 1,Link2,NavLink3,Redirect 之前的文章中,已经介绍过了 BrowserRouter / HashRouter,Route,Switch,withRouter 这些组件。 再介绍3个常用的组件: 1,Link 官方文档…

基于Django + Web + MySQL的智慧校园系统

基于Django Web MySQL的智慧校园系统 由于时间紧迫,好多功能没实现,只是个半吊子的后台管理系统,亮点是项目安全性还算完整,权限保护加密功能检索功能有实现,可参考修改 功能如下(服务为超链接&#xff0…

面试突击指南:Java基础面试题1

1. Lambda表达式 Lambda表达式提供了一种简洁的方式来实现接口的单个抽象方法,通常用于替代匿名类。 示例: List<String> names = Arrays.asList("peterF", "anna", "mike", "xenia"); Collections.sort(names, (a, b) -&g…

java面向对象(4)

目录 1.多态 1.1如何构成多态 1.2多态的调用规则 1.3多态的向下转型 1.4 instanceof运算符 1.5多态的好处 2.final关键字 3.接口 3.1接口中可以定义哪些成员 3.2接口的使用 3.2接口的特性 1.多态 多态:同一种事物,在不同的时刻表现出不同的状态 1.1如何构成多态 …

yii2 ActiveForm使用技巧

持续更新&#xff1a; 1、搜索输入框&#xff1a;form-inline <?php $form ActiveForm::begin([action > [index],method > get,options > [class > form-inline] &#xff08;增加此行代码&#xff09; ]); ?>

PBR网络数据流量分流+NQA联动静态路由

一、实验目的&#xff1a; 企业有两个网段&#xff0c;业务1网段和业务2网段&#xff0c;拓扑图如下&#xff0c; 二、实验要求 pc1报文走左侧链路到达ar1&#xff0c;pc2报文走右侧链路到达ar1&#xff0c;且当ar2或者ar3发生故障时候&#xff0c;可以通过另一个设备到达ar1…

1.4 Kettle 数据同步工具详细教程

工具介绍 一、概述 Kettle&#xff0c;又名 Pentaho Data Integration&#xff08;PDI&#xff09;&#xff0c;是一个开源的数据集成工具&#xff0c;最初由 Pentaho 公司开发。它能够从多种数据源提取、转换并加载&#xff08;ETL&#xff09;数据&#xff0c;适用于数据仓…

字符串根据给定关键词进行高亮显示

问题 一般使用搜索引擎的时候我们会发现,搜索出来的内容都对我们搜索的关键词进行了高亮显示, 这样我们能很直观的看出是不是我们想要的结果, 最近我也遇到了类似的功能, 因为关于舆情的系统使用到了ES, 一开始心想ES本身就有支持的API实现起来不难, 但我这里的需求还不太一样…

Altera的JTAG电路下载模块为何上下拉电阻,不可不知的秘密

一、FPGA背景信息 当前的FPGA市场上有国际和国产两大体系&#xff0c;国际排名&#xff0c;一直很稳定&#xff0c;国际上前三名Xilinx、Altera、Lattice&#xff0c;国内FPG厂商也在填补空白&#xff0c;低端、中低端市场上发力&#xff0c;替代潮流已在兴起&#xff0c;目前…

【驱动篇】龙芯LS2K0300之单总线驱动

实验过程 实验目的&#xff1a; 在龙芯开发板上面使用单总线驱动DS18B20温度传感器 ① 根据原理图连接DS18B20模块 ② 将i2c0引脚的功能复用为GPIO ③ 注册字符设备&#xff0c;按照DS18B20的读写时序编写读写驱动接口 ④ 编写测试用例解析传感器的数值 原理图 将板子上…