博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【HttpClient4.5中文教程】五. HttpClient执行上下文HttpContext
阅读量:4291 次
发布时间:2019-05-27

本文共 3802 字,大约阅读时间需要 12 分钟。

最初,HTTP是被设计成无状态的,面向请求-响应的协议。然而,现实世界中的应用程序经常需要通过一些逻辑相关的请求-响应交换来保持状态信息。 为了使应用程序能够维持一个过程状态, HttpClient允许HTTP请求在一个特定的执行上下文中来执行--称为HTTP上下文。如果相同的上下文在连续请求之间重用,那么多种逻辑相关的请求可以参与到一个逻辑会话中。HTTP上下文功能和java.util.Map<String,Object>很相似。 它仅仅是任意命名参数值的集合。应用程序可以在请求之前填充上下文属性,也可以在执行完成之后来检查上下文属性。
HttpContext能够包含任意的对象,因此在两个不同的线程中共享上下文是不安全的,建议每个线程都一个它自己执行的上下文。
在HTTP请求执行的这一过程中, HttpClient添加了下列属性到执行上下文中:
  • `HttpConnection实例代表连接到目标服务器的当前连接。
  • `HttpHost实例代表连接到目标服务器的当前连接。
  • `HttpRoute实例代表了完整的连接路由。
  • `HttpRequest实例代表了当前的HTTP请求。最终的HttpRequest对象在执行上下文中总是准确代表了状态信息,因为它已经发送给了服务器。每个默认的HTTP/1.0 和 HTTP/1.1使用相对的请求URI,可是,请求以non-tunneling模式通过代理发送时,URI会是绝对的。
  • `HttpResponse实例代表当前的HTTP响应。
  • `java.lang.Boolean对象是一个标识,它标志着当前请求是否完整地传输给连接目标。
  • `RequestConfig代表当前请求配置。
  • `java.util.List<URI>对象代表一个含有执行请求过程中所有的重定向地址。
你可以使用HttpClientContext适配器类来简化上下文状态的活动。
HttpContext context = <...>HttpClientContext clientContext = HttpClientContext.adapt(context);HttpHost target = clientContext.getTargetHost();HttpRequest request = clientContext.getRequest();HttpResponse response = clientContext.getResponse();RequestConfig config = clientContext.getRequestConfig();
代表一个逻辑相关的会话中的多个请求序列应该被同一个HttpContext实例执行,以确保请求之间会话上下文和状态信息的自动传输。
下面的例子中:请求配置在最初被初始化,它将在执行上下文中一直保持。共享与同一个会话中所有连续的请求。
CloseableHttpClient httpclient = HttpClients.createDefault();RequestConfig requestConfig = RequestConfig.custom()    .setSocketTimeout(1000)    .setConnectTimeout(1000)    .build();HttpGet httpget1 = new HttpGet("http://localhost/1");httpget1.setConfig(requestConfig);CloseableHttpResponse response1 = httpclient.execute(httpget1, context);try {    HttpEntity entity1 = response1.getEntity();} finally {    response1.close();}HttpGet httpget2 = new HttpGet("http://localhost/2");CloseableHttpResponse response2 = httpclient.execute(httpget2, context);try {    HttpEntity entity2 = response2.getEntity();} finally {    response2.close();}

下面的例子使用http上下文来绑定cookie:

  
import java.util.List;import org.apache.http.client.CookieStore;import org.apache.http.client.methods.CloseableHttpResponse;import org.apache.http.client.methods.HttpGet;import org.apache.http.client.protocol.HttpClientContext;import org.apache.http.cookie.Cookie;import org.apache.http.impl.client.BasicCookieStore;import org.apache.http.impl.client.CloseableHttpClient;import org.apache.http.impl.client.HttpClients;import org.apache.http.util.EntityUtils;/** * This example demonstrates the use of a local HTTP context populated with * custom attributes. */public class ClientCustomContext {    public final static void main(String[] args) throws Exception {        CloseableHttpClient httpclient = HttpClients.createDefault();        try {            // Create a local instance of cookie store            CookieStore cookieStore = new BasicCookieStore();            // Create local HTTP context            HttpClientContext localContext = HttpClientContext.create();            // Bind custom cookie store to the local context            localContext.setCookieStore(cookieStore);            HttpGet httpget = new HttpGet("http://localhost/");            System.out.println("Executing request " + httpget.getRequestLine());            // Pass local context as a parameter            CloseableHttpResponse response = httpclient.execute(httpget, localContext);            try {                System.out.println("----------------------------------------");                System.out.println(response.getStatusLine());                List
cookies = cookieStore.getCookies(); for (int i = 0; i < cookies.size(); i++) { System.out.println("Local cookie: " + cookies.get(i)); } EntityUtils.consume(response.getEntity()); } finally { response.close(); } } finally { httpclient.close(); } }}

转载地址:http://ynhgi.baihongyu.com/

你可能感兴趣的文章
很多人都没用过的轻量级Oracle数据库数据导出工具——性能超赞
查看>>
大白话讲解并发控制的悲观锁与乐观锁 / 高性能 MySQL 笔记
查看>>
javascript大量推送数据如何快速处理?
查看>>
一个关于 nolock 的故事
查看>>
关于数据库方面的面试技巧:如何从建表展现自己能力
查看>>
直击Redis持久化磁盘IO痛点,让存储不再有负担!
查看>>
CentOS 7.0 x64下Zabbix 3.0 安装笔记 / linux运维之ZABBIX通过自带web检测功能检测网站是否正常
查看>>
什么是搜索引擎分词技术?
查看>>
细说分布式Session管理
查看>>
String字符串
查看>>
java—Tomcat高性能调优方案详解
查看>>
误删mysql库不要紧,binlog数据来帮你,再也不用担心删库要跑路
查看>>
MongoDB数据库管理开源工具Robo 3T
查看>>
记一次地址服务优化(Redis使用优化)
查看>>
Oracle Database 18c 的10大新特性一览
查看>>
volatile变量与普通变量的区别
查看>>
Spring Security 使用总结
查看>>
Mysql Repliaction技术入门
查看>>
Java互联网架构-分布式系统服务治理
查看>>
阿里巴巴Java开发规约插件全球首发!
查看>>