Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK 与 JRE 与 JVM
- Java - Hello World 程序
- Java - 环境设置
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode 系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期和时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - If-else
- Java - Switch
- Java - For 循环
- Java - For-Each 循环
- Java - While 循环
- Java - do-while 循环
- Java - Break
- Java - Continue
面向对象编程
- Java - OOPs 概念
- Java - 对象和类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造函数
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造函数
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误和异常
- Java - 异常
- Java - try-catch 块
- Java - try-with-resources
- Java - 多重捕获块
- Java - 嵌套 try 块
- Java - Finally 块
- Java - throw 异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 合并线程
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络
- Java - 网络
- Java - 套接字编程
- Java - URL 处理
- Java - URL 类
- Java - URLConnection 类
- Java - HttpURLConnection 类
- Java - Socket 类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级 Java
- Java - 命令行参数
- Java - Lambda 表达式
- Java - 发送电子邮件
- Java - Applet 基础
- Java - Javadoc 注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像 API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional 类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64 编码解码
- Java - Switch 表达式
- Java - Teeing 收集器
- Java - 微基准测试
- Java - 文本块
- Java - 动态 CDS 归档
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 紧凑数字格式化
- Java - 垃圾回收
- Java - JIT 编译器
Java 杂项
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - 进程 API 改进
- Java - 流 API 改进
- Java - 增强的 @Deprecated 注释
- Java - CompletableFuture API 改进
- Java - 流
- Java - 日期时间 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java API 和框架
Java 类参考
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java - HttpURLConnection 类
Java HttpURLConnection 类
java.net.HttpURLConnection 是一个抽象类,表示特定于 HTTP 的 URL 连接。此类的实例可用于读取和写入 URL 引用的资源。
例如 -
连接到 URL 的步骤
以下是连接到 URL 并开始处理的步骤。
调用 URL.openConnection() 方法 以获取基于 HTTP 的 URL 的 HttpURLConnection 对象。
根据需要使用连接对象的各种 setter 方法更新设置参数和常规请求属性。
使用连接对象的 connect() 方法创建到远程对象的连接。
远程对象可用后,访问远程对象的内容/标头。
HttpURLConnection 类声明
public abstract class HttpURLConnection extends URLConnection
HttpURLConnection 类字段
| 序号 | 字段和描述 |
|---|---|
| 1 | protected int chunkLength 使用分块编码流模式输出时的分块长度。 |
| 2 | protected int fixedContentLength 使用固定长度流模式时的固定内容长度。 |
| 3 | protected long fixedContentLengthLong 使用固定长度流模式时的固定内容长度。 |
| 4 | static int HTTP_ACCEPTED HTTP 状态代码 202:已接受。 |
| 5 | static int HTTP_BAD_GATEWAY HTTP 状态代码 502:错误网关。 |
| 6 | static int HTTP_BAD_METHOD HTTP 状态代码 405:方法不允许。 |
| 7 | static int HTTP_BAD_REQUEST HTTP 状态代码 400:错误请求。 |
| 8 | static int HTTP_CLIENT_TIMEOUT HTTP 状态代码 408:请求超时。 |
| 9 | static int HTTP_CONFLICT HTTP 状态代码 409:冲突。 |
| 10 | static int HTTP_CREATED HTTP 状态代码 201:已创建。 |
| 11 | static int HTTP_ENTITY_TOO_LARGE HTTP 状态代码 413:请求实体过大。 |
| 12 | static int HTTP_FORBIDDEN HTTP 状态代码 403:禁止。 |
| 13 | static int HTTP_GATEWAY_TIMEOUT HTTP 状态代码 504:网关超时。 |
| 14 | static int HTTP_GONE HTTP 状态代码 410:已消失。 |
| 15 | static int HTTP_INTERNAL_ERROR HTTP 状态代码 500:内部服务器错误。 |
| 16 | static int HTTP_LENGTH_REQUIRED HTTP 状态代码 411:需要长度。 |
| 17 | static int HTTP_MOVED_PERM HTTP 状态代码 301:永久移动。 |
| 18 | static int HTTP_MOVED_TEMP HTTP 状态代码 302:临时重定向。 |
| 19 | static int HTTP_MULT_CHOICE HTTP 状态代码 300:多种选择。 |
| 20 | static int HTTP_NO_CONTENT HTTP 状态代码 204:无内容。 |
| 21 | static int HTTP_NOT_ACCEPTABLE HTTP 状态代码 406:不可接受。 |
| 22 | static int HTTP_NOT_AUTHORITATIVE HTTP 状态代码 203:非权威信息。 |
| 23 | static int HTTP_NOT_FOUND HTTP 状态代码 404:未找到。 |
| 24 | static int HTTP_NOT_IMPLEMENTED HTTP 状态代码 501:未实现。 |
| 25 | static int HTTP_NOT_MODIFIED HTTP 状态代码 304:未修改。 |
| 26 | static int HTTP_OK HTTP 状态代码 200:确定。 |
| 27 | static int HTTP_PARTIAL HTTP 状态代码 206:部分内容。 |
| 28 | static int HTTP_PAYMENT_REQUIRED HTTP 状态代码 402:需要付款。 |
| 29 | static int HTTP_PRECON_FAILED HTTP 状态代码 412:前提条件失败。 |
| 30 | static int HTTP_PROXY_AUTH HTTP 状态代码 407:需要代理身份验证。 |
| 31 | static int HTTP_REQ_TOO_LONG HTTP 状态代码 414:请求 URI 过长。 |
| 32 | static int HTTP_RESET HTTP 状态代码 205:重置内容。 |
| 33 | static int HTTP_SEE_OTHER HTTP 状态代码 303:查看其他。 |
| 34 | static int HTTP_UNAUTHORIZED HTTP 状态代码 401:未授权。 |
| 35 | static int HTTP_UNAVAILABLE HTTP 状态代码 503:服务不可用。 |
| 36 | static int HTTP_UNSUPPORTED_TYPE HTTP 状态代码 415:不支持的媒体类型。 |
| 37 | static int HTTP_USE_PROXY HTTP 状态代码 305:使用代理。 |
| 38 | static int HTTP_VERSION HTTP 状态代码 505:不支持的 HTTP 版本。 |
| 39 | protected boolean instanceFollowRedirects 如果为 true,则协议将自动跟随重定向。 |
| 40 | protected String method HTTP 方法(GET、POST、PUT 等)。 |
| 41 | protected int responseCode 表示三位数 HTTP 状态代码的整数。 |
| 42 | protected String responseMessage HTTP 响应消息。 |
HttpURLConnection 类方法
HttpURLConnection 类有许多方法用于设置或确定有关连接的信息,包括以下内容 -
| 序号 | 方法和描述 |
|---|---|
| 1 | abstract void disconnect() 表示在不久的将来不太可能向服务器发送其他请求。 |
| 2 |
如果连接失败但服务器仍然发送了有用的数据,则返回错误流。 |
| 3 | static boolean getFollowRedirects() 返回一个布尔值,指示是否应自动跟随 HTTP 重定向 (3xx)。 |
| 4 |
返回第 n 个头部字段的值。 |
| 5 | String getHeaderFieldKey(int n) 返回第 n 个头部字段的键。 |
| 6 | boolean getInstanceFollowRedirects() 返回此 HttpURLConnection 的 instanceFollowRedirects 字段的值。 |
| 7 |
返回一个 SocketPermission 对象,表示连接到目标主机和端口所需的权限。 |
| 8 |
获取请求方法。 |
| 9 |
从 HTTP 响应消息中获取状态码。 |
| 10 |
获取 HTTP 响应消息(如果有),该消息与服务器返回的响应代码一起返回。 |
| 11 | void setAuthenticator(Authenticator auth) 提供一个 Authenticator,当通过 HTTP 协议为该 HttpURLConnection 请求身份验证时使用。 |
| 12 | void setChunkedStreamingMode(int chunklen) 此方法用于启用 HTTP 请求主体流而无需内部缓冲,当内容长度事先未知时。 |
| 13 | void setFixedLengthStreamingMode(int contentLength) 此方法用于启用 HTTP 请求主体流而无需内部缓冲,当内容长度事先已知时。 |
| 14 | void setFixedLengthStreamingMode(long contentLength) 此方法用于启用 HTTP 请求主体流而无需内部缓冲,当内容长度事先已知时。 |
| 15 | static void setFollowRedirects(boolean set) 设置此类是否应自动跟随 HTTP 重定向(响应代码为 3xx 的请求)。 |
| 16 | void setInstanceFollowRedirects(boolean followRedirects) 设置此 HttpURLConnection 实例是否应自动跟随 HTTP 重定向(响应代码为 3xx 的请求)。 |
| 17 | void setRequestMethod(String method) 设置 URL 请求的方法,以下方法是合法的:GET POST HEAD OPTIONS PUT DELETE TRACE,但受协议限制。 |
| 18 | abstract boolean usingProxy() 指示连接是否通过代理。 |
继承
此类继承以下类
java.lang.Object
java.net.URLConnection
Java HttpURLConnection 类示例
以下 HttpURLConnection 程序连接到从命令行输入的 URL。
如果 URL 表示 HTTP 资源,则将连接转换为 HttpURLConnection,并逐行读取资源中的数据。
package com.tutorialspoint;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLConnection;
public class HttpUrlConnectionDemo {
public static void main(String [] args) {
try {
URL url = new URL("https://tutorialspoint.com");
URLConnection urlConnection = url.openConnection();
HttpURLConnection connection = null;
if(urlConnection instanceof HttpURLConnection) {
connection = (HttpURLConnection) urlConnection;
}else {
System.out.println("Please enter an HTTP URL.");
return;
}
BufferedReader in = new BufferedReader(
new InputStreamReader(connection.getInputStream()));
String urlString = "";
String current;
while((current = in.readLine()) != null) {
urlString += current;
}
System.out.println(urlString);
} catch (IOException e) {
e.printStackTrace();
}
}
}
此程序的示例运行将产生以下结果:
输出
$ java HttpURLConnection .....a complete HTML content of home page of tutorialspoint.com.....