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

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

wKioL1ZvvdjRs20OAAAxpUs_Qbw907.png

二.以下是实现的代码

    

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


你可能感兴趣的:(记录,public,命名,历史,letter)