二开案例.服务插件.获取调用堆栈

【应用场景】
某个功能不知道被谁调用了,可通过记录调用堆栈日志进行跟踪分析。
【案例演示】
付款申请单被删,查看删除操作的调用堆栈。

【实现步骤】
<1>编写服务插件,代码如下。
using Kingdee.BOS.Core.DynamicForm.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Log;
using Kingdee.BOS.Util;
using System.Collections.Generic;
using System.ComponentModel;
using System.Diagnostics;
using System.Linq;
namespace Jac.XkDemo.BOS.App.PlugIn
{
/// <summary>
/// 【服务插件】获取调用堆栈
/// </summary>
[Description("【服务插件】获取调用堆栈"), HotUpdate]
public class CatchStackOperationServicePlugIn : AbstractOperationServicePlugIn
{
public override void EndOperationTransaction(EndOperationTransactionArgs e)
{
base.EndOperationTransaction(e);
var ids = string.Join(",", e.DataEntitys.Select(o => string.Format("{0}({1})", o[0], o[this.BusinessInfo.GetBillNoField().PropertyName])));
var logs = new List<string>();
logs.Add(string.Format("单据:{0};操作:{1};单号:{2}", this.BusinessInfo.GetForm().Name, this.FormOperation.OperationName, ids));
var stackFrames = new StackTrace().GetFrames();
foreach (var stackFrame二开案例.服务插件.获取调用堆栈
【应用场景】某个功能不知道被谁调用了,可通过记录调用堆栈日志进行跟踪分析。【案例演示】付款申请单被删,查看删除操作的调用堆栈。【实...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



