跟我一步一步学爬虫---403禁止访问(三)

对于初学者肯定会什么网站都爬,然后就会发现有些网站比如CSDN就会返回403错误。原因是浏览器和java程序的请求是不太一样的,我们伪装成浏览器的行为就可以了。

import java.io.IOException;

import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.HttpException;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.commons.httpclient.params.HttpMethodParams;

public class PostMethodTest {
	
	public static void main(String[] args) {
		Test();
	}
	
	public static void Test() {
			
			HttpClient httpClient = new HttpClient();
			PostMethod postMethod = new PostMethod("http://blog.csdn.net/hjgzj");
			try {
				httpClient.getParams().setParameter(HttpMethodParams.USER_AGENT, "Mozilla/5.0 (X11; U; Linux i686; zh-CN; rv:1.9.1.2) Gecko/20090803");
				int statusCode = httpClient.executeMethod(postMethod);
				System.out.println(statusCode);
				System.out.println(postMethod.getResponseBodyAsString());
			} catch (HttpException e) {
				e.printStackTrace();
			} catch (IOException e) {
				e.printStackTrace();
			}
	}
}

嗯,我们就是比之前的代码多加了一行httpClient.getParams().setParameter(HttpMethodParams.USER_AGENT, "Mozilla/5.0 (X11; U; Linux i686; zh-CN; rv:1.9.1.2) Gecko/20090803"); 可以解决了。

如果还有什么网站报403,欢迎留言,我会研究一下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值