java读取网页内容,并保存

4 篇文章 0 订阅

利用java进行读取网页内容并保存。参数为url链接。


使用到的jar文件:

  1. commons-logging-1.2.jar
  2. httpclient-4.5.1.jar
  3. httpcore-4.4.3.jar


package com.crawler;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;

/**
 * 网络爬虫测试
 * 
 * @author Administrator
 * @2016年11月4日
 */
public class WebCrawler {
	public static void main(String[] args) {
		CloseableHttpClient httpClient = HttpClients.createDefault();
		HttpGet httpGet = new HttpGet("http://www.zysj.com.cn/lilunshuji/jichulilun/index.html");
		httpGet.addHeader("Content-Type","application/x-www-form-urlencoded;charset=utf-8");
		// 执行请求
		HttpResponse response;
		String line;
		try {

			response = httpClient.execute(httpGet);
			HttpEntity httpEntity = response.getEntity();
			BufferedReader bufferedReader = null;
			bufferedReader = new BufferedReader(new InputStreamReader(
					httpEntity.getContent(), "utf-8"), 8 * 1024);
			StringBuilder entityStringBuilder = new StringBuilder();
			while ((line = bufferedReader.readLine()) != null) {
				entityStringBuilder.append(line + "\n");
			}
		//	System.out.println(entityStringBuilder.toString());
		// appendMethodB("f:/中医基础理论.html",entityStringBuilder.toString());
			savaFile("f:/中医基础理论.html",entityStringBuilder.toString(),"UTF-8");

		} catch (ClientProtocolException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	/**
	 * 保存文件
	 * @param fileName 文件名称:绝对路径
	 * @param content 要保存的内容
	 * @param format 以某种格式保存文件
	 */
	public static void savaFile(String fileName, String content,String format) {
		BufferedWriter rd=null;
		OutputStream out=null;
		File file = new File(fileName);
		try {
			out = new FileOutputStream(file);
			rd = new BufferedWriter(new OutputStreamWriter(out,format));
			rd.write(content);
		} catch (IOException e) {
			e.printStackTrace();
		}finally{
			if(null!=rd){
				try {
					rd.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
			if(null!=out){
				try {
					out.close();
				} catch (IOException e) {
					e.printStackTrace();
				}
			}
			
		}
	}

	/**
	 * 
	 * @param fileName
	 * @param content
	 */
	public static void appendMethodB(String fileName, String content) {
		FileWriter writer=null;
		try {
			writer = new FileWriter(fileName, false);
			// 打开一个写文件器,构造函数中的第二个参数true表示以追加形式写文件
			writer.write(content);
		} catch (IOException e) {
			e.printStackTrace();
		}finally{
			try {
				if(null!=writer){
					writer.close();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
			
		}
	}
}




  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值