Python 从0开始 一步步基于Django创建项目(12)使用装饰器login_required()限制对页面的访问

本文实现功能:

除'主页'和'注册'页之外的所有页面,都只有在用户登录后才能访问。

实施方法:在city_infos的views.py文件中,引入装饰器,并在所有视图函数前应用装饰器。

步骤如下:

1、使用import引入装饰器

python 复制代码
from django.contrib.auth.decorators import login_required #导入函数login_required()

2、在视图函数前使用装饰器

python 复制代码
#将login_required函数作为装饰器,在运行cities代码前,先运行login_required中的代码
#login_required检查用户登录情况,已经登录,才运行cities的代码
#如果未登录,就定向到登录界面
@login_required
def cities(request):
    cities = City.objects.order_by('date_added')
    context = {'cities':cities}
    return render(request,'city_infos/cities.html',context)

3、为了实现重定向,修改city_infos的setting.py文件。该文件位于项目根目录:C:\D\Python\Python310\study\snap_gram\snap_gram

在文件的最后添加如下内容:

python 复制代码
#我的设置
LOGIN_URL = 'users:login'

4、如果只在cities函数前加装'装饰器',未登录用户无法查看城市列表,但是仍旧可以使用url(例如:localhost:8000/new_city/),进行非登录用户不应该执行的操作,如下图所示:

为了防止此类情况,需要在views.py文件除index函数外的,所有函数前加装装饰器。

相关推荐
子木HAPPY阳VIP4 分钟前
Ubuntu 22.04 VMware 设置固定IP配置
人工智能·后端·目标检测·机器学习·目标跟踪
cm6543205 分钟前
用Python破解简单的替换密码
jvm·数据库·python
人间打气筒(Ada)11 分钟前
如何基于 Go-kit 开发 Web 应用:从接口层到业务层再到数据层
开发语言·后端·golang
开心就好202512 分钟前
使用Wireshark进行TCP数据包抓包分析:三次握手与四次挥手详解
后端·ios
wan9yu22 分钟前
为什么你需要给 LLM 的数据"加密"而不是"脱敏"?我写了一个开源工具
python
用户44193950548725 分钟前
OpenClaw服务器部署保姆级教程
后端
zdl68626 分钟前
springboot集成onlyoffice(部署+开发)
java·spring boot·后端
Soofjan28 分钟前
sync.Mutex讲解
后端
Soofjan29 分钟前
sync.RWMutex 源码解析
后端
摇滚侠31 分钟前
你是一名 java 程序员,总结定义数组的方式
java·开发语言·python