Take this example.
import java.io.InputStreamReader; import java.io.Reader; import java.net.URL; import java.net.URLConnection; public class HttpConnect { public static void main(String[] args) throws Exception { URL url = new URL("http://www.rgagnon.com/howto.html"); URLConnection con = url.openConnection(); Reader reader = new InputStreamReader(con.getInputStream()); while (true) { int ch = reader.read(); if (ch==-1) { break; } System.out.print((char)ch); } } }
The above snippet reads the HTML page and dumps it to the console.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <HTML><HEAD> <!-- developpe par Real Gagnon, Quebec Canada --> <LINK REL="SHORTCUT ICON" HREF="http://www.maixuanviet.com/favicon.ico"> <META NAME="description" Content="Real's JAVA JAVASCRIPT WSH and PowerBuilder How-to pages with useful code snippets"> <META NAME="keywords" Content="java,javascript,wsh,vbscript,how-to,powerbuilder"> <LINK title="mystyle" href="howto.css" type="text/css" rel="stylesheet"> ...
To trace what is going on at the HTTP protocol level, we can switch the HttpURLConnection/UrlConnection in debug mode.
You must enable the java-logging mechanism by setting a special property when starting the JVM :
java.exe -Djava.util.logging.config.file=logging.properties HttpConnect
and put in logging.properties file (by default in JRE_HOME\lib) the following property
sun.net.www.protocol.http.HttpURLConnection.level = ALL
Note :
If running from Eclipse, you put the -Djava.util.logging… via the Run configuration dialog -> Arguments Tab -> VM arguments textarea.
The result is :
2010-08-07 00:00:31 sun.net.www.protocol.http.HttpURLConnection writeRequests FIN: sun.net.www.MessageHeader@16caf435 pairs: {GET /howto.html HTTP/1.1: null}{User-Agent: Java/1.6.0_20}{Host: www.maixuanviet.com}{Accept: text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2}{Connection: keep-alive} 2010-08-07 00:00:31 sun.net.www.protocol.http.HttpURLConnection getInputStream FIN: sun.net.www.MessageHeader@5ac0728 pairs: {null: HTTP/1.1 200 OK}{Date: Sat, 07 Aug 2010 04:00:33 GMT}{Server: Apache}{Accept-Ranges: bytes}{Content-Length: 17912}{Keep-Alive: timeout=5, max=64}{Connection: Keep-Alive}{Content-Type: text/html} <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <HTML><HEAD> <!-- developpe par Real Gagnon, Quebec Canada --> <LINK REL="SHORTCUT ICON" HREF="http://www.maixuanviet.com/favicon.ico"> <META NAME="description" Content="Real's JAVA JAVASCRIPT WSH and PowerBuilder How-to pages with useful code snippets"> ...
Done! Happy Coding!
Related posts:
Interface trong Java 8 – Default method và Static method
Sao chép các phần tử của một mảng sang mảng khác như thế nào?
Sorting Query Results with Spring Data
Custom HTTP Header with the HttpClient
Creating Docker Images with Spring Boot
Filtering a Stream of Optionals in Java
Integer Constant Pool trong Java
Derived Query Methods in Spring Data JPA Repositories
Java Program to Solve the 0-1 Knapsack Problem
Java Program to Implement vector
LinkedHashSet trong java
Java Program to Implement Gabow Algorithm
Introduction to Apache Commons Text
Java Program to Implement Booth Algorithm
Chương trình Java đầu tiên
Spring Boot - Exception Handling
Java Program to Implement Johnson’s Algorithm
Examine the internal DNS cache
Spring Boot: Customize the Jackson ObjectMapper
New Features in Java 14
Java Program to Perform Left Rotation on a Binary Search Tree
The HttpMediaTypeNotAcceptableException in Spring MVC
How to Return 404 with Spring WebFlux
Giới thiệu JDBC Connection Pool
Introduction to Liquibase Rollback
Java Program to Perform Optimal Paranthesization Using Dynamic Programming
Java Program to Implement AA Tree
Java Program to Find the Edge Connectivity of a Graph
CharSequence vs. String in Java
Spring Boot - Service Components
A Guide to JPA with Spring
Java Program to find the maximum subarray sum O(n^2) time(naive method)