在之前,写了篇Java模拟HTTP的Get和Post请求的文章,这篇文章起源与和一个朋友砍飞信诈骗网站的问题,于是动用了Apache的comments-net包,也实现了get和post的http请求,并且将响应html代码获取。可是细心的博友提出:在获取有些网站出现乱码,最后发现没有处理字符集,这里做针对博友的意见做了增强,增强部分主要是响应内容的字符编码、相应代码的美化选项。
下面是代码:
importorg.apache.commons.httpclient.HttpClient;importorg.apache.commons.httpclient.HttpMethod;importorg.apache.commons.httpclient.HttpStatus;importorg.apache.commons.httpclient.URIException;importorg.apache.commons.httpclient.methods.GetMethod;importorg.apache.commons.httpclient.methods.PostMethod;importorg.apache.commons.httpclient.params.HttpMethodParams;importorg.apache.commons.httpclient.util.URIUtil;importorg.apache.commons.lang.StringUtils;importorg.apache.commons.logging.Log;importorg.apache.commons.logging.LogFactory;importjava.io.BufferedReader;importjava.io.IOException;importjava.io.InputStreamReader;importjava.util.Map;/*** HTTP工具箱
*
*@authorleizhimin 2009-6-19 16:36:18*/
public final classHttpTookit {private static Log log = LogFactory.getLog(HttpTookit.class);/*** 执行一个HTTP GET请求,返回请求响应的HTML
*
*@paramurl 请求的URL地址
*@paramqueryString 请求的查询参数,可以为null
*@paramcharset 字符集
*@parampretty 是否美化
*@return返回请求响应的HTML*/
public static String doGet(String url, String queryString, String charset, booleanpretty) {
StringBuffer response= newStringBuffer();
HttpClient client= newHttpClient();
HttpMethod method= newGetMethod(url);try{if(StringUtils.isNotBlank(queryString))//对get请求参数做了http请求默认编码,好像没有任何问题,汉字编码后,就成为%式样的字符串
method.setQueryString(URIUtil.encodeQuery(queryString));
client.executeMethod(method);if (method.getStatusCode() ==HttpStatus.SC_OK) {
BufferedReader reader= new BufferedReader(newInputStreamReader(method.getResponseBodyAsStream(), charset));
String line;while ((line = reader.readLine()) != null) {if(pretty)
response.append(line).append(System.getProperty("line.separator"));elseresponse.append(line);
}
reader.close();
}
}catch(URIException e) {