Java tutorial
/* * ======================================================================== * * Copyright 2005 Tim O'Brien. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * ======================================================================== */ package com.discursive.jccook.httpclient; import java.io.IOException; import org.apache.commons.httpclient.Header; import org.apache.commons.httpclient.HeaderElement; import org.apache.commons.httpclient.HttpClient; import org.apache.commons.httpclient.HttpException; import org.apache.commons.httpclient.HttpMethod; import org.apache.commons.httpclient.HttpStatus; import org.apache.commons.httpclient.methods.GetMethod; public class ConditionalGetExample { public static void main(String[] args) throws HttpException, IOException { // Configure Logging System.setProperty("org.apache.commons.logging.Log", "org.apache.commons.logging.impl.SimpleLog"); System.setProperty("org.apache.commons.logging.simplelog.showdatetime", "true"); System.setProperty("org.apache.commons.logging.simplelog.log.httpclient.wire", "debug"); System.setProperty("org.apache.commons.logging.simplelog.log.org.apache.commons.httpclient", "debug"); ConditionalGetExample example = new ConditionalGetExample(); example.start(); } String entityTag = ""; String lastModified = ""; public void start() throws HttpException, IOException { HttpClient client = new HttpClient(); HttpMethod method = new GetMethod("http://www.apache.org"); for (int i = 0; i < 3; i++) { setHeaders(method); client.executeMethod(method); processResults(method); method.releaseConnection(); method.recycle(); } } private void setHeaders(HttpMethod method) { method.setRequestHeader(new Header("If-None-Match", entityTag)); method.setRequestHeader(new Header("If-Modified-Since", lastModified)); } private void processResults(HttpMethod method) throws HttpException { if (method.getStatusCode() == HttpStatus.SC_NOT_MODIFIED) { System.out.println("Content not modified since last request"); } else { System.out.println("Get Method retrieved content."); entityTag = retrieveHeader(method, "ETag"); lastModified = retrieveHeader(method, "Last-Modified"); System.out.println("Entity Tag: " + entityTag); System.out.println("Last Modified: " + lastModified); } } private String retrieveHeader(HttpMethod method, String name) throws HttpException { HeaderElement[] header = method.getResponseHeader(name).getElements(); String value = ""; if (header.length > 0) { value = header[0].getName(); } return value; } }