zoukankan      html  css  js  c++  java
  • 自己写的Log记录组件

      常规的Debug组件的封装,然后加了一个文件log,分异步和同步(可跨平台使用)。

    /// <summary>
        /// 常用IO操作类
        /// </summary>
        public class HIO
        {
            /// <summary>
            /// 控制台数据错误
            /// </summary>
            /// <param name="ex"></param>
            public static void WriteConsole(Exception ex)
            {
                Console.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
                Console.WriteLine("Data:" + ex.Data + Environment.NewLine
                + " InnerException:" + ex.InnerException + Environment.NewLine
                + " Message:" + ex.Message + Environment.NewLine
                + " Source:" + ex.Source + Environment.NewLine
                + " StackTrace:" + ex.StackTrace + Environment.NewLine
                + " TargetSite:" + ex.TargetSite);
            }
            /// <summary>
            /// 控制台数据错误
            /// </summary>
            /// <param name="ex"></param>
            public static void WriteDebug(Exception ex)
            {
                Debug.WriteLine(DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss"));
                Debug.WriteLine("Data:" + ex.Data + Environment.NewLine
                + " InnerException:" + ex.InnerException + Environment.NewLine
                + " Message:" + ex.Message + Environment.NewLine
                + " Source:" + ex.Source + Environment.NewLine
                + " StackTrace:" + ex.StackTrace + Environment.NewLine
                + " TargetSite:" + ex.TargetSite);
            }
            /// <summary>
            /// 应用根目录
            /// </summary>
            public static string AppRootPath = AppDomain.CurrentDomain.BaseDirectory;// Environment.CurrentDirectory
            /// <summary>
            /// 日志目录
            /// </summary>
            public static string logDir = "Log";
            /// <summary>
            /// 日志目录全路径
            /// </summary>
            public static string logDirPath = AppRootPath + Path.DirectorySeparatorChar + logDir;
            /// <summary>
            /// 错误记录
            /// </summary>
            /// <param name="ex"></param>
            public static void WriteLog(Exception ex)
            {
                WriteLog("Data:" + ex.Data + Environment.NewLine
                    + " InnerException:" + ex.InnerException + Environment.NewLine
                    + " Message:" + ex.Message + Environment.NewLine
                    + " Source:" + ex.Source + Environment.NewLine
                    + " StackTrace:" + ex.StackTrace + Environment.NewLine
                    + " TargetSite:" + ex.TargetSite);
            }
            /// <summary>
            /// 写log
            /// </summary>
            /// <param name="InfoStr"></param>
            public static void WriteLog(string info)
            {
                WriteLog(info, logDirPath);
            }
            /// <summary>
            /// 写log(自动时间log)
            /// </summary>
            /// <param name="InfoStr">内容</param>
            /// <param name="FilePath">目录地址</param>
            public static void WriteLog(string info, string DirPath)
            {
                FileStream stream = null;
                System.IO.StreamWriter writer = null;
                try
                {
                    if (Directory.Exists(DirPath) == false)
                    {
                        Directory.CreateDirectory(DirPath);
                    }
                    string dateDir = DateTime.Now.ToString("yyyyMMdd");
                    if (!Directory.Exists(DirPath + Path.DirectorySeparatorChar + dateDir)) { Directory.CreateDirectory(DirPath + Path.DirectorySeparatorChar + dateDir); }
                    string logFilePath = DirPath + Path.DirectorySeparatorChar + dateDir
                        + Path.DirectorySeparatorChar + "SyncLog_" + DateTime.Now.ToString("yyyyMMddHH") + ".txt";
                    if (File.Exists(logFilePath) == false)
                    {
                        stream = new FileStream(logFilePath, FileMode.CreateNew, FileAccess.Write, FileShare.ReadWrite);
                    }
                    else
                    {
                        stream = new FileStream(logFilePath, FileMode.Append, FileAccess.Write, FileShare.ReadWrite);
                    }
                    writer = new System.IO.StreamWriter(stream);
                    writer.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
                    writer.WriteLine(info);
                }
                finally
                {
                    if (writer != null)
                    {
                        writer.Close();
                        writer.Dispose();
                    }
                    if (stream != null)
                    {
                        stream.Close();
                        stream.Dispose();
                    }
                }
            }
            /// <summary>
            /// 异步写log
            /// </summary>
            /// <param name="info"></param>
            public static void AsyncWriteLog(string info)
            {
                AsyncWriteLog(info, Encoding.UTF8, logDirPath);
            }
            /// <summary>
            /// 异步写log
            /// </summary>
            /// <param name="ex"></param>
            public static void AsyncWriteLog(Exception ex)
            {
                AsyncWriteLog("Data:" + ex.Data + Environment.NewLine
                    + " InnerException:" + ex.InnerException + Environment.NewLine
                    + " Message:" + ex.Message + Environment.NewLine
                    + " Source:" + ex.Source + Environment.NewLine
                    + " StackTrace:" + ex.StackTrace + Environment.NewLine
                    + " TargetSite:" + ex.TargetSite, Encoding.UTF8, logDirPath);
            }
            /// <summary>
            /// 异步写log
            /// </summary>
            /// <param name="info"></param>
            /// <param name="encode"></param>
            /// <param name="FilePath"></param>
            public static void AsyncWriteLog(string info, Encoding encode, string FileDirPath)
            {
                AsyncWriteLog(encode.GetBytes(info), FileDirPath);
            }
            /// <summary>
            /// 异步写log
            /// </summary>
            /// <param name="datagram">要写入当前流的数据的缓冲区</param>
            /// <param name="FilePath"></param>
            public static void AsyncWriteLog(byte[] datagram, string FileDirPath)
            {
                AsyncWriteLog(datagram, datagram.Length, FileDirPath, (obj) =>
                {
                    AsyncResult ar = obj as AsyncResult;
                    FileStream stream = ar.AsyncState as FileStream;
                    if (stream != null)
                    {
                        stream.Close();
                        stream.Dispose();
                    }
                });
            }
            /// <summary>
            /// 异步写log
            /// </summary>
            /// <param name="datagram">要写入当前流的数据的缓冲区</param>
            /// <param name="numBytes">最多写入的字节数</param>
            /// <param name="FilePath"></param>
            /// <param name="callback"></param>
            public static void AsyncWriteLog(byte[] datagram, int numBytes, string FileDirPath, AsyncCallback callback)
            {
                if (datagram.Length == 0) { throw new Exception("数据为0"); }
                if (numBytes == 0) { throw new Exception("写入数为0"); }
                if (string.IsNullOrEmpty(FileDirPath)) { throw new Exception("文件地址为空"); }
                if (!Directory.Exists(FileDirPath)) { Directory.CreateDirectory(FileDirPath); }
                string dateDir = DateTime.Now.ToString("yyyyMMdd");
                if (!Directory.Exists(FileDirPath + Path.DirectorySeparatorChar + dateDir)) { Directory.CreateDirectory(FileDirPath + Path.DirectorySeparatorChar + dateDir); }
                string logFilePath = FileDirPath + Path.DirectorySeparatorChar + dateDir
                    + Path.DirectorySeparatorChar + "AsyncLog_" + DateTime.Now.ToString("yyyyMMddHH") + ".txt";
                FileStream stream = null;
                try
                {
                    if (File.Exists(logFilePath) == false)
                    {
                        stream = new FileStream(logFilePath, FileMode.CreateNew, FileAccess.Write, FileShare.ReadWrite);
                    }
                    else
                    {
                        stream = new FileStream(logFilePath, FileMode.Append, FileAccess.Write, FileShare.ReadWrite);
                    }
    
                    if (stream.CanWrite)
                    {
                        stream.BeginWrite(datagram, 0, numBytes, callback, stream);
                    }
                    else
                    {
                        throw new Exception("文件无法写入,文件或只读!");
                    }
                }
                catch (Exception ex)
                {
                    WriteDebug(ex);
                }
            }
            /// <summary>
            /// 文本转义(方便讲文本转换成C#变量代码)
            /// 例子 " 转化成 string str=""";
            /// </summary>
            /// <param name="str"></param>
            /// <returns></returns>
            public static string ToEscape(string str, string m_var)
            {
                /*
                    "           "
                               \
                */
                str = str.Trim();
                str = str.Replace("\", "\\");
                str = str.Replace(""", "\"");
                return "string " + m_var + "="" + str + "";";
            }
    
            /// <summary>
            /// (递归)去掉所有首部出现的字符串
            /// </summary>
            /// <param name="str">源字符串</param>
            /// <param name="headStr">首部出现的字符串</param>
            /// <returns></returns>
            public static string RemoveHead(string str, string headStr)
            {
                if (str.StartsWith(headStr))
                {
                    str = str.Remove(0, headStr.Length);
                    return RemoveHead(str, headStr);
                }
                else
                {
                    return str;
                }
            }
            /// <summary>
            /// 路径解析转换,转化成符合当前系统的路径符号
            /// </summary>
            /// <param name="path">路径</param>
            /// <param name="flag">(路径的类型)1:windows  2:linux /(linux和web网页的分隔相符)</param>
            /// <param name="dHear">是否去掉首部的路径分隔符</param>
            /// <returns></returns>
            public static string PathParse(string path, int flag, bool dHear)
            {
                string win = @"";
                string linux = @"/";
                string sys = Path.DirectorySeparatorChar.ToString();
                if (flag == 1)
                {
                    path = path.Replace(win, sys);
                }
                else if (flag == 2)
                {
                    path = path.Replace(linux, sys);
                }
                if (dHear)
                {
                    path = RemoveHead(path, sys);
                }
                return path;
            }
            /// <summary>
            /// web路径地址转换为系统路径
            /// </summary>
            /// <param name="appPath">应用路径</param>
            /// <param name="webPath">web路径</param>
            /// <param name="dHear">是否去掉首部的路径分隔符</param>
            /// <returns></returns>
            public static string SysPathParse(string appPath, string webPath, bool dHear)
            {
                string sys = Path.DirectorySeparatorChar.ToString();
                string web = @"/";//web的分隔符
                webPath = webPath.Replace(web, sys);
                if (dHear)
                {
                    webPath = RemoveHead(webPath, sys);
                }
                string result = "";
                if (appPath.EndsWith(sys))
                {
                    if (webPath.StartsWith(sys))
                    {
                        result = appPath + webPath.Remove(0, 1);
                    }
                    else
                    {
                        result = appPath + webPath;
                    }
                }
                else
                {
                    if (webPath.StartsWith(sys))
                    {
                        result = appPath + webPath;
                    }
                    else
                    {
                        result = appPath + sys + webPath;
                    }
                }
                return result;
            }
            public static string WebPathParse(string fullPath, string appPath, bool dHear)
            {
                string sys = Path.DirectorySeparatorChar.ToString();
                string web = @"/";//web的分隔符
                if (fullPath.StartsWith(appPath))
                {
                    string webPath = fullPath.Remove(0, appPath.Length);
                    webPath = webPath.Replace(sys, web);
                    if (webPath.StartsWith(web) == false)
                    {
                        webPath = web + webPath;
                    }
                    if (dHear)
                    {
                        webPath = RemoveHead(webPath, web);
                    }
                    return webPath;
                }
                else
                {
                    return "";
                }
            }
        }
    

      

  • 相关阅读:
    触摸屏与usb鼠标同时支持
    QT国际化(lupdate/linguits/lrelease)生成.ts,转换成.qm方法
    Qt5 使用lambda
    c++中lambda表达式的用法
    异或运算的作用
    函数指针和指针函数用法和区别
    前端html页面学习---html部分
    二:maven构建module
    一:使用maven构建项目
    maven项目发布到tomcat后没有lib目录解决方案
  • 原文地址:https://www.cnblogs.com/RainbowInTheSky/p/5914766.html
Copyright © 2011-2022 走看看