最基础的记录日志代码

    /// 一个非常小的系统需要记录系统日志文件,要求按天建立文件夹,将当天的日志文件放在当天文件夹内
    /// 每个日志文件的大小不超过指定的大小,例如5M,超过大小限制时,创建新的日志文件记录日志
    /// 当前代码存在一个获取文件大小的问题,暂时没有找到好的解决办法,有没有其他好的办法?

    /// 实现代码如下:

public static class SystemLog
    {
        /// <summary>
        /// 写入日志
        /// </summary>
        /// <param name="log">需要记录的日志内容</param>
        public static void WriteLog(string log)
        {
            try
            {
                Stream stream = File.Open(CheckFile(), FileMode.Append);
                StreamWriter sw = new StreamWriter(stream);
                sw.Write(log);
                sw.Close();
                stream.Close();
            }
            catch (Exception e)
            {
                //日志文件存在IO读写权限等限制
                //出现读写日志BUG时,需要以其他方法记录系统BUG
                Console.WriteLine(e.Message);
            }
        }

        /// <summary>
        /// 检查目前日志文件的记录情况,保证每个日志文件的大小不超过5M
        /// 日志文件按天分文件夹存储,当天的日志文件超过5M时,在文件夹新建日志文件
        /// </summary>
        /// <returns></returns>
        private static string CheckFile()
        {
            //文件夹地址
            string appPath = System.Windows.Forms.Application.StartupPath + "\\" + DateTime.Now.ToString("yyyyMMdd");
            string filePath = string.Empty;
            if (!Directory.Exists(appPath))
            {
                DateTime now = DateTime.Now;
                Directory.CreateDirectory(appPath);
                Directory.SetLastAccessTime(appPath, now);
                filePath = appPath + "\\" + now.ToString("yyyyMMddHHmmss") + ".log";
                FileStream fs = File.Create(filePath);
                fs.Close();
            }
            else
            {
                DateTime lastAccessTime = Directory.GetLastAccessTime(appPath);
                filePath = appPath + "\\" + lastAccessTime.ToString("yyyyMMddHHmmss") + ".log";
                //这里在获取文件大小时需要打开文件获取字节流后关闭文件
                //需要采用其他方法获取文件大小,以提高效率
                if (File.ReadAllBytes(filePath).Length >= 5242880)
                {
                    try
                    {
                        DateTime now = DateTime.Now;
                        Directory.SetLastAccessTime(appPath, now);
                        filePath = appPath + "\\" + now.ToString("yyyyMMddHHmmss") + ".log";
                        FileStream fs = File.Create(filePath);
                        fs.Close();
                    }
                    catch (IOException e)
                    {
                        //如果文件夹处于打开状态,则该属性无法写入文件夹
                        //系统包IOException错误,下面需要以其他方法记录BUG
                        Console.WriteLine(e.Message);
                    }
                }
            }
            return filePath;
        }
    }


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值