在后台管理中,有一些操作是需要增加操作日志的,尤其是對一些比較敏感的金額類的操作,比如商城類的修改商品金額、刪除商品、贈送金額等人工的操作。日志中記錄着相關操作人的操作信息,這樣,出了問題也容易排查。
那么如何高效統一的處理增加這些日志呢?下面,分享一下我的思路及做法。
1、建日志相關表。需要建兩個表,一是日志類型表(ActivityLogType),二是日志表(ActivityLog), 相關的表結構如下:
日志類型表:Id,SystemKeyword,Name,Enable (1 自動投標設置 自動投標設置 0)
日志表:Id,ActivityLogTypeId,CustomerId,Comment,CreateTime
2、自定義一個屬性類,繼承ActionFilterAttribute
/// <summary>
/// 業務日志
/// </summary>
public class BizActivityLogAttribute : ActionFilterAttribute
{
/// <summary>
/// 參數名稱列表,可以用, | 分隔
/// </summary>
private readonly string _parameterNameList;
//類型名稱
private string _activityLogTypeName = "";
/// <summary>
/// 活動日志
/// </summary>
/// <param name="activityLogTypeName">類別名稱</param>
/// <param name="parm">參數名稱列表,可以用, | 分隔</param>
public BizActivityLogAttribute(string activityLogTypeName, string parm)
{
_activityLogTypeName = activityLogTypeName;
_parameterNameList = parm;
}
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
var workContext = EngineContext.Current.Resolve<IWorkContext>();
if (workContext != null && workContext.CurrentCustomer != null)
{
Dictionary<string, string> parmsObj = new Dictionary<string, string>();
foreach (var item in _parameterNameList.Split(',', '|'))
{
var valueProviderResult = filterContext.Controller.ValueProvider.GetValue(item);
if (valueProviderResult != null && !parmsObj.ContainsKey(item))
{
parmsObj.Add(item, valueProviderResult.AttemptedValue);
}
}
//日志內容
StringBuilder logContent = new StringBuilder();
foreach (KeyValuePair<string, string> kvp in parmsObj)
{
logContent.AppendFormat("{0}:{1} ",kvp.Key,kvp.Value);
}
//******************************************************************************
//這里是插入數據表操作
//步驟:
//1、根據日志類型表的SystemKeyword得到日志類型Id
//2、往日志表里插入數據,logContent.ToString()是內容,內容可以自己拼接字符串,比如:string.Format("刪除記錄,刪除操作者{0}","xxxx");
var _customerActivityService = EngineContext.Current.Resolve<ICustomerActivityService>();
_customerActivityService.InsertActivity(_activityLogTypeName, logContent.ToString(), workContext.CurrentCustomer, workContext.CurrentCustomer.Id);
//******************************************************************************
}
}
}
3、在要寫日志的ActionResult里增加屬性標識,很簡單,如:
參數寫法:
[BizActivityLog("新增激活碼", "activateCodeType,filePath")]
public ActionResult Add(int? activateCodeType, string filePath)
{
}
模型寫法:
[BizActivityLog("刪除激活碼", "RegNumber,CouponCode,ActivateCodeType,StartCreateDate,EndCreateDate,StartPresentedDate,EndPresentedDate")]
public ActionResult Del(ActivateCodeSearchModel searchModel)
{
}
BizActivityLog的第一個參數是SystemKeyword。
那么,最終將會往數據庫里增加類型下面的一條記錄:
16599 ,804,274075 CustomerId:276638 Phone:18686556492 Amount:1000000 RealName:張三 BankName:中國人民銀行 2015-01-21 14:52:02.290
