All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.turbomanage.httpclient.ConsoleRequestLogger Maven / Gradle / Ivy


package com.turbomanage.httpclient;

import java.io.IOException;
import java.net.HttpURLConnection;
import java.util.List;
import java.util.Map;

/**
 * Default {@link RequestLogger} used by {@link BasicHttpClient}. In recent
 * versions of Android, log() gets directed to LogCat so this can
 * work for Android, too.
 * http://stackoverflow.com/questions/2220547/why-doesnt-system
 * -out-println-work-in-android
 * 
 * @author David M. Chandler
 */
public class ConsoleRequestLogger implements RequestLogger {

    /*
     * (non-Javadoc)
     * @see com.turbomanage.httpclient.RequestLogger#isLoggingEnabled()
     */
    public boolean isLoggingEnabled() {
        return true;
    }

    /* (non-Javadoc)
     * @see com.turbomanage.httpclient.RequestLogger#log(java.lang.String)
     */
    @Override
    public void log(String msg) {
        System.out.println(msg);
    }

    /*
     * (non-Javadoc)
     * @see com.turbomanage.httpclient.RequestLogger#logRequest(java.net.
     * HttpURLConnection, java.lang.Object)
     */
    @Override
    public void logRequest(HttpURLConnection uc, Object content) throws IOException {
        log("=== HTTP Request ===");
        log(uc.getRequestMethod() + " " + uc.getURL().toString());
        if (content instanceof String) {
            log("Content: " + (String) content);
        }
        logHeaders(uc.getRequestProperties());
    }

    /*
     * (non-Javadoc)
     * @see com.turbomanage.httpclient.RequestLogger#logResponse(java.net.
     * HttpURLConnection)
     */
    @Override
    public void logResponse(HttpResponse res) {
        if (res != null) {
            log("=== HTTP Response ===");
            log("Receive url: " + res.getUrl());
            log("Status: " + res.getStatus());
            logHeaders(res.getHeaders());
            log("Content:\n" + res.getBodyAsString());
        }
    }

    /**
     * Iterate over request or response headers and log them.
     * 
     * @param map
     */
    private void logHeaders(Map> map) {
        if (map != null) {
            for (String field : map.keySet()) {
                List headers = map.get(field);
                for (String header : headers) {
                    log(field + ":" + header);
                }
            }
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy