当前位置: 首页 > wzjs >正文

上饶做网站公司seo的收费标准

上饶做网站公司,seo的收费标准,成功的营销案例及分析,长葛网站制作上一篇我们介绍了 OkHttp 的责任链以及第一个内置拦截器 —— 重试与重定向拦截器。本篇我们将剩余四个拦截器的解析做完。 1、桥接拦截器 BridgeInterceptor 作为请求准备和实际发送之间的桥梁,自动处理 HTTP 请求头等繁琐工作。比如设置请求内容长度&#xff0c…

上一篇我们介绍了 OkHttp 的责任链以及第一个内置拦截器 —— 重试与重定向拦截器。本篇我们将剩余四个拦截器的解析做完。

1、桥接拦截器

BridgeInterceptor 作为请求准备和实际发送之间的桥梁,自动处理 HTTP 请求头等繁琐工作。比如设置请求内容长度,编码,gzip 压缩,Cookie 等,获取响应后保存 Cookie 等。它的设计目的是为了解决开发者手动处理 HTTP 协议细节的麻烦,特别是那些必须做但很繁琐或难以实现的工作。

它的拦截代码 intercept() 如下:

class BridgeInterceptor(private val cookieJar: CookieJar) : Interceptor {@Throws(IOException::class)override fun intercept(chain: Interceptor.Chain): Response {// 1.前置工作:从责任链上获取请求,添加相关请求头val userRequest = chain.request()val requestBuilder = userRequest.newBuilder()val body = userRequest.bodyif (body != null) {val contentType = body.contentType()if (contentType != null) {requestBuilder.header("Content-Type", contentType.toString())}// 请求体内容长度如果不是 -1 意味着使用 Content-Length 这个请求头展示内容大小,// 否则就是要使用 Transfer-Encoding: chunked 分块传输的方式。这两个头互斥val contentLength = body.contentLength()if (contentLength != -1L) {requestBuilder.header("Content-Length", contentLength.toString())requestBuilder.removeHeader("Transfer-Encoding")} else {requestBuilder.header("Transfer-Encoding", "chunked")requestBuilder.removeHeader("Content-Length")}}if (userRequest.header("Host") == null) {requestBuilder.header("Host", userRequest.url.toHostHeader())}// Connection 头自动开启了长连接if (userRequest.header("Connection") == null) {requestBuilder.header("Connection", "Keep-Alive")}// 在没有 Accept-Encoding 与 Range 这两个请求头的情况下,自动添加 gzip 压缩数据var transparentGzip = falseif (userRequest.header("Accept-Encoding") == null && userRequest.header("Range") == null) {transparentGzip = truerequestBuilder.header("Accept-Encoding", "gzip")}val cookies = cookieJar.loadForRequest(userRequest.url)if (cookies.isNotEmpty()) {requestBuilder.header("Cookie", cookieHeader(cookies))}if (userRequest.header("User-Agent") == null) {requestBuilder.header("User-Agent", userAgent)}// 2.中置工作:启动责任链的下一个节点,做接力棒交接val networkResponse = chain.proceed(requestBuilder.build())// 3.后置工作:修改响应cookieJar.receiveHeaders(userRequest.url, networkResponse.headers)val responseBuilder = networkResponse.newBuilder().request(userRequest)// 如果在第 1 步中使用了 gzip 压缩,那么这里在拿到响应 networkResponse 后,需要将响应体// responseBody 解压后放到新的响应体 responseBuilder.body() 中if (transparentGzip &&"gzip".equals(networkResponse.header("Content-Encoding"), ignoreCase = true) &&networkResponse.promisesBody()) {val responseBody = networkResponse.bodyif (responseBody != null) {val gzipSource = GzipSource(responseBody.source())val strippedHeaders = networkResponse.headers.newBuilder().removeAll("Content-Encoding").removeAll("Content-Length").build()responseBuilder.headers(strippedHeaders)val contentType = networkResponse.header("Content-Type")responseBuilder.body(RealResponseBody(contentType, -1L, gzipSource.buffer()))}}return responseBuilder.build()}
}

桥接拦截器的拦截逻辑还是很清晰的,三步走:

  1. 前置工作为请求添加请求头。当请求体长度 contentLength 不为 -1 时,添加 Content-Length 请求头填入请求体的完整长度;否则意味着要使用分块传输,添加 Transfer-Encoding: chunked 请求头。这两个头互斥,只能存在一个
  2. 中置工作启动下一个责任链节点,进而触发缓存拦截器
  3. 后置工作就一项,如果在前置工作中启动了 gzip 数据压缩,那么在拿到响应后,要把响应体解压放到新的响应中
http://www.dtcms.com/wzjs/377953.html

相关文章:

  • 网站哪家公司做得好成都网络营销公司排名
  • 济南市高新技术官方网站开发区b2b网站源码
  • 门户网站建设费用第一接单网app地推和拉新
  • 做网站的内容样本快手作品免费推广软件
  • 建筑设计案例网站ks数据分析神器
  • 厦门英文网站建设百度竞价推广登陆
  • 天津企业做网站多少钱黄页网络的推广软件
  • 做南美生意做什么网站好百度推广获客
  • 深圳福田住房和建设局网站官网郑州外贸网站推广
  • 摄影网站网络促销方式免费发广告的平台有哪些
  • 网站的系统建设方式世界杯比分查询
  • 游戏网站做的思想步骤赣州seo优化
  • 做网站上凡科中国科技新闻网
  • 网站后台灰色网站开发教程
  • 网站站点层叠样式怎么做黄页推广引流网站
  • 做ui的图从哪个网站找做网站找哪个公司好
  • 建设网站商城百度竞价开户联系方式
  • 新华社两学一做网站模板网站哪个好
  • 茂名公司网站制作各引擎收录查询
  • 做网站都需要什么资料域名交易平台
  • 免费ppt模板下载 知乎网站推广优化怎样
  • wordpress 打开评论优化公司哪家好
  • 网络小说网站建设手机百度app安装下载
  • 崇明手机网站建设公司网页制作流程
  • 做金融资讯网站需要哪些牌照自己建立网站步骤
  • 政府网站建设的功能市场调研流程
  • 什么网站可以做期货海外市场推广方案
  • 销售管理软件排行上海企业优化
  • 落伍者论坛 做网站分析网站推广和优化的原因
  • 怎么在ppt上做网站视频号广告推广