C# 写日志帮助类

写日志帮助类,共有三个静态方法。

1.创建错误日志,写文本文件。

2.创建错误日志,写入MSSQL数据库。

2.创建登陆日志,写入MSSQL数据库。

using System;

using System.Text;

using System.IO;

using System.Data;

using System.Data.SqlClient;

namespace myClass

{

public class clsLogHelper

{

#region 创建错误日志

///-----------------------------------------------------------------------------

/// <summary>创建错误日志 在c:\ErrorLog\</summary>

/// <param name="strFunctionName">strFunctionName,调用方法名</param>

/// <param name="strErrorNum">strErrorNum,错误号</param>

/// <param name="strErrorDescription">strErrorDescription,错误内容</param>

/// <returns></returns>

/// <history>2009-05-29 Created</history>

///-----------------------------------------------------------------------------

//举例:

// try

// { 要监视的代码 }

// catch()

// { myErrorLog.m_CreateErrorLogTxt("myExecute(" & str执行SQL语句 & ")", Err.Number.ToString, Err.Description) }

// finally

// { }

public static void m_CreateErrorLogTxt(string strFunctionName, string strErrorNum, string strErrorDescription)

{

string strMatter; //错误内容

string strPath; //错误文件的路径

DateTime dt = DateTime.Now;

try

{

//Server.MapPath("./") + "File"; 服务器端路径

strPath = Directory.GetCurrentDirectory() + "\\ErrorLog"; //winform工程\bin\目录下 创建日志文件夹

//strPath = "c:" + "\\ErrorLog";//暂时放在c:下

if(Directory.Exists(strPath)==false) //工程目录下 Log目录 '目录是否存在,为true则没有此目录

{

Directory.CreateDirectory(strPath); //建立目录 Directory为目录对象

}

strPath = strPath + "\\" + dt.ToString("yyyyMM");

if(Directory.Exists(strPath) == false) //目录是否存在 '工程目录下 Log\月 目录 yyyymm

{

Directory.CreateDirectory(strPath); //建立目录//日志文件,以 日 命名

}

strPath = strPath + "\\" + dt.ToString("dd") + ".txt";

strMatter = strFunctionName + " , " + strErrorNum + " , " + strErrorDescription;//生成错误信息

StreamWriter FileWriter= new StreamWriter(strPath, true); //创建日志文件

FileWriter.WriteLine("Time: " + dt.ToString("HH:mm:ss") + " Err: " + strMatter);

FileWriter.Close(); //关闭StreamWriter对象

}

catch(Exception ex)

{

//("写错误日志时出现问题,请与管理员联系! 原错误:" + strMatter + "写日志错误:" + ex.Message.ToString());

string str=ex.Message.ToString();

}

}

#endregion

#region 创建错误日志

///-----------------------------------------------------------------------------

/// <summary>创建错误日志 在 数据库 sys_ErrorLog 表中</summary>

/// <param name="strFunctionName">strFunctionName,调用方法名</param>

/// <param name="strErrorNum">strErrorNum,错误号</param>

/// <param name="strErrorDescription">strErrorDescription,错误内容</param>

/// <returns></returns>

/// <history>2009-09-08 Created</history>

///-----------------------------------------------------------------------------

//举例:

// try

// { 要监视的代码 }

// catch()

// { myErrorLog.m_CreateErrorLogSql("myExecute(" & str执行SQL语句 & ")", Err.Number.ToString, Err.Description) }

// finally

// { }

//重载--默认连接字符串

public static void m_CreateErrorLogSql(string strFunctionName, string strErrorNum, string strErrorDescription)

{

m_CreateErrorLogSql(clsPubConstant.p_ConnectionString, strFunctionName, strErrorNum, strErrorDescription);

}

public static void m_CreateErrorLogSql(string strConnectionString, string strFunctionName, string strErrorNum, string strErrorDescription)

{

try

{

DbHelperSQL.connectionString = strConnectionString;//连接字符串

if (strFunctionName.Length >= 90)//控件字符串长度

{

strFunctionName = strFunctionName.Remove(90);

}

if (strErrorNum.Length >= 90)

{

strErrorNum = strErrorNum.Remove(90);

}

if (strErrorDescription.Length >= 190)

{

strErrorDescription = strErrorDescription.Remove(190);

}

StringBuilder strSql = new StringBuilder();

strSql.Append("insert into sys_ErrorLog(");

strSql.Append("DateTime,FunctionName,ErrorNum,ErrorDescription)");

strSql.Append(" values (");

strSql.Append("@DateTime,@FunctionName,@ErrorNum,@ErrorDescription)");

SqlParameter[] parameters = {

new SqlParameter("@DateTime", SqlDbType.NVarChar),

new SqlParameter("@FunctionName", SqlDbType.NVarChar),

new SqlParameter("@ErrorNum", SqlDbType.NVarChar),

new SqlParameter("@ErrorDescription", SqlDbType.NVarChar)};

parameters[0].Value = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");//当前日间

parameters[1].Value = strFunctionName;

parameters[2].Value = strErrorNum;

parameters[3].Value = strErrorDescription;

DbHelperSQL.ExecuteSql(strSql.ToString(), parameters);//执行

}

catch

{

}

}

#endregion

#region 创建登陆日志

///-----------------------------------------------------------------------------

/// <summary>创建登陆日志 在 数据库 sys_LoginLog 表中</summary>

/// <param name="strLoginDate">登陆时间</param>

/// <param name="strLoginName">登陆用户名</param>

/// <param name="strLoginStatus">登陆情况</param>

/// <param name="strEmployeeNo">员工编号</param>

/// <param name="strRemark">备注</param>

/// <returns></returns>

/// <history>2010-01-31 Created</history>

///-----------------------------------------------------------------------------

//举例:

// clsLogHelper.m_CreateLoginLogSql("2010-01-31 12:12:00", "admin", "登陆成功","1001","备注-预留字段") }

//重载--默认连接字符串

public static void m_CreateLoginLogSql(string strLoginName, string strLoginStatus, string strEmployeeNo, string strRemark)

{

m_CreateLoginLogSql(clsPubConstant.p_ConnectionString, strLoginName, strLoginStatus, strEmployeeNo, strRemark);

}

public static void m_CreateLoginLogSql(string strConnectionString,string strLoginName, string strLoginStatus, string strEmployeeNo, string strRemark)

{

try

{

DbHelperSQL.connectionString = strConnectionString;//连接字符串

StringBuilder strSql = new StringBuilder();

strSql.Append("insert into sys_LoginLog(");

strSql.Append("LoginDate,LoginName,LoginStatus,EmployeeNo,Remark)");

strSql.Append(" values (");

strSql.Append("@LoginDate,@LoginName,@LoginStatus,@EmployeeNo,@Remark)");

SqlParameter[] parameters = {

new SqlParameter("@LoginDate", SqlDbType.NVarChar),

new SqlParameter("@LoginName", SqlDbType.NVarChar),

new SqlParameter("@LoginStatus", SqlDbType.NVarChar),

new SqlParameter("@EmployeeNo", SqlDbType.NVarChar),

new SqlParameter("@Remark", SqlDbType.NVarChar)};

parameters[0].Value = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");//当前日间

parameters[1].Value = strLoginName;

parameters[2].Value = strLoginStatus;

parameters[3].Value = strEmployeeNo;

parameters[4].Value = strRemark;

DbHelperSQL.ExecuteSql(strSql.ToString(), parameters);//执行

}

catch(System.Exception ex)

{

m_CreateErrorLogSql(strConnectionString, "m_CreateLoginLogSql( " + strLoginName + "," + strLoginStatus +"," + strEmployeeNo + "," + strRemark + ")", "", ex.Message.ToString());

}

}

#endregion

}

}