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
}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值