HttpURLConnection官方文档翻译

2024-06-04 22:18

本文主要是介绍HttpURLConnection官方文档翻译,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇为翻译文章,原文地址在这里http://developer.android.com/intl/zh-cn/reference/java/net/HttpURLConnection.html

因为Android6.0已经放弃HttpClient,而Volley和okhttp需要导入第三方库,公司项目因条件比较特殊,不予许擅自导入第三方库,所以只能使用另一个原生网络连接类HttpURLConnection。虽然我一直觉得HttpClient比较好用。。。

网上查的HttpURLConnection讲的不是很全,大体都是讲边流程而已,而且大多都很老旧,这都2016年了喂大哥!所以干脆把最新的官方文档翻译一下吧~~


API Level: 23

public abstract class 公有抽象类

HttpURLConnection

extends URLConnection


java.lang.Object
↳ java.net.URLConnection
↳ java.net.HttpURLConnection
Known Direct Subclasses 已知的直接子类
HttpsURLConnection


类概述

一个为HTTP协议(RFC 2616)设计的URLConnection,被用来在网络上发送和接收数据。数据可能是任何类型,也可能是任何长度。这个类也可以被用在发送和接收那些提前并不知道长度的流数据上。

使用这个类应该遵循的模板:

  • 1 得到一个新的HttpURLConnection实例应该通过调用URL.openConnection()这个方法,然后把结果强制转换为HttpURLConnection。

  • 2 准备请求。请求的主要属性是它的URI。请求头也包括元数据,比如证书、首选内容类型和会话cookie。

  • 3 可选择地上传一个请求体。如果实例包含请求体,则必须配置setDoOutput(true)。通过写入流来传输数据,返回值在getOutputStream()中。

  • 4 读取响应(返回结果)。响应头通常包括元数据,比如响应体的内容类型和长度,修改日期和会话cookie。响应体可以通过getInputStream()将流读取出来。如果响应没有响应体,这个方法会返回一个空的流。

  • 5 断开连接。一旦响应体读取完成,这个HttpURLConnection就应该被断开,调用disconnect()方法断开。断开会释放connection所持有的资源,所以它们可能会被关闭或者重用。

例如,检索网页 http://www.android.com/

URL url = new URL("http://www.android.com/");
HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
try {InputStream in = new BufferedInputStream(urlConnection.getInputStream());readStream(in);
finally {urlConnection.disconnect();}
}

通过 HTTPS进行安全通信

已”https”的方式在一个URL上调用openConnection()方法会返回一个HttpsURLConnection对象,这个对象允许去重写默认的HostnameVerifier(主机名验证)和SSLSocketFactory(安全套接字工厂)。通过SSLContext创建一个应用程序提供的SSLSockerFactory,它可以提供一个自定义的X509TrustManager,用来验证证书链;它还可以提供一个自定义的X509KeyManager,用来提供客户端证书。查看HttpsURLConnection,获取更多细节。


响应处理

HttpURLConnection遵循五个HTTP重定向。它从一个源服务器重定向到另一个。这个实现不会将HTTPS重定向到HTTP,反之亦然 。
如果这个HTTP响应表明有错误发生,getInoutStream()方法将会抛出一个IOException。使用getErrorStream()来读取错误响应信息。响应头可以使用getHeaderFields()方法来正常读取。


发布内容

要上传数据到服务端,使用setDoOutput(true)来配置connection的输出。
为了获得最佳的性能,当请求体长度事先已经知道的时候你应该使用setFixedLengthStreamingMode(int),事先不知道的时候使用setChunkedStreamingMode(int)。要不然的话这个HttpURLConnection会在传输完成之前被迫地把整个的请求体都缓冲在内存中,浪费(很可能会耗尽)堆和增加延迟。

例如,执行一个上传:

HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();
try {urlConnection.setDoOutput(true);urlConnection.setChunkedStreamingMode(0);OutputStream out = new BufferedOutputStream(urlConnection.getOutputStream());writeStream(out);InputStream in = new BufferedInputStream(urlConnection.getInputStream());readStream(in);
finally {urlConnection.disconnect();}
}

性能

通过这个类返回的输入流和输出流是没有缓冲的。大多数调用者应该用BufferedInputStream或者BufferedOutputStream将返回的流包裹起来。那些只做批量读取或写入的调用者们可以忽略缓冲操作。
当从服务端或者向服务端传输大量的数据时,要限制一次性在内存里可以存多少数据。除非你需要一下子把整个数据体都放在内存中,当成一个流(不是把整个数据体当做一个字节数组或者字符串来存储,而是流)来处理。

为了减少延迟,这个类可以为多个请求/响应重用相同的底层套接字。因此,HTTP连接能够被重新打开的功能就不再重要了。调用disconnect()方法会从连接套接字池中返回一个套接字。在任意HTTP请求发出之前,这种行为都可以通过将系统属性http.keepAlive设置为false来禁用。http.maxConnections属性可以用来控制连接每个服务器的空闲的connections的数量。

在HttpURLConnection请求的实现里,服务器默认使用gzip压缩,当使用者调用getInputStream()时,它会自动将数据解压。内容编码和内容长度响应头在实例中被清除。可以通过在请求头中设置可接受的编码格式来禁用gzip压缩。

urlConnection.setRequestProperty("Accept-Encoding", "identity");

在请求头中设置可接受的编码格式可以显示的禁用自动解压缩,让响应头更完整。但是要求调用者必须根据响应的内容编码头来自行处理解压缩操作。

getContentLength()方法返回的传输的字节数,并不能被用来估计有多少字节可以用getInputStream()方法从压缩流中读取出来。相反的,它会一直读取流,直到当read()返回-1的时候。


这篇关于HttpURLConnection官方文档翻译的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1031277

相关文章

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Python实现合并与拆分多个PDF文档中的指定页

《Python实现合并与拆分多个PDF文档中的指定页》这篇文章主要为大家详细介绍了如何使用Python实现将多个PDF文档中的指定页合并生成新的PDF以及拆分PDF,感兴趣的小伙伴可以参考一下... 安装所需要的库pip install PyPDF2 -i https://pypi.tuna.tsingh

Python批量调整Word文档中的字体、段落间距及格式

《Python批量调整Word文档中的字体、段落间距及格式》这篇文章主要为大家详细介绍了如何使用Python的docx库来批量处理Word文档,包括设置首行缩进、字体、字号、行间距、段落对齐方式等,需... 目录关键代码一级标题设置  正文设置完整代码运行结果最近关于批处理格式的问题我查了很多资料,但是都没

Python自动化Office文档处理全攻略

《Python自动化Office文档处理全攻略》在日常办公中,处理Word、Excel和PDF等Office文档是再常见不过的任务,手动操作这些文档不仅耗时耗力,还容易出错,幸运的是,Python提供... 目录一、自动化处理Word文档1. 安装python-docx库2. 读取Word文档内容3. 修改

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

SpringBoot3集成swagger文档的使用方法

《SpringBoot3集成swagger文档的使用方法》本文介绍了Swagger的诞生背景、主要功能以及如何在SpringBoot3中集成Swagger文档,Swagger可以帮助自动生成API文档... 目录一、前言1. API 文档自动生成2. 交互式 API 测试3. API 设计和开发协作二、使用