102.限制请求的method装饰器:require_http_methods,require_GET,require_POST,require_safe
2021-04-17 23:27
阅读:338
YPE html>
标签:创建时间 传递 django text 方法 首页 产生 ext color
客户端与服务器之间最常用的两种请求方式:
1. GET请求一般是用来向服务器索取数据,但不会向服务器提交数据,不会对服务器的状态进行更改。
2.POST请求一般是用来向服务器提交数据,会对服务器的状态进行更改。
限制请求装饰器:
Django内置的视图装饰器可以给视图提供一下限制,比如正视图只能通过GET的method访问等。常用的内置视图装饰器:
1. django.http.decorators.http.require_http_methods: 这个装饰器需要传递一个允许访问的方法的列表。
(1)比如,如果客户端发送的是GET请求,就返回给用户一个添加文章的界面;如果发送的是POST请求,就将提交的数据进行保存到数据库中。views.py文件中示例代码如下:
from django.views.decorators.http import require_http_methods
from django.http import HttpResponse
from django.shortcuts import render
from .models import Article
@require_http_methods(['GET', 'POST'])
def index2(request):
if request.method == 'GET':
return render(request,'static/add.html')
else:
title = request.POST.get('title')
content = request.POST.get('content')
price = request.POST.get('price')
Article.objects.create(title=title, content=content, price=price)
articles = Article.objects.all()
return render(request, 'static/index.html', context={'articles': articles}
(2)index.html示例代码如下:
Title
标题
内容
价格
创建时间
{% for article in articles %}
{{ article.title }}
{{ article.content }}
{{ article.price }}
{{ article.create_time }}
{% endfor %}
(3)urls.py文件中示例代码如下:
from django.urls import path
from article import views
urlpatterns = [
path('', views.index, name='index'),
path('add/', views.add, name='add'),
path('add2/', views.index2, name='add2'),
]
在Postman软件中,采用POST请求输入url:127.0.0.1:3000/add2/(在这里我修改了端口号为3000,默认情况为8000),并且在URL下面的Body中传入需要的参数值title,content,price.返回这样的结果:
在Postman软件采用GET请求访问url:127.0.0.1:3000/add2/,就会返回添加文章的页面,但是在Postman中,即使在表单中输入了数据点击提交按钮之后也没有任何反应,所以可以在浏览器中使用GET请求访问。点击提交按钮,就可以在数据库中看到新添加的文章信息了。
2. django.views.decorators.http.require_GET: 这个装饰器相当于是require_http_methods([‘GET‘])的简写形式,只允许使用GET的method来访问视图。
(1)比如,我们只允许GET请求访问首页,views.py文件中示例代码如下:
from django.views.decorators.http import require_GET
@require_GET
def index(request):
articles = Article.objects.all()
return render(request, 'static/index.html', context={'articles':articles})
(2)index.html中示例代码如下:
{% for article in articles %}
- {{% article.title %}}
- {{% article.content %}}
- {{% article.price %}}
{% endfor %}
3. django.views.decorators.http.require_POST: 这个装饰器相当于是require_http_methods([‘POST‘])的简写形式,只允许使用POST请求的method来访问视图,示例代码如下:
from django.views.decorators.http import require_POST
@require_POST
def add(request):
title = request.POST.get('title')
content = request.POST.get('content')
Article.objects.create(title=title, content=content)
return HttpResponse('success')
4. django.views.decorators.http.require_safe: 这个装饰器相当于是require_http_methods([‘GET‘, ‘HEAD‘])的简写形式,只允许使用相对安全的方式来访问视图,因为GET和HEAD不会对服务器产生增删改的行为,因此这是一种相对安全的请求方式。
102.限制请求的method装饰器:require_http_methods,require_GET,require_POST,require_safe
标签:创建时间 传递 django text 方法 首页 产生 ext color
原文地址:https://www.cnblogs.com/guyan-2020/p/12287737.html
上一篇:CSS Sprite雪碧图应用
下一篇:nginx连接PHP-fpm
文章来自:搜素材网的编程语言模块,转载请注明文章出处。
文章标题:102.限制请求的method装饰器:require_http_methods,require_GET,require_POST,require_safe
文章链接:http://soscw.com/index.php/essay/76137.html
文章标题:102.限制请求的method装饰器:require_http_methods,require_GET,require_POST,require_safe
文章链接:http://soscw.com/index.php/essay/76137.html
评论
亲,登录后才可以留言!