二开案例.服务插件.写日志
【应用场景】
在服务插件中保存上机操作日志和文件日志。
【案例演示】
采购订单,保存时,在服务插件中保存上机操作日志和文件日志。
【实现步骤】
<1>编写服务插件,代码如下。
using Kingdee.BOS;
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Core.Log;
using Kingdee.BOS.Log;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.Util;
using System.Collections.Generic;
using System.ComponentModel;
namespace Jac.XkDemo.BOS.App.PlugIn
{
/// <summary>
/// 【服务插件】写日志
/// </summary>
[Description("【服务插件】写日志"), HotUpdate]
public class WriteLogOperationServicePlugIn : AbstractOperationServicePlugIn
{
public override void AfterExecuteOperationTransaction(AfterExecuteOperationTransaction e)
{
base.AfterExecuteOperationTransaction(e);
// 写上机操作日志
var logs = new List<LogObject>();
foreach (DynamicObject obj in e.DataEntitys)
{
var log = new LogObject();
log.pkValue = obj[0].ToString();
log.Description = "我是一条测试日志数据:)";
log.OperateName = "保存上机操作日志";
log.ObjectTypeId = this.BusinessInfo.GetForm().Id;
log.SubSystemId = this.BusinessInfo.GetForm().SubsysId;
log.Environment = OperatingEnvironment.BizOperate;
logs.Add(log);
}
new Kingdee.BOS.App.LogService.Log().BatchWriteLog(this.Context, logs);
// 写文件日志
Logger.Info("BOS", "我是一条测试日志数据:)");
Logger.Error("BOS", "我是一条测试日志数据:)", new KDException("?", "金蝶异常......"));
}
}
}
<2>拷贝插件组件到应用站点的WebSite\Bin目录下,重启IIS。
<3>BOSIDE扩展采购订单,保存操作注册服务插件,保存元数据,开发完毕。
如果使用Python插件,代码如下图所示:
【功能验证】
<1>登录业务站点,打开采购订单编辑界面,点保存菜单,就会写入日志啦。
上机操作日志:
文件日志:
---------------------------------------------------------------------------------------------------------
【金蝶云星空BOS二次开发案例演示】https://vip.kingdee.com/article/94751030918525696
二开案例.服务插件.写日志
本文2024-09-23 04:18:33发表“云星空知识”栏目。
本文链接:https://wenku.my7c.com/article/kingdee-k3cloud-164481.html