方法一:通过log4j来实现
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;
public class LogException {
/**
* @将错误信息输入到txt中
* @param path
* @throws IOException
*/
public void writeLog(String path,String content) throws IOException{
File F=new File(path);
//如果文件不存在,就动态创建文件
if(!F.exists()){
F.createNewFile();
}
FileWriter fw=null;
String writeDate="时间:"+this.getNowDate()+"---"+"error:"+content;
try {
//设置为:True,表示写入的时候追加数据
fw=new FileWriter(F, true);
fw.write(writeDate+"\r\n");
} catch (IOException e) {
e.printStackTrace();
}finally{
if(fw!=null){
fw.close();
}
}
}
/**
* @获取系统当前时间
* @return
*/
public String getNowDate(){
Calendar D=Calendar.getInstance();
int y=0;
int m=0;
int d=0;
y=D.get(Calendar.YEAR);
m=D.get(Calendar.MONTH)+1;
d=D.get(Calendar.DAY_OF_MONTH);
String nowDate=String.valueOf(y)+"-"+String.valueOf(m)+"-"+String.valueOf(d);
return nowDate;
}
//测试方法
public static void main(String[] args) throws IOException {
LogException le=new LogException();
try {
le.writeLog("G:/ticket.txt", request.toString());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
方法二:使用定向输出流
public class RedirectOutputStream {
public static void main(String[] args) {
try {
PrintStream out = System.out;// 保存原输出流
PrintStream ps=new PrintStream(“E:/log.txt”);// 创建文件输出流1
PrintStream ps2=new PrintStream(“./log.txt”);// 创建文件输出流2
System.setOut(ps);// 设置使用新的输出流
System.out.println("使用新的输出流将log输出到 E:/log.txt");
System.setOut(ps2);// 设置使用新的输出流
System.out.println("使用新的输出流将log输出到 ./log.txt");
System.setOut(out);// 恢复原有输出流
System.out.println("程序运行完毕,恢复为原输出流。");
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
}