https://www.codejava.net/java-se/networking/java-urlconnection-and-httpurlconnection-examples
In this article, you will learn how to use the URLConnectionand HttpURLConnection classes for developing Java network applications through various examples.
For understanding the API for URLConnection and HttpURLConnection, please refer to this tutorial.
Here is the list of examples in this article:
- Download a web page’s HTML source code
- Check HTTP Response Code
- Set Client’s HTTP Request Header Fields
- Read all Server’s Header Fields
- Read Common Header Fields
- Set HTTP Request Method
- Send HTTP POST Request
Example #1: Download a web page’s HTML source code
The following code snippet downloads HTML source code of a webpage and save it to a file:
1234567891011121314151617181920 | String url = "https://google.com" ; String filePath = "Google.html" ; URL urlObj = new URL(url); URLConnection urlCon = urlObj.openConnection(); InputStream inputStream = urlCon.getInputStream(); BufferedInputStream reader = new BufferedInputStream(inputStream); BufferedOutputStream writer = new BufferedOutputStream( new FileOutputStream(filePath)); byte [] buffer = new byte [ 4096 ]; int bytesRead = - 1 ; while ((bytesRead = reader.read(buffer)) != - 1 ) { writer.write(buffer, 0 , bytesRead); } writer.close(); reader.close(); |
As you can see, this code opens a connection from the specified URL, gets an input stream and an output stream. Then it reads data from the input stream and writes the data to a specified file.
Adding exception handling code and parameterize the URL and file path, we have a complete program as follows:
1234567891011121314151617181920212223242526272829303132333435363738394041424344 | import java.net.*; import java.io.*; import java.util.*; public class DownloadWebPage { public static void main(String[] args) { if (args.length < 2 ) { System.out.println( "Syntax: <url> <file>" ); return ; } String url = args[ 0 ]; String filePath = args[ 1 ]; try { URL urlObj = new URL(url); URLConnection urlCon = urlObj.openConnection(); InputStream inputStream = urlCon.getInputStream(); BufferedInputStream reader = new BufferedInputStream(inputStream); BufferedOutputStream writer = new BufferedOutputStream( new FileOutputStream(filePath)); byte [] buffer = new byte [ 4096 ]; int bytesRead = - 1 ; while ((bytesRead = reader.read(buffer)) != - 1 ) { writer.write(buffer, 0 , bytesRead); } writer.close(); reader.close(); System.out.println( "Web page saved" ); } catch (MalformedURLException e) { System.out.println( "The specified URL is malformed: " + e.getMessage()); } catch (IOException e) { System.out.println( "An I/O error occurs: " + e.getMessage()); } } } |
You can run this program from command line using this syntax:
1 | java DownloadWebPage <url> <file> |
For example, download the Google’s homepage:
1 | java DownloadWebPage https://google.com Google.html |
The page’s HTML code is saved to the file Google.html.
Example #2: Check HTTP Response Code
The above program will fail silently if the server returns a response code other than 200 – the HTTP response code indicates the server returns the document without any problem. For example, if you run the above program using this command:
1 | java DownloadWebPage http://facebook.com Facebook.html |
The program terminates normally but the file Facebook.html is empty (0 byte). So let use the following code to check the server’s response code before reading and writing data:
123456789 | URL urlObj = new URL(url); HttpURLConnection httpCon = (HttpURLConnection) urlObj.openConnection(); int responseCode = httpCon.getResponseCode(); if (responseCode != HttpURLConnection.HTTP_OK) { System.out.println( "Server returned response code " + responseCode + ". Download failed." ); System.exit( 0 ); } |
This code will terminate the program if the response code is not 200 (HTTP_OK). Update, recompile and run the program again:
1 | java DownloadWebPage http://facebook.com Facebook.html |
And you should see the following output:
1 | Server returned response code 301. Download failed. |
The HTTP status code 301 indicates that the requested document is moved permanently. That means we should use https:// instead of http://. Run the program again with this command:
1 | java DownloadWebPage https://facebook.com Facebook.html |
And you see the file Facebook.html is saved with HTML code.
Example #3: Set Client’s HTTP Request Header Fields
Use the setRequestProperty(String key, String value) method of the URLConnection class to set header fields for the request. The client’s header fields provide additional information about the client and how the client expects response from the server.
Here’s an example:
1234567 | URL urlObj = new URL(url); URLConnection urlCon = urlObj.openConnection(); urlCon.setRequestProperty( "User-Agent" , "Java Client; Mac OS" ); urlCon.setRequestProperty( "Accept" , "text/html" ); urlCon.setRequestProperty( "Accept-Language" , "en-US" ); urlCon.setRequestProperty( "Connection" , "close" ); |
As you can see, this code snippet specifies 4 header fields for the request:
– User-Agent: information about the client such as browser type, operating system, architecture, etc.
– Accept: the content type understood by the client
– Accept-Language: the language understood by the client
– Connection: type of the connection. In this case, the connection is closed after a request-response roundtrip finished.
Example #4: Read all Server’s Header Fields
We can use the getHeaderFields() method of the URLConnection class to read all header fields sent from the server. Here’s an example:
12345678910111213141516 | String url = "https://google.com" ; URL urlObj = new URL(url); URLConnection urlCon = urlObj.openConnection(); Map<String, List<String>> map = urlCon.getHeaderFields(); for (String key : map.keySet()) { System.out.println(key + ":" ); List<String> values = map.get(key); for (String aValue : values) { System.out.println( "\t" + aValue); } } |
Run this code and you should see the output looks like this (from google.com):
123456789101112131415 | Transfer-Encoding: chunked null: HTTP/1.1 200 OK Server: gws Date: Sat, 09 Dec 2017 15:38:16 GMT Accept-Ranges: none Cache-Control: private, max-age=0 Content-Type: text/html; charset=ISO-8859-1 |
This information varies, depending on each server.
Example #5: Read Common Header Fields
Using descriptive get header fields methods, the following code snippet reads and prints the values of common header fields such as response code, response message, content type, content encoding, content length, and so on:
1234567891011121314151617181920212223 | String url = "https://facebook.com" ; URL urlObj = new URL(url); HttpURLConnection httpCon = (HttpURLConnection) urlObj.openConnection(); int responseCode = httpCon.getResponseCode(); String responseMessage = httpCon.getResponseMessage(); String contentType = httpCon.getContentType(); String contentEncoding = httpCon.getContentEncoding(); int contentLength = httpCon.getContentLength(); long date = httpCon.getDate(); long expiration = httpCon.getExpiration(); long lastModified = httpCon.getLastModified(); System.out.println( "Response Code: " + responseCode); System.out.println( "Response Message: " + responseMessage); System.out.println( "Content Type: " + contentType); System.out.println( "Content Encoding: " + contentEncoding); System.out.println( "Content Length: " + contentLength); System.out.println( "Date: " + new Date(date)); System.out.println( "Expiration: " + new Date(expiration)); System.out.println( "Last Modified: " + new Date(lastModified)); |
The output would be:
12345678 | Response Code: 200 Response Message: OK Content Type: text/html; charset=UTF-8 Content Encoding: null Content Length: -1 Date: Sun Dec 10 10:52:31 ICT 2017 Expiration: Sat Jan 01 07:00:00 ICT 2000 Last Modified: Thu Jan 01 07:00:00 ICT 1970 |
Example #6: Set HTTP Request Method
By default the HTTP request method is GET. You can call the setRequestMethod(String method) to set the request method which is one of GET, POST, HEAD, PUT, DELETE, TRACE, and OPTIONS.
For example, the following code sets the request method to HEAD:
123 | URL urlObj = new URL(url); HttpURLConnection httpCon = (HttpURLConnection) urlObj.openConnection(); httpCon.setRequestMethod( "HEAD" ); |
When processing a HEAD request, the server returns a response without the body content. Only the header fields are returned. Hence the method name “HEAD”.
Also note that when you set the request method to POST, you must also enable output for the connection, as POST method is about send data to the server. For example:
12 | httpCon.setDoOutput( true ); httpCon.setRequestMethod( "POST" ); |
See how to send a POST request in the next example.
Example #7: Send HTTP POST Request
To send an HTTP POST request along with parameters, you need to constructor the parameters in the following form:
1 | param1=value1¶m2=value2¶m3=value3 |
The following code snippet demonstrates how to send a login request to Twitter via HTTP POST:
12345678910111213141516171819 | String url = "https://twitter.com/sessions" ; String email = "yourname@gmail.com" ; String password = "yourpass" ; URL urlObj = new URL(url); HttpURLConnection httpCon = (HttpURLConnection) urlObj.openConnection(); httpCon.setDoOutput( true ); httpCon.setRequestMethod( "POST" ); String parameters = "username=" + email; parameters += "password=" + password; OutputStreamWriter writer = new OutputStreamWriter( httpCon.getOutputStream()); writer.write(parameters); writer.flush(); |
Of course this won’t work because Twitter requires more complex parameters for the login process (i.e. authentication key). Anyway, let try to combine this code with the example of reading all header fields and save to file to see what will happen.
And for more practical URLConnection/HttpURLConnection examples, refer to the following articles:
- Use HttpURLConnection to download file from an HTTP URL
- An HTTP utility class to send GET/POST request
- Upload files by sending multipart request programmatically
- Use URLConnection to download file from FTP server
- Using URLConnection to list files and directories on FTP server
- Upload files to FTP server using URLConnection class