package com.yss.demo.util;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* 打印专用
*
* @Author: yss
* @Date: 2021-01-17 12:49
* @Version: 1.0.0
*/
public class log {
/**
* 数组、集合fori循环打印日志
* @param message 备注信息
* @param num fori循环的i
* @param objects 实体类的多个参数
* 打印结果:message[1] - [备注] - [zhangsan]
*/
public static void info(String message,Integer num,Object... objects){
String msg = "message[" + num + "] - [" + message + " ] ";
logFori(msg, objects);
}
/**
* 多参数循环打印日志
* @param message 备注信息
* @param objects 实体类的多个参数
* 打印结果:message[备注] - [zhangsan] - [15岁]
*/
public static void info(String message,Object... objects){
String msg = "message[" + message + " ] ";
logFori(msg, objects);
}
/**
* 普通信息日志
* @param msg 备注信息
* 打印结果:我是信息
*/
public static void info(String msg){
logFori(msg, null);
}
/**
* 数组、集合fori循环打印日志
* @param num fori循环的i
* @param objects 实体类的多个参数
* 打印结果:message[1] - [zhangsan] - [15岁]
*/
public static void info(int num,Object... objects){
String msg = "message[" + num + "]";
logFori(msg, objects);
}
public static void logFori(String msg, Object[] objects) {
if (objects != null){
for (int i = 0; i < objects.length; i++) {
msg = msg + " - " ;
if (objects[i] != null){
msg = msg + "[" + objects[i].toString() + "]";
}else{
msg = msg + "[null]";
}
}
}
writeLog(msg);
}
/**
* 创建当天日志文件
*/
public static String creatNewPath(){
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyMMdd");//修改日期格式
String format = simpleDateFormat.format(new Date());
String projectName = System.getProperty("user.dir");//获取当前工程的路径
File path=new File(projectName + "/logByYss");
if(!path.exists()){//如果文件夹不存在
path.mkdir();//创建文件夹
}
String newPath = path + "/log" + format + ".txt";
return newPath;
}
/**
* 写入数据到日志文件中
*/
public static void writeLog(String massage){
//创建日志文件
String newPath = creatNewPath();
File file = new File(newPath);
if (!file.exists()){//判断文件夹是否存在 - 文件夹不存在
//不存在就创建
try {
file.createNewFile();
} catch (IOException e) {
e.printStackTrace();
}
}
//获取方法类名以及方法名
String className = Thread.currentThread().getStackTrace()[4].getClassName();
String methodName = new Throwable().getStackTrace()[3].getMethodName();
//日期区别文件名
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String format = simpleDateFormat.format(new Date());
//组装信息
massage = "[" + format + "] - [ " + className + "] - [" + methodName + "] : [" + massage + "]";
System.out.println(massage);
//写入日志
FileWriter fileWriter = null;
try {
fileWriter = new FileWriter(file,true);
fileWriter.write(massage);
fileWriter.write("\r\n");
fileWriter.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (fileWriter != null ){
try {
fileWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
执行方法:
执行效果: