5

对于调试问题,我希望在出现一组选项时让 Unirest-Java 执行请求。我怎样才能得到这个:

POST / HTTP/1.1
Host: www.some.host.tld
Connection: keep-alive
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
field1=FIELD1&field2=FIELD2

由此:

HttpRequest request = Unirest.post(SOMEHOST_URL)
            .field("field1" , FIELD1)
            .field("field2", FIELD2)
            .getHttpRequest();

也就是说,我怎样才能从 a 获取完整的 HTTP 请求HttpRequest?我真的不知道要使用的代理,因为我可以让 SSL 支持工作的唯一一个是 Charles,并且由于某种原因它不会拾取 java 流量。其他工具会阻塞 SSL,主要是因为我需要与之通信的服务器存在缺陷,使用自签名证书和无效主机名。所以我很乐意尝试代理,但它必须在这些条件下工作。最好从Unirest/HTTPClient本身提取这些信息。我已经尝试过构建HttpClientwith.setInterceptorFirst(但我无法从拦截器中获取请求正文,只有它的一些标头。

4

3 回答 3

5

我从未使用过 Unirest,但它使用 Apache HTTP 客户端 4,因此在 org.apache.http 上设置调试级别记录器应该会为您提供所有传输的数据,包括标题和内容。

请根据您使用的日志系统查看如何操作

编辑:https ://hc.apache.org/httpcomponents-client-4.5.x/logging.html

于 2014-09-25T06:27:59.440 回答
3

不幸的是,Unirest 没有一个很好的机制来获取发送的请求。但是您可以通过以下方式重建请求:

// build a request
HttpRequestWithBody request = Unirest.post(url);
request.headers = myHeaders;
request.body = myBody;

// send the request
HttpResponse<String> response = request.asString(); 

// print the request 
System.out.println(request.getHttpMethod() + " " + request.getUrl() + " HTTP/1.1");

Map<String, List<String>> requestHeaders = request.getHeaders();

for(String key : requestHeaders.keySet()) {
    List<String> values = requestHeaders.get(key);
    for(String value : values) {
        System.out.println(key + " : " + value);
    }
}

InputStream in = loginRequest.getBody().getEntity().getContent();
String body = IOUtils.toString(in, "UTF-8");
in.close();

System.out.println(body);
于 2016-09-28T22:27:16.870 回答
1

您可以使用 TCPMon:https ://code.google.com/p/tcpmon/

从网站:

客户端将连接到运行 tcpmon 的主机上的本地端口。服务器的地址应在服务器名称和服务器端口中指定。为每个连接捕获的信息显示在由连接的本地端口标识的选项卡式面板中。

这个工具我以前用过,轻巧好用。如果您需要教程,请检查以下内容:

http://www.asjava.com/web-services/tcpmon-tutorial-web-service-debugging-tool/

更新。

TCPMon 无法监控 https 流量。或者,您可以使用 SSLDump。

ssldump 的主站点:http ://www.rtfm.com/ssldump/Ssldump.html 使用示例:http: //blog.facilelogin.com/2010/11/ssl-debugging-part-ii-intercepting 。 html

于 2014-09-22T14:16:26.143 回答