自己写的日志log文件资源解说

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();
                }
            }
        }
    }
}

执行方法:
在这里插入图片描述

执行效果:
在这里插入图片描述

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值