后端代码views.py(Django主app下的子app的其中一个文件)
def login(request):
if request.method == 'GET':
return render(request, 'login.html')
接下来是易错点
#登录成功之后,要回到这里 即login路由
elif request.method=='POST':
# 接收用户名参数
username=request.POST.get('user')
# 返回个人中心
response=redirect(reverse('user')) #重定向到个人中心
# 把用户名设置到cookie中
response.set_cookie('username',username)
return response
# 个人中心
def user(request):
# 从cookie中获取用户名
username=request.COOKIES.get('username7ygf')
print(username)
if username:
return HttpResponse('欢迎回来%s'%username)
return HttpResponse('暂未登录,请登录')(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220415193702757.png)
前端login.html代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
#提交之后回到login 通过login重定向到user
<form action="{%url 'login'%}" method="post">
<!--点击表单“提交按钮”之后要回到login路由 进入——>POST继续判断-->
{% csrf_token %}
<!--csrf使用这种和下面这种都可以 防网站攻击 Django自带的(settings中)默认是开启的-->
<!--<input name="csrfmiddlewaretoken" type="hidden" value="QJWwbFuIiqaGLD1TOS9iFJ2CVMAmrDmpQxVq7P3QrWyBI0txc7envabcJjvtlzN8">-->
用户名:
<input type="text" name="user"><br>
<input type="submit" value="提交">
</form>
</body>
</html>
#路由文件urls.py
from django.urls import path
from day11.views import *
urlpatterns=[
path('login', login, name='login'),
path('user', user, name='user'),
]
```python
视图响应的过程:
浏览器地址栏中输入 ----> django获取信息并且去掉ip和端口号,---->保留剩下地址----->urls文件进行路由匹配 ----> 视图响应 --->渲染模板并返回浏览器```
第一次直接进user路由 ——cookie没有设置和记录
首先进入login路由 输入username(用户名)
提交之后通过login重定向到user路由
相关子app的文件目录:
结束语:每天记录自己项目的易错点,如果有相似问题 可以参考。