.net实现日志文件重命名且保留历史日志文件
一.当WebSurver.log日志文件内容大于多少M时,进行重命名,重命名的名字是系统当前时间(可以根据自己的需要更改名字),以时间重命名的日志都是一些历史记录,以便日后查看,但最新记录的东西还是会记录在WebSurver.log中
成都创新互联公司主营金牛网站建设的网络公司,主营网站建设方案,成都APP应用开发,金牛h5微信小程序开发搭建,金牛网站营销推广欢迎金牛等地区企业咨询
二.以下是实现的代码
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(); } }
本文标题:.net实现日志文件重命名且保留历史日志文件
网址分享:http://pwwzsj.com/article/jceddp.html