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

相关文章

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

C++读写word文档(.docx)DuckX库的使用详解

《C++读写word文档(.docx)DuckX库的使用详解》DuckX是C++库,用于创建/编辑.docx文件,支持读取文档、添加段落/片段、编辑表格,解决中文乱码需更改编码方案,进阶功能含文本替换... 目录一、基本用法1. 读取文档3. 添加段落4. 添加片段3. 编辑表格二、进阶用法1. 文本替换2

Python实现自动化删除Word文档超链接的实用技巧

《Python实现自动化删除Word文档超链接的实用技巧》在日常工作中,我们经常需要处理各种Word文档,本文将深入探讨如何利用Python,特别是借助一个功能强大的库,高效移除Word文档中的超链接... 目录为什么需要移除Word文档超链接准备工作:环境搭建与库安装核心实现:使用python移除超链接的

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图