今天做了一个小工具,就是用java io流去读取一个文件,从那个文件中检索相应的内容,然后在把内容抓取出来。做这个的初衷是,从Linux系统上自动down下来日志文件,然后把日志文件里的有用内容抓取过来,通过Email发送给指定的人,这是其中的一个小环节,项目还要扩充。以后还会定时任务处理,自动发邮件功能。
字节流版本
package com.ibm.logstool.io;
import java.io.DataInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.LineNumberInputStream;
public class ReadLogs {
public String getErrMessage(String filePath,String errMessage){
FileInputStream fs=null;
StringBuffer sb=new StringBuffer();
DataInputStream ds = null;
LineNumberInputStream li=null;
try {
File file=new File(filePath);
fs = new FileInputStream(file);
li= new LineNumberInputStream(fs);
ds= new DataInputStream(li);
String line;
int i=1;
while((line=ds.readLine())!=null){
//System.out.println("Did line number: " +li.getLineNumber()+"-"+line);
if(line.indexOf(errMessage)>-1){
sb.append("line "+i+" : "+line+"\n");
}
i++;
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
if(ds!=null){
ds.close();
ds=null;
}
if(li!=null){
li.close();
li=null;
}
if(fs!=null){
fs.close();
fs=null;
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return sb.toString();
}
public static void main(String[] args) {
// TODO Auto-generated method stub
String errM="Send mail failed after trying";
ReadLogs rl=new ReadLogs();
String path="E:\\programs\\antLogProject\\ShopzAll.log";
String err=rl.getErrMessage(path,errM);
System.out.println("err==="+err);
}
}
字符流版本
package com.ibm.logstool.io;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.io.LineNumberReader;
public class ReadLogs {
public String getErrMessage(String filePath,String errMessage){
FileReader fr=null;
StringBuffer sb=new StringBuffer();
LineNumberReader lr=null;
BufferedReader br=null;
try {
File file=new File(filePath);
fr = new FileReader(file);
lr= new LineNumberReader(fr);
br=new BufferedReader(lr);
String line;
int i=1;
while((line=br.readLine())!=null){
//System.out.println("Did line number: " +li.getLineNumber()+"-"+line);
if(line.indexOf(errMessage)>-1){
sb.append("line "+i+" : "+line+"\n");
}
i++;
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
if(br!=null){
br.close();
br=null;
}
if(lr!=null){
lr.close();
lr=null;
}
if(fr!=null){
fr.close();
fr=null;
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return sb.toString();
}
public static void main(String[] args) {
// TODO Auto-generated method stub
String errM="Send mail failed after trying";
ReadLogs rl=new ReadLogs();
String path="E:\\programs\\antLogProject\\ShopzAll.log";
String err=rl.getErrMessage(path,errM);
System.out.println("err==="+err);
}
}