http库Java_Java HTTP 请求库

HttpRequest是一个简单的便利库,用于通过HttpURLConnection发起请求并访问响应。该库旨在简化使用HttpURLConnection进行HTTP请求的过程,提供流畅的接口构建请求及支持多部分请求等功能。

Http Request 68747470733a2f2f7472617669732d63692e6f72672f6b6576696e73617769636b692f687474702d726571756573742e737667

A simple convenience library for using a HttpURLConnection to make requests and access the response.

This library is available under the MIT License.

Usage

The http-request library is available from Maven Central.

com.github.kevinsawicki

http-request

6.0

Not using Maven? Simply copy the HttpRequest class into your project, update the package declaration, and you are good to go.

Javadocs are available here.

FAQ

Who uses this?

See here for a list of known projects using this library.

Why was this written?

This library was written to make HTTP requests simple and easy when using a HttpURLConnection.

Libraries like Apache HttpComponents are great but sometimes for either simplicity, or perhaps for the environment you are deploying to (Android), you just want to use a good old-fashioned HttpURLConnection. This library seeks to add convenience and common patterns to the act of making HTTP requests such as a fluid-interface for building requests and support for features such as multipart requests.

Bottom line: The single goal of this library is to improve the usability of the HttpURLConnection class.

What are the dependencies?

None. The goal of this library is to be a single class class with some inner static classes. The test project does require Jetty in order to test requests against an actual HTTP server implementation.

How are exceptions managed?

The HttpRequest class does not throw any checked exceptions, instead all low-level exceptions are wrapped up in a HttpRequestException which extends RuntimeException. You can access the underlying exception by catching HttpRequestException and calling getCause() which will always return the original IOException.

Are requests asynchronous?

No. The underlying HttpUrlConnection object that each HttpRequest object wraps has a synchronous API and therefore all methods on HttpRequest are also synchronous.

Therefore it is important to not use an HttpRequest object on the main thread of your application.

Here is a simple Android example of using it from an AsyncTask:

private class DownloadTask extends AsyncTask {

protected File doInBackground(String... urls) {

try {

HttpRequest request = HttpRequest.get(urls[0]);

File file = null;

if (request.ok()) {

file = File.createTempFile("download", ".tmp");

request.receive(file);

publishProgress(file.length());

}

return file;

} catch (HttpRequestException exception) {

return null;

}

}

protected void onProgressUpdate(Long... progress) {

Log.d("MyApp", "Downloaded bytes: " + progress[0]);

}

protected void onPostExecute(File file) {

if (file != null)

Log.d("MyApp", "Downloaded file to: " + file.getAbsolutePath());

else

Log.d("MyApp", "Download failed");

}

}

new DownloadTask().execute("http://google.com");

Examples

Perform a GET request and get the status of the response

int response = HttpRequest.get("http://google.com").code();

Perform a GET request and get the body of the response

String response = HttpRequest.get("http://google.com").body();

System.out.println("Response was: " + response);

Print the response of a GET request to standard out

HttpRequest.get("http://google.com").receive(System.out);

Adding query parameters

HttpRequest request = HttpRequest.get("http://google.com", true, 'q', "baseball gloves", "size", 100);

System.out.println(request.toString()); // GET http://google.com?q=baseball%20gloves&size=100

Using arrays as query parameters

int[] ids = new int[] { 22, 23 };

HttpRequest request = HttpRequest.get("http://google.com", true, "id", ids);

System.out.println(request.toString()); // GET http://google.com?id[]=22&id[]=23

Working with request/response headers

String contentType = HttpRequest.get("http://google.com")

.accept("application/json") //Sets request header

.contentType(); //Gets response header

System.out.println("Response content type was " + contentType);

Perform a POST request with some data and get the status of the response

int response = HttpRequest.post("http://google.com").send("name=kevin").code();

Authenticate using Basic authentication

int response = HttpRequest.get("http://google.com").basic("username", "p4ssw0rd").code();

Perform a multipart POST request

HttpRequest request = HttpRequest.post("http://google.com");

request.part("status[body]", "Making a multipart request");

request.part("status[image]", new File("/home/kevin/Pictures/ide.png"));

if (request.ok())

System.out.println("Status was updated");

Perform a POST request with form data

Map data = new HashMap();

data.put("user", "A User");

data.put("state", "CA");

if (HttpRequest.post("http://google.com").form(data).created())

System.out.println("User was created");

Copy body of response to a file

File output = new File("/output/request.out");

HttpRequest.get("http://google.com").receive(output);

Post contents of a file

File input = new File("/input/data.txt");

int response = HttpRequest.post("http://google.com").send(input).code();

Using entity tags for caching

File latest = new File("/data/cache.json");

HttpRequest request = HttpRequest.get("http://google.com");

//Copy response to file

request.receive(latest);

//Store eTag of response

String eTag = request.eTag();

//Later on check if changes exist

boolean unchanged = HttpRequest.get("http://google.com")

.ifNoneMatch(eTag)

.notModified();

Using gzip compression

HttpRequest request = HttpRequest.get("http://google.com");

//Tell server to gzip response and automatically uncompress

request.acceptGzipEncoding().uncompress(true);

String uncompressed = request.body();

System.out.println("Uncompressed response is: " + uncompressed);

Ignoring security when using HTTPS

HttpRequest request = HttpRequest.get("https://google.com");

//Accept all certificates

request.trustAllCerts();

//Accept all hostnames

request.trustAllHosts();

Configuring an HTTP proxy

HttpRequest request = HttpRequest.get("https://google.com");

//Configure proxy

request.useProxy("localhost", 8080);

//Optional proxy basic authentication

request.proxyBasic("username", "p4ssw0rd");

Following redirects

int code = HttpRequest.get("http://google.com").followRedirects(true).code();

Custom connection factory

Looking to use this library with OkHttp? Read here.

HttpRequest.setConnectionFactory(new ConnectionFactory() {

public HttpURLConnection create(URL url) throws IOException {

if (!"https".equals(url.getProtocol()))

throw new IOException("Only secure requests are allowed");

return (HttpURLConnection) url.openConnection();

}

public HttpURLConnection create(URL url, Proxy proxy) throws IOException {

if (!"https".equals(url.getProtocol()))

throw new IOException("Only secure requests are allowed");

return (HttpURLConnection) url.openConnection(proxy);

}

});

Contributors

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值