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

相关文章

ubuntu系统使用官方操作命令升级Dify指南

《ubuntu系统使用官方操作命令升级Dify指南》Dify支持自动化执行、日志记录和结果管理,适用于数据处理、模型训练和部署等场景,今天我们就来看看ubuntu系统中使用官方操作命令升级Dify的方... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。

浅谈Redis Key 命名规范文档

《浅谈RedisKey命名规范文档》本文介绍了Redis键名命名规范,包括命名格式、具体规范、数据类型扩展命名、时间敏感型键名、规范总结以及实际应用示例,感兴趣的可以了解一下... 目录1. 命名格式格式模板:示例:2. 具体规范2.1 小写命名2.2 使用冒号分隔层级2.3 标识符命名3. 数据类型扩展命

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

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