首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django教程(二)- Django视图与网址进阶1. HTML表单2.CSRF3.代码操作

HTML表单 HTML 表单用于搜集不同类型的用户输入。 表单是一个包含表单元素的区域。...表单使用表单标签 来设置: input elements HTML 表单 - 输入元素 多数情况下被用到的表单标签是输入标签()。...在所有 ajax POST 请求里,添加一个 X-CSRFTOKEN header,其值为 cookie 里的 csrftoken 的值 Django 里如何使用 CSRF 防护: 首先,最基本的原则是...要启用 django.middleware.csrf.CsrfViewMiddleware 这个中间件 再次,在所有的 POST 表单元素时,需要加上一个 {% csrf_token %} tag 在渲染模块时...login.html 3.建立项目视图的练习,详情请见Django教程(一)- Django视图与网址 ? 逻辑示意图.png 定义视图函数 ?

4.3K40
您找到你想要的搜索结果了吗?
是的
没有找到

Django获取HTTP请求体数据

Django获取HTTP请求体数据 请求体的数据格式是多种多样的,可以是表单类型字符串,可以是JSON字符串,可以是XML字符串。 通常,都是在POST请求中携带请求体参数。...Django默认开启了CSRF防护,会对POST,PUT,DELETE,PATCH请求方式进行CSRF防护验证,之后,我会专门写文章来讲述XSS攻击和CSRF攻击。...现在,可以先注释掉settings.py中的MIDDLEWARE列表中的 'django.middleware.csrf.CsrfViewMiddleware' 表单类型 Form Data 前端发送的表单类型的请求体数据...,可以通过request.POST属性获取,返回QueryDict对象。..."}) 使用PostMan进行请求: 非表单类型 Non-Form Data 非表单类型的请求体数据,Django无法自动解析,可以通过request.body属性获取原始的请求体数据,自己按照请求体格式

1.7K20

Django 安全之跨站点请求伪造(CSRF)保护

,则可以针对特定视图使用csrf_protect()修饰器,如下: from django.views.decorators.csrf import csrf_protect @csrf_protect...相反的,如果中间件已经开启,但是又不想针对特定视图使用中间件保护,则可以针对特定视图使用csrf_exempt() 修饰器 from django.views.decorators.csrf import.../en/2.1/ref/csrf/#utilities html模板配置 开启CSRF中间件的情况下,要在html模板中为使用post方法的form表单新增 csrf_token tag,如下: 注意:如果被渲染的view视图未使用csrf_token模板标签,Django可能不会设置CSRF token cookie。...这种情况下,假如有必要,可以使用Django提供的 @ensure_csrf_cookie()装饰器强制view视图发送CSRF cookie。

1.2K10

解决django中form表单设置action后无法回到原页面的问题

+ Ajax发送POST表单,并将返回信息回显到页面中 将表单数据发送回后端,然后处理后端返回的信息并显示在当前页面中,这里使用Ajax进行处理; 那么先看js代码: <!...,代表将获取到的数据发送到后端,后端再进行处理 success:function(data){ console.log(data); #调试使用...说说“data”这里面需要注意:data:{“name”, $(“#id_name”).val(), } 这其中id_name必须为控件的id 名称,使用其它的则不能获取的数据,这个还是得注意。...标记,所以导包from django.views.decorators.csrf import csrf_exempt,否则会出现错误csrf_token错误 (403) 2、request.is_ajax...()判断当前是否是使用ajax 进行表单提交 3、django request.POST / request.body 当request.POST没有值 需要考虑: 1.请求头中的: Content-Type

2.2K10

Python Django开发 经验技巧总结(一)

文章目录 1.前后台的数据传递 2.与数据库交互并返回数据的几种比较常用的方法 3.一个表单对应多个按钮解决方案 4.HTML中的表单控件及操作 5.消息框架 message使用 6.日期和时间DateField...的auto_now、auto_now_add 7.获取已登录用户的名字 8.数据库表中属性的自增/自减操作 9.执行原始sql语句 10.分页显示数据 1.前后台的数据传递 view -> HTML使用...-这个method代表方法,方法一般有两个一个是'post',一个是'get',action是提交表单到何处,可填写一个网址。不填则默认到本页面。> {%csrf_token%} 前端HTML代码: <!...已经发生的错误信息 该功能运用了django.contrib.messages这个库,在django项目中setting.py文件中APP注册部分自定义注册 INSTALLED_APPS = [

1.3K10

CSRF 跨站请求伪造

如果不用{% csrf_token %}标签,在用 form 表单时,要再次跳转页面会报403权限错误。 用了{% csrf_token %}标签,在 form 表单提交数据时,才会成功。...Django 中处理CSRF csrf是针对与post请求的才会做验证 几种处理方式 csrf_token 用于form表单中,作用是跨站请求伪造保护。...如果不用{% csrf_token %}标签,在用 form 表单时,要再次跳转页面会报403权限错误。 用了{% csrf_token %}标签,在 form 表单提交数据时,才会成功。...这里使用装饰器就可以解决~ 两个装饰器可用: csrf_protect: 需要验证 csrf_exempt:不需要验证 装饰器的使用方法按照FBV或者CBV装饰器的使用方法即可 导入:from django.views.decorators.csrf...') CBV装饰器示例,CBV装饰器有三种用法分别局部验证都可以使用 # 方式一,加在方法上验证,可以使用 '''局部验证,全局的csrf禁用''' from django.utils.decorators

1.1K20

初探Django框架

kwargs: 视图使用的字典类型的参数。 name: 用来反向获取 URL。...{% include "1.html" %} #这个例子都包含了 1.html 模板: csrf_token csrf_token 用于form表单中,作用是跨站请求伪造保护。...如果不用{% csrf_token %}标签,在用 form 表单时,要再次跳转页面会报403权限错误。 用了{% csrf_token %}标签,在 form 表单提交数据时,才会成功。...首先,向服务器发送请求,获取登录页面,此时中间件 csrf 会自动生成一个隐藏input标签,该标签里的 value 属性的值是一个随机的字符串,用户获取到登录页面的同时也获取到了这个隐藏的input标签...然后,等用户需要用到form表单提交数据的时候,会携带这个 input 标签一起提交给中间件 csrf,原因是 form 表单提交数据时,会包括所有的 input 标签,中间件 csrf 接收到数据时

2K20

Django使用普通表单、Form、以及modelForm操作数据库方式总结

Django使用普通表单、Form、以及modelForm操作数据库主要应用于增删该查的情景下,流程通用如下,只是实现方式不一样: 进入填写表单页面; 在表单页面填写信息,并提交...; 表单数据验证 验证成功,和数据库进行交互(增删改查); 验证成功,页面提示表单填写失败; 一、Django使用普通表单操作数据库 1、html代码: <form...使用自有插件Form表单操作数据库 和方法一的使用普通表单相比,使用django的Form表单更方便快捷地生成前端form表单以及对字段的校验规则; from django.shortcuts...> 具体Form在前端展示以及校验方式、以及操作model的方式(增删改查)不展开,此处主要说明方式 三、Django使用插件modelForm表单操作数据库 和方法二的使用表单Form...相比,modelForm具有Form中所有的验证钩子,使用django的modelForm表单不需要重新定义Form,比较方便。

2.6K30

第 14 篇:交流的桥梁“评论功能”—— HelloDjango 系列教程

然后我们看到 {% csrf_token %},这个模板标签在表单渲染时会自动渲染为一个隐藏类型的 HTML input 控件,其值为一个随机字符串,作用主要是为了防护 CSRF(跨站请求伪造)攻击。...例如假设我们的博客支持登录功能(目前没有),并使用 cookie(或者 session)记录用户的登录状态,且评论表单没有 csrf token 防护。...# 这里我们使用django 提供的一个快捷函数 get_object_or_404, # 这个函数的作用是当获取的文章(Post)存在时,则获取;否则返回 404 页面给用户。...如果用户提交的数据合法,我们就将评论数据保存到数据库,否则说明用户提交的表单包含错误,我们将渲染一个 preview.html 页面,来展示表单中的错误,以便用户修改后重新提交。...请修改表单中的错误后重新提交。', extra_tags='danger') 发送的消息被缓存在 cookie 中,然后我们在模板中获取显示即可。

1.6K20

django 实现简单的搜索功能

html 表单代码大概像这样: {% csrf_token %} <input type="search" placeholder...如果不知道什么是 CSRF 的话也没有关系,只要记住在使用 django 时,前端的表单代码里一定要加上 {% csrf_token %} 。...用户通过表单提交的数据 django 为我们保存在 request.GET 里,这是一个类似于 Python 字典的对象,所以我们使用 get 方法从字典里取出键 q 对应的值,即用户的搜索关键词。...接下来我们做了一个小小的校验,如果用户没有输入搜索关键词而提交了表单,我们就无需执行查询,而是渲染一个错误页面提示用户请输入关键词。...首先是修改表单,打开 templates/base.html,在 header 标签里找到搜索表单部分的代码并修改,即添加 {% csrf_token %} 模板标签、修改搜索框的 name 属性和表单

12.3K80

Django form表单

Django Form表单 Form介绍  总结一下,其实Django form组件的主要功能如下: 生成页面可用的HTML标签 对用户提交的数据进行校验 保留上次输入内容 form表单的作用:   ...1.生成HTML代码   2.验证   3.把验证的错误显示在页面上并保留原始数据 form表单的基本使用: form_obj生成HTML代码的方式   1.form_obj.as_p...2.自己挨个字段取 3.form表单实现机制 {% csrf_token %} {% for field in form_obj...,需要注意choices的选项可以从数据库中获取,但是由于是静态字段 ***获取的值无法实时更新***,那么需要自定义构造方法从而达到此目的。...注:需要PIL模块,pip3 install Pillow 以上两个字典使用时,需要注意两点: - form表单中 enctype="multipart/form-data"

4.3K40

Django 模板HTML转义和CSRF4.3

一般省略,因为Django自动转义 {{t1|escape}} 关闭转义 对于变量使用safe过滤器 {{ data|safe }} 对于代码块使用autoescape标签 { % autoescape...csrf1.html用于展示表单 Title <form method="post" action="/crsf2...,报错如下: 将settings.py中的中间件代码'<em>django</em>.middleware.<em>csrf</em>.CsrfViewMiddleware'注释 查看<em>csrf</em>1的源代码,复制,在自己的网站内建一个<em>html</em>...文件,粘贴源码,访问查看效果 防<em>csrf</em>的<em>使用</em> 在<em>django</em>的模板中,提供了防止跨站攻击的方法,<em>使用</em>步骤如下: step1:在settings.py中启用'<em>django</em>.middleware.<em>csrf</em>.CsrfViewMiddleware...的<em>csrf</em>不是完全的安全 当提交请求时,中间件'<em>django</em>.middleware.<em>csrf</em>.CsrfViewMiddleware'会对提交的cookie及隐藏域的内容进行验证,如果失败则返回403<em>错误</em>

1.2K40

Django Web 极简教程(六)- Django Form(Part A)

HTML 表单,而无须手动书写,并且支持表单信息的验证 使用 PyCharm 创建一个新的项目 Django 项目 django_forms,并创建应用 lima 图片 PyCharm 已经自动配置好了模板所在目录...在视图类中的 post 方法获取表单中传来的数据 def post(self, request): print('这是处理 POST 请求的方法') username = request.POST.get...CSRF 的报错 在 register.html表单中添加 {% csrf_token %} 解决 CSRF 报错,再次输入数据,点击注册按钮,控制台中输出了表单提交的信息 之后就可以根据表单提交的信息与数据库交互执行...CRUD 操作了 使用 Django 表单代替 HTML 表单 在 lima 应用中新增 forms.py,在该文件中新增一个 RegisterForm 类继承 Form 类 from django...Form 渲染出来的表单成功展示出来,修改视图类 Register 的 post 方法,获取 Django Form 提交的信息 class Register(View): # 其余代码保持不变

93210

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券