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

如何在 Web 关闭页面时发送 Ajax 请求

有时候我们需要在用户离开页面的时候,做一些上报来记录用户行为。又或者是发送服务器ajax请求,通知服务器用户已经离开,比如直播间内的退房操作。 本文主要分两部分来讲解怎么完成退出行为的上报。 1....请求发送 有了上面的监听,事情只完成了一半,如果我们在监听中直接发送ajax请求,就会发现请求被浏览器abort了,无法发送出去。在页面卸载的时候,浏览器并不能保证异步的请求能够成功发出去。...如何在 Web 关闭页面时发送 Ajax 请求 (2)使用FormData对象,但是这时content-type会被设置成"multipart/form-data"。...如何在 Web 关闭页面时发送 Ajax 请求 (3)数据也可以使用URLSearchParams 对象,content-type会被设置成"text/plain;charset=UTF-8" 。...如何在 Web 关闭页面时发送 Ajax 请求 通过尝试,可以发现使用blob发送比较方便,内容的设置也比较灵活,如果发送的消息抓包后发现后台没有识别出来,可以尝试修改内容的string或者header

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

    PHP 判断页面请求是否为ajax

    php ajax PHP 判断是否为 AJAX 请求 先说前端使用 jQuery 时怎么区分:   jQuery 发出 ajax 请求时,会在请求头部添加一个名为 X-Requested-With...(注意:中划线换成了下划线,不区分大小写)   由此,我们可以这样来判断是否为 ajax 请求: // php 判断是否为 ajax 请求 http://www.cnblogs.com/sosoft/...请求的处理方式 }else{ // 正常请求的处理方式 }; 在使用原生 JavaScript 发出 ajax 请求时,我们也可以给头部添加信息,以方便后端同学进行区分,方法如下: var...说两个例子:   1.当 js 文件未加载完时,用户点击了某个按钮或链接,本应是 ajax 请求的成了 正常请求,后端根据判断,不输出 ajax 时的 json 数据,而是跳转,这也是优雅降级的形式。...[A 页面]使用 ajax 方式进行登录,[B 页面]使用正常方式登录,如果不区分,后端需要写两次几乎完全相同的代码,而有了区分,可以把重复的代码消掉。

    1.7K30

    Django分离JS代码,处理AJax错误请求

    Ajax请求时,这里的block同样会变得很臃肿。...最近遇到的问题: 并且最近在进行Ajax的POST请求时候,遇到Illegal invocation这个错误。...查了下,大概就是传递了个对象导致的,但是从自己代码上看,好像没有,因此找了下,发现在进行AJax提交时,默认会将数据转换成对象,并且会进行序列化处理,特别是在使用AJax进行文件上传时候。...Django中,开启CSRF的防护时,在进行POST提交时必须附带csrf_token,但是将JS分离后,独立的JS文件中是无法获取到 {{ csrf_token }}的,因此我只能采用传参的方式来解决...下面以复选框批量删除操作来说明上面的问题 多个复选框 复用代码,分离请求 分离JS代码,抽离功能 这里重点在Ajax请求时的两个参数: processData: false, contentType:

    4.3K70

    ajax请求的五个步骤java_如何发送ajax请求ajax请求的五个步骤详解

    Ajax是一种可以异步交互数据的技术,目前是前端开发的程序员们最需要的技术之一,那你们知道如何实现ajax吗?它又是怎么实现的呢?跟我一起了解一下吧。 什么是ajax?...JavaScript 不是使用 AJAX 编程的唯一客户端脚本语言; VBScript 和其他语言都有这种功能,但 JavaScript 是最受欢迎的。 如何构建一个完整的ajax请求?...例://url就是请求的地址 //successFunc就是一个请求返回成功之后的一个function,有一个参数,参数就是服务器返回的报文体 function ajax(url, successFunc...; } } }; xhr.send(); } Ajax请求的五个步骤都有哪些? 1....name=”+ name,true)此步注意设置http的请求方式(post / get), 如果是POST方式,注意设置请求头信息xmlHttp.setRequestHeader(“Content-Type

    2.1K40

    JS 中的网络请求 AJAX, Fetch, WebSocket

    AJAX 是 Asynchronous JavaScript And XML 的简称,它可以让页面在不刷新的情况下从服务器获取数据。...lengthComputable 布尔值 表示进度信息是否可用 position 已经接收到的字节数 totalSize 根据Content-Length预期的字节数 跨域 同源策略限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互...为了使 ajax 可以从不同的网址获取数据。 我们可以使用跨域资源共享(CORS)来解决问题。...在发送请求时会有个Origin头表示请求页面的源信息, 如果服务器返回的Access-Control-Allow-Origin中有相同的源信息或是* 那么就可以跨域请求信息,请求和响应都不包含cookie...Response 实现了 Body(代表响应/请求的正文,允许你声明其内容类型是什么以及应该如何处理。) 它有 9 个属性。

    4.1K30

    如何配置ajax请求跨域携带cookie,cors支持ajax请求携带cookie

    首先咱们来看一下前后端数据交互的一些规则: 1、同域名下发送ajax请求请求中默认会携带cookie 2、ajax在发送跨域请求时,默认情况下是不会携带cookie的 3、ajax在发送跨域请求时如果想携带...接下来咱们来一条条验证: 1、同域名下发送ajax请求请求中默认会携带cookie, 我们用express构建一个静态资源服务器端口为3000,然后新建一个页面,在页面中直接调用jquery的ajax...2、ajax在发送跨域请求时,默认情况下是不会携带cookie的。...接着看第三条: 3、ajax在发送跨域请求时如果想携带cookie,必须将请求对象的withcredentials属性设置为true。...那需要后端如何设置才能支持前端发送ajax请求携带cookie呢,Access-Control-Allow-Origin必须设置成这样子:Access-Control-Allow-Origin: http

    17.1K31
    领券