.net实现日志文件重命名且保留历史日志文件

2 篇文章 0 订阅

一.当WebSurver.log日志文件内容大于多少M时,进行重命名,重命名的名字是系统当前时间(可以根据自己的需要更改名字),以时间重命名的日志都是一些历史记录,以便日后查看,但最新记录的东西还是会记录在WebSurver.log中

二.以下是实现的代码

        public static void WriteSysLog(string p_strLogMsg)
        {
            //获取Web.config中设置的一个盘符路径
            string customPath = ConfigurationManager.AppSettings["ImagePath"].ToString();
            string[] strSplit = customPath.Split('\\');
            string letter = strSplit[0].ToString();//获得盘符
            string strFileDirectory = letter + "\\XCKY_Chancel\\";//文件夹名称         
            string strFileName = strFileDirectory + "WebSurver.log";//文件名称
 
            string sourceFileName = strFileName;
            string extension = sourceFileName.Substring(sourceFileName.LastIndexOf('.'), sourceFileName.Length - sourceFileName.LastIndexOf('.'));//获得文件后缀
            string newName = DateTime.Now.ToString("yyyyMMddHHmmssfff").ToString();//新文件的名称
 
            if (!Directory.Exists(strFileDirectory))//文件不存在
            {
                Directory.CreateDirectory(strFileDirectory);
            }
 
            if (File.Exists(strFileName))//如果文件存在
            {
                FileInfo fi = new FileInfo(strFileName);
                if (fi.Length > 1024*1024*10)//如果文件大于10M,则重命名
                {
                    
                    if (!File.Exists(Path.Combine(strFileDirectory, newName + extension)))//判断是否存在相同的名字
                    {
                        string currNewFilePath = Path.Combine(strFileDirectory, newName);
                        fi.MoveTo(currNewFilePath + extension);//生成一个重命名的文件
                    }
                }
            }
 
            if (File.Exists(strFileName))
            {
                string strLogMsg = "[" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss fff") + "]" + p_strLogMsg + "\r\n";
                File.AppendAllText(strFileName, strLogMsg);
            }
            else
            {
                FileStream fs1 = new FileStream(strFileName, FileMode.Create, FileAccess.Write);//创建写入文件 
                StreamWriter sw = new StreamWriter(fs1);
                sw.WriteLine("[" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss fff") + "]" + p_strLogMsg + "\r");//开始写入值
                sw.Close();
                fs1.Close();
            }
        }

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值