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函数外的,所有函数前加装装饰器。

相关推荐
布局呆星7 分钟前
SQLite数据库的介绍与使用
数据库·python
2401_838472517 分钟前
用Python和Twilio构建短信通知系统
jvm·数据库·python
weixin_4521595515 分钟前
如何从Python初学者进阶为专家?
jvm·数据库·python
Hello.Reader16 分钟前
面向 403 与域名频繁变更的合规爬虫工程实践以 Libvio 系站点为例
爬虫·python·网络爬虫
深蓝海拓30 分钟前
PySide6从0开始学习的笔记(二十五) Qt窗口对象的生命周期和及时销毁
笔记·python·qt·学习·pyqt
一点技术38 分钟前
基于SpringBoot的选课调查系统
java·spring boot·后端·选课调查系统
Dfreedom.40 分钟前
开运算与闭运算:图像形态学中的“清道夫”与“修复匠”
图像处理·python·opencv·开运算·闭运算
2301_7903009644 分钟前
用Python读取和处理NASA公开API数据
jvm·数据库·python
葱明撅腚1 小时前
利用Python挖掘城市数据
python·算法·gis·聚类
Serendipity_Carl1 小时前
1637加盟网数据实战(数分可视化)
爬虫·python·pycharm·数据可视化·数据清洗