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:
Create Java Applet to Simulate Any Sorting Technique
Converting a List to String in Java
Java Program to Implement DelayQueue API
Spring RestTemplate Request/Response Logging
Spring Boot - Tracing Micro Service Logs
Introduction to Apache Commons Text
Hướng dẫn Java Design Pattern – MVC
Dynamic Proxies in Java
Fixing 401s with CORS Preflights and Spring Security
Sorting in Java
Removing all Nulls from a List in Java
A Guide to Spring Cloud Netflix – Hystrix
Spring Boot Change Context Path
Java Program to Use rand and srand Functions
Spring Boot - Securing Web Applications
Java Program to implement Bit Set
Java Program to implement Circular Buffer
Java Stream Filter with Lambda Expression
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Exception Handling in Java
Custom Cascading in Spring Data MongoDB
Java Program to Implement Find all Cross Edges in a Graph
Lấy ngày giờ hiện tại trong Java
Java Program to Show the Duality Transformation of Line and Point
SOAP Web service: Authentication trong JAX-WS
Introduction to the Java NIO Selector
Java Program to Optimize Wire Length in Electrical Circuit
A Guide to the Java LinkedList
Hướng dẫn Java Design Pattern – Transfer Object
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Practical Java Examples of the Big O Notation
A Guide to JPA with Spring