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

09.Django基础七之Ajax

当文件框发生了输入变化时,使用AJAX技术向服务器发送一个请求,然后服务器会把查询到的结果响应给浏览器,最后再把后端返回的结果展示出来。       ...当输入用户名后,把光标移动到其他表单项上时,浏览器会使用AJAX技术向服务器发出请求,服务器会查询名为lemontree7777777的用户是否存在,最终服务器返回true表示名为lemontree7777777...技术向服务器发送异步请求;       2.AJAX请求无须刷新整个页面;       3.因为服务器响应内容不再是整个页面,而是页面中的部分内容,所以AJAX性能高; 5.作业     ...非get请求),django就没有办法了,他还是帮你重新定向发送get请求,不能满足你的需求,所以如果你用post方法提交数据的时候,就像上面这个ajax里面的那个url写的必须和你后端配置的那个url...当input标签失去焦点后获取 username表单字段的值,向服务端发送AJAX请求; django的视图函数中处理该请求,获取username值,判断该用户在数据库中是否被注册,如果被注册了就返回“

3.6K20

Django之CSRF(跨站请求伪造)

综合起来的意思就是:从一个网站A中发起一个到网站B的请求,而这个请求是经过了伪装的,伪装操作达到的目的就是让请求看起来像是从网站B中发起的,也就是说,让B网站所在的服务器端误以为该请求是从自己网站发起的...默认(全局):'django.middleware.csrf.CsrfViewMiddleware' 中间间,过滤所有post的请求。...是为全局的,需要遵循下面 在html中加上{% csrf_token %} views:的返回用render方法 去掉(全局):'django.middleware.csrf.CsrfViewMiddleware...token再次发送到服务端,而对于ajax的话,使用如下方式。...之前设置一个请求头,名字是X-CSRFToken, // 在ajax发送之前把请求头放到csrftoken,在一块发过去,对的就执行

1.1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    CSRF攻击原理场景

    那么这时候就存在一个漏洞了,如果你访问了一个别有用心或病毒网站,这个网站可以在网页源代码中插入js代码,使用js代码给其他服务器发送请求(比如ICBC的转账请求)。...那么因为在发送请求的时候,浏览器会自动的把cookie发送给对应的服务器,这时候相应的服务器(比如ICBC网站),就不知道这个请求是伪造的,就被欺骗过去了。...从而达到在用户不知情的情况下,给某个服务器发送了一个请求(比如转账)。防御CSRF攻击:CSRF攻击的要点就是在向服务器发送请求的时候,相应的cookie会自动的发送给对应的服务器。...以后给服务器发送请求的时候,必须在body中以及cookie中都携带csrf_token,服务器只有检测到cookie中的csrf_token和body中的csrf_token都相同,才认为这个请求是正常的...,来自动生成一个带有csrf token的input标签:{% csrf_token %}使用ajax处理csrf防御:如果用ajax来处理csrf防御,那么需要手动的在form中添加csrfmiddlewaretoken

    97440

    AJAX

    AJAX AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。 AJAX 不是新的编程语言,而是一种使用现有标准的新方法。...AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。 AJAX 不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。...举例: 搜索引擎搜索框输入字符后下边显示可能要搜索的内容; 注册账号是显示昵称是否被使用 AJAX使用步骤 1.创建XMLHTTPRequest对象 2.open打开与服务器的连接 3.向服务器端发送请求...4.监听服务器发送回的响应 AJAX实现过程 1.一个简单的html页面 <!...(); xmlHttp.open("POST", "/ajax_test/", true); 3.向服务端发送请求 post请求,发送的是个字符串,相当于post请求中的键值 xmlHttp.send(

    4.3K20

    Django学习笔记之Ajax入门

    当文件框发生了输入变化时,使用AJAX技术向服务器发送一个请求,然后服务器会把查询到的结果响应给浏览器,最后再把后端返回的结果展示出来。 整个过程中页面没有刷新,只是刷新页面中的局部位置而已!...整个过程中页面没有刷新,只是局部刷新了; 在请求发出后,浏览器不用等待服务器响应结果就可以进行其他操作; AJAX的优缺点 优点: AJAX使用JavaScript技术向服务器发送异步请求; AJAX...请求无须刷新整个页面; 因为服务器响应内容不再是整个页面,而是页面中的部分内容,所以AJAX性能高; jQuery实现的AJAX 最基本的jQuery发送AJAX请求示例: 请求如何设置csrf_token 方式1 通过获取隐藏的input标签中的csrfmiddlewaretoken值,放置在data中发送。...当input标签失去焦点后获取 username表单字段的值,向服务端发送AJAX请求; django的视图函数中处理该请求,获取username值,判断该用户在数据库中是否被注册,如果被注册了就返回“

    1.3K50

    CSRF 原理与防御案例分析

    CSRF 不仅仅只能针对 GET 请求,也可以针对 POST 请求,不过只能使用 from 标签进行自动提交,注意此处需用到 javascript。...这个就是 Django 的 CSRF 防御机制,当我们发送 POST 请求时 Django 会自动检测 CSRF_Token 值是否正确。...{% csrf_token %}这串代码被 Django 解析成了一个隐藏的input标签,其中的值为 token 值,当我们发送请求时必须带上这个值。...只有这样 Django 才会接受 POST 请求来的数据,否则返回错误,并且原登陆页面的 CSRF_Token 重新生成,上一个进行销毁,很大程度上防御住了 POST 请求的 CSRF。 ?...3、还有就是考虑能不能绕过 Token,比如 Url 处的 Token 用加载攻击者服务器上的图片来获取。

    2.3K30

    Django之json、Ajax简介及实例介绍

    当文件框发生了输入变化时,浏览器会使用AJAX技术向服务器发送一个请求,查询包含“传”字的前10个关键字,然后服务器会把查询到的结果响应给浏览器,最后浏览器把这4个关键字显示在下拉列表中。...当输入用户名后,把光标移动到其他表单项上时,浏览器会使用AJAX技术向服务器发出请求,服务器会查询名为zhangSan的用户是否存在,最终服务器返回true表示名为lemontree7777777的用户已经存在了...整个过程中页面没有刷新,只是局部刷新了; 在请求发出后,浏览器不用等待服务器响应结果就可以进行其他操作; AJAX的优缺点 优点: AJAX使用Javascript技术向服务器发送异步请求;...xmlHttp.send(null); 步骤3: 接收服务器响应 当请求发送出去后,服务器端就开始执行了,但服务器端的响应还没有接收到。接下来我们来接收服务器的响应。...页面中给出注册表单; 在username表单字段中添加onblur事件,调用send()方法; send()方法获取username表单字段的内容,向服务器发送异步请求,参数为username; django

    6.7K20

    Django---Ajax

    当文件框发生了输入变化时,浏览器会使用AJAX技术向服务器发送一个请求,查询包含“传”字的前10个关键字,然后服务器会把查询到的结果响应给浏览器,最后浏览器把这4个关键字显示在下拉列表中。...当输入用户名后,把光标移动到其他表单项上时,浏览器会使用AJAX技术向服务器发出请求,服务器会查询名为zhangSan的用户是否存在,最终服务器返回true表示名为lemontree7777777的用户已经存在了...整个过程中页面没有刷新,只是局部刷新了; 在请求发出后,浏览器不用等待服务器响应结果就可以进行其他操作; AJAX的优缺点 优点: AJAX使用Javascript技术向服务器发送异步请求; AJAX...当请求发送出去后,服务器端就开始执行了,但服务器端的响应还没有接收到。...7.2 案例分析 页面中给出注册表单; 在username表单字段中添加onblur事件,调用send()方法; send()方法获取username表单字段的内容,向服务器发送异步请求,参数为username

    4.8K101

    AJAX使用说明书

    AJAX除了异步的特点外,还有一个就是:浏览器页面局部刷新;(这一特点给用户的感受是在不知不觉中完成请求和响应过程) AJAX优点 AJAX使用JavaScript技术向服务器发送异步请求; AJAX请求无须刷新整个页面...当文件框发生了输入变化时,使用AJAX技术向服务器发送一个请求,然后服务器会把查询到的结果响应给浏览器,最后再把后端返回的结果展示出来。 整个过程中页面没有刷新,只是刷新页面中的局部位置而已!...常用参数如下: 1.url 要求为String类型的参数,(默认为当前地址)发送请求的页面。 2.type 要求为String类型的参数,请求方式(post或get)默认为get。...script:返回纯文本javascript代码。不会自动缓存结果,除非设置了cache参数。注意在远程请求时(不在同一个域下),所有post请求都将转为get请求。   ...通常在本地和远程的内容编码不同时使用。 AJAX请求如何设置csrf_token 方式1 通过获取隐藏的input标签中的csrfmiddlewaretoken值,放置在data中发送。

    2.7K70

    AJAX

    AJAX简介 我们之前知道的前端向后端发送数据的方式有:   GET:地址栏、a标签、Form表单   POST:Form表单 其实AJAX也是一种前端向后端发送数据的方式   AJAX...当文件框发生了输入变化时,使用AJAX技术向服务器发送一个请求,然后服务器会把查询到的结果响应给浏览器,最后再把后端返回的结果展示出来。 整个过程中页面没有刷新,只是刷新页面中的局部位置而已!...当输入用户名后,把光标移动到其他表单项上时,浏览器会使用AJAX技术向服务器发出请求,服务器会查询名为lemontree7777777的用户是否存在,最终服务器返回true表示名为lemontree7777777...整个过程中页面没有刷新,只是局部刷新了; 在请求发出后,浏览器不用等待服务器响应结果就可以进行其他操作;  AJAX的优缺点 优点: AJAX使用JavaScript技术向服务器发送异步请求;...AJAX请求如何设置csrf_token 方式1 通过获取隐藏的input标签中的csrfmiddlewaretoken值,放置在data中发送。

    4.4K70

    CSRF 跨站请求伪造

    与XSS攻击相比,CSRF攻击往往不大流行(因此对其进行防范的资源也相当稀少)和难以防范,所以被认为比XSS更具危险性 可以这样来理解: 攻击者盗用了你的身份,以你的名义发送恶意请求,对服务器来说这个请求是完全合法的...但是,在一个网站中,可以接受请求的地方非常多,要对于每一个请求都加上 token 是很麻烦的,并且很容易漏掉,通常使用的方法就是在每次页面加载时,使用 javascript 遍历整个 dom 树,对于...解析: 首先,向服务器发送请求,获取登录页面,此时中间件 csrf 会自动生成一个隐藏input标签,该标签里的 value 属性的值是一个随机的字符串,用户获取到登录页面的同时也获取到了这个隐藏的input...Django 中处理CSRF csrf是针对与post请求的才会做验证 几种处理方式 csrf_token 用于form表单中,作用是跨站请求伪造保护。...csrf_token %} ··· Ajax提交,两种方式 # 方式一 $.ajax({ url:'', method:'post',

    1.1K20

    被解放的姜戈04 各取所需

    我们在庄园疑云中讲到了服务器上的数据。当时我们是用手动的方式,直接在数据库插入数据。我们将允许客户向服务器传递数据。 表格是客户向服务器传数据的经典方式。...我们先会看到传统的表格提交,然后了解Django的表格对象。 ? “我可不做赔本的买卖”,庄主对姜戈说。 html表格 HTTP协议以“请求-回复”的方式工作。客户发送请求时,可以在请求中附加数据。...服务器通过解析请求,就可以获得客户传来的数据,并根据URL来提供特定的服务。  (http协议的运作方式,详见http协议) HTML文件中可以包含表格标签。...HTML表格的目的是帮助用户构成HTTP请求,把数据用GET或者POST的方法,传递给某一URL地址。...这是Django提供的防止伪装提交请求的功能。POST方法提交的表格,必须有此标签。

    1.1K50

    Django 中间件

    二.中间件用途 django的中间件,其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法,所以如果需要修改请求,例如被传送到view中的HttpRequest...', ] 请求传递到Django的过程如下: ?...与XSS攻击相比,CSRF攻击往往不大流行(因此对其进行防范的资源也相当稀少)和难以防范,所以被认为比XSS更具危险性 可以这样来理解: 攻击者盗用了你的身份,以你的名义发送恶意请求,对服务器来说这个请求是完全合法的...,但是却完成了攻击者所期望的一个操作,比如以你的名义发送邮件、发消息,盗取你的账号,添加系统管理员,甚至于购买商品、虚拟货币转账等。...并验证(Django处理方式) 3.在HTTP头中自定义属性并验证 在form表单中应用: post"> {% csrf_token %}

    1K20

    王老板Python面试(9):整理的最全 python常见面试题(基本必考)

    2.跨域请求问题django怎么解决的(原理) 启用中间件 post请求 验证码 表单中添加{%csrf_token%}标签 3.请解释或描述一下Django的架构 对于Django框架遵循MVC设计,...正向代理 是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端...客户端向反向代理的命名空间中的内容发送普通请求,接着反向代理将判断向何处(原始服务器)转交请求,并将获得的内容返回给客户端,就像这些内容原本就是它自己的一样。 9. Tornado 的核是什么?...ajax(异步的javascript 和xml) 能够刷新局部网页数据而不是重新加载整个网页。...Post和get区别? GET请求,请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数用&连接。

    1.6K10

    Python进阶34-Django 中间件

    与XSS攻击相比,CSRF攻击往往不大流行(因此对其进行防范的资源也相当稀少)和难以防范,所以被认为比XSS更具危险性 可以这样来理解: 攻击者盗用了你的身份,以你的名义发送恶意请求,对服务器来说这个请求是完全合法的...而如果黑客要对银行网站实施 CSRF 攻击,他只能在他自己的网站构造请求,当用户通过黑客的网站发送请求到银行时,该请求的 Referer 是指向黑客自己的网站。...可以在 HTTP 请求中以参数的形式加入一个随机产生的 token,并在服务器端建立一个拦截器来验证这个 token,如果请求中没有 token 或者 token 内容不正确,则认为可能是 CSRF 攻击而拒绝该请求...但是,在一个网站中,可以接受请求的地方非常多,要对于每一个请求都加上 token 是很麻烦的,并且很容易漏掉,通常使用的方法就是在每次页面加载时,使用 javascript 遍历整个 dom 树,对于...,每次都要注释掉的那个,也就是说,它每次都会拒绝我们的post请求,就是为了防止CSRF工具,从今以后我们不注释它,直接带着这个中间件的token去做post请求即可。

    1.8K20

    Django CSRF认证的几种解决方案

    什么是CSRF 浏览器在发送请求的时候,会自动带上当前域名对应的cookie内容,发送给服务端,不管这个请求是来源A网站还是其它网站,只要请求的是A网站的链接,就会带上A网站的cookie。...浏览器的同源策略并不能阻止CSRF攻击,因为浏览器不会停止js发送请求到服务端,只是在必要的时候拦截了响应的内容。或者说浏览器收到响应之前它不知道该不该拒绝。...Django使用CsrfViewMiddleware中间件进行CSRF校验,默认开启防止csrf(跨站点请求伪造)攻击,在post请求时,没有携带csrf字段,导致校验失败,报403错误。...这种方式只限制在form表单中使用,ajax请求不支持。 3....指定请求去掉CSRF校验 可以只针对指定的路由去掉CSRF校验,这也分为两种情况: FBV:用函数实现路由处理 # 导入,可以使此次请求忽略csrf校验 from django.views.decorators.csrf

    2K20

    Django ajax 简单介绍

    AJAX Asynchronous Javascript And XML是 "异步Javascript和XML"。即使用 Javascript 语言与服务器进行异步交互,传输的数据为XML。...同步交互:客户端发出一个请求后,需要等待服务器响应结束后,才能发出第二个请求; 异步交互:客户端发出一个请求后,无需等待服务器响应结束,就可以发出第二个请求。...优点: AJAX使用Javascript技术向服务器发送异步请求; AJAX无须刷新整个页面; 因为服务器响应内容不再是整个页面,而是页面中的局部,所以AJAX性能高; 缺点: AJAX并不适合所有场景...,很多时候还是要使用同步交互; AJAX虽然提高了用户体验,但无形中向服务器发送的请求次数增多了,导致服务器压力增大; 因为AJAX是在浏览器中使用Javascript技术完成的,所以还需要处理浏览器兼容性问题...---- ajax 发送POST请求 修改 index.html 文件 <!

    55710
    领券