MS CRM 2011的自定义和开发(11)——插件(plugin)开发(四)

上面几篇文章介绍了Microsoft Dynamics CRM 2011中如何进行插件开发,本文将介绍插件的调试。

调试的基本步骤是

1. 注册、部署插件,这部分内容在上一篇Blog中已经介绍,不再赘述;

2. 将插件的pdb文件拷贝到CRM安装目录下的“Server\Bin\Assembly”文件夹下,一般而言,如果使用默认配置安装的CRM系统,那么此文件夹的全路径是“C:\Program Files\Microsoft Dynamics CRM Server\Server\bin\assembly”;

3. 配置调试器,即通过Visual Studio .net的附加到相应进程进行调试:

  • 对于运行于服务器上的插件,需要附加的进程是w3wp.exe进程;
  • 如果是调试脱机客户端中的插件,附加的进程是Microsoft.Crm.Application.Hoster.exe;
  • 如果是异步方式运行的插件,那么附加的进程是CrmAsyncService.exe
  • 如果是运行在沙盒Sandbox中的插件,那么附加的进程是Microsoft.Crm.Sandbox.WorkerProcess.exe

    4. 在插件类中,设置断点;

    5. 开始调试,进行界面操作,以触发插件的运行,以便可以在IDE中开始插件的调试工作。

以下是各个步骤的截屏

1. 插件注册,请参看文章《MS CRM 2011的自定义和开发(11)——插件(plugin)开发(三)》;

2. 拷贝pdb文件。首先打开插件项目的文件夹,导航到bin\debug目录下,找到插件程序集相关的pdb文件。如下图的红色方框区域所示

将该文件拷贝到CRM$\Server\Bin\Assembly目录下。

3. 配置调试器,本例中,使用Visual Studio .Net 2010进行调试。点击“调试”—> “附加到进程”,系统弹出“附加到进程”对话框,在其中列出了当前服务器上运行的进程,根据待调试插件的运行模式、部署模式,选择目标进程,而后点击“附加”按钮即可。如果在进程列表中没有目标进程,那么,点击“显示所有会话中的进程”复选框。

在附加w3wp.exe进程时,如果服务器的IIS中有多个站点同时处于活动状态,进程列表中就会出现多个w3wp.exe进程,这些进程之间的区别只是第二列ID列的信息不同,那么哪个进程是我们需要附加的进程呢?对于这种情况,可以通过IIS管理器来获得需要附加的进程。运行IIS管理器,在左侧导航栏中,点击第二个节点,而后再在右侧的内容区域点击“工作进程”,如下图所示。

内容区域会切换到工作进程列表界面,其中显示了当前IIS中所有处于运行状态的W3wp进程,其中第一列是w3wp.exe进程所对应的应用程序池名称,第二列信息就是进程ID。效果如下图所示,其中,蓝色区域圈定的就是进程ID信息,这将会有助于我们在“附加到进程”对话框中选择正确的进程予以附加:

4. 设置断点,这没有啥可以说的了,对于经常使用Visual Studio.Net的各位同学们已经是驾轻就熟;

5. 运行应用程序,或者使用界面操作的方式,或者使用C#开发的测试程序,总而言之,就是调用组织服务,发起某个请求,以触发插件的运行。本例中的插件是注册于account的pre-create事件上。所以呢,就是在crm中新建客户记录的时候会触发插件的运行。ok,通过浏览器操作,新建一条客户记录。记录内容如下图所示。

点击保存按钮,会向MS CRM的组织服务发送创建请求,从而触发插件的运行,此时,由于VS附件到进程已经开启,将可以对插件进行调试了。效果如下图所示:

如果Visual Studio没有被触发,或者插件类的断点没有起作用。首先,要看一下当前MS CRM是否允许进行debug,若否,可打开debug开关。打开Debug开关的步骤如下:

打开CRM$\CrmWeb目录,其中CRM$指的是微软CRM的安装目录,本例中是“C:\Program files\Microsoft Dynamcis CRM Server”;

找到web.config文件,使用任意编辑器打开该文件;

在web.config文件中找到,<compiliation defaultLanguage=”C#” debug=”…>这一句。默认情况下,debug开关的值是false,为了能够调试,需要将其设置为true,设置完成后,重新启动IIS;

设置debug开关项的示意图如下所示。

此外,除了使用调试器进行debug之外,还可以借助日志与跟踪服务,来确定插件的执行顺序,这样可以方便我们在不启用VS等调试工具的前提下,确定问题的根源所在。跟踪服务ITracingService,也是插件执行上下文中的一个组成部分,可以通过IServiceProvider.GetService()方法获得,样例代码例如:

ITracingService tracingService = (ITracingService)serviceProvider.GetService(typeof(ITracingService));

ITracingService实例化时候,可以利用trace方法,创建跟踪日志信息,例如

tracingService.Trace(“Plug-in execution begin”);

MSCRM Plugin Debug的更多相关文章

  1. Android 验证APK是否已经签名或是否是Debug签名

    https://source.android.google.cn/ http://www.android-doc.com/tools/publishing/app-signing.html Signi ...

  2. mac 下基于firebreath 开发多浏览器支持的浏览器插件

    mac 下基于firebreath 开发多浏览器支持的浏览器插件 首先要区分什么是浏览器扩展和浏览器插件;插件可以像本地程序一样做的更多 一. 关于 firebreath http://www.fir ...

  3. android-包签名

    android-包签名 应用能在Android 系统上安装必须是经过有私有key的证书数据签名.Android系统通过证书确定应用的作者,和与应用建立信任关系.证书不会用于控制应用的安装.证书不需要权 ...

  4. oracle linux 7.3 下用dtrace 跟踪 mysql-community-server-5.6.20

    第一部分:oracle linux 7.3 dtrace 安装: http://public-yum.oracle.com/   内核升极到 [root@server1 SPECS]# uname - ...

  5. bottle源码

    import sys __author__ = 'Marcel Hellkamp' __version__ = '0.13-dev' __license__ = 'MIT' ############# ...

  6. 深入MySQL复制(三):半同步复制

    1.半同步复制 半同步复制官方手册:https://dev.mysql.com/doc/refman/5.7/en/replication-semisync.html 默认情况下,MySQL的复制是异 ...

  7. centos7下mysql半同步复制原理安装测试详解

    原理简介: 在MySQL5.5之前,MySQL的复制其实都是异步复制(见下图),主库和从库的数据之间存在一定的延迟,这样存在一个隐患:当在主库上写入一个事务并提交成功,而从库尚未得到主库推送的BinL ...

  8. jmeter sampler maven项目排错记

    eclipse 创建的maven项目,引入jar包之后出现红色叹号,一直找不到原因,连main方法都无法运行,提示找不到类: 错误: 找不到或无法加载主类 soapsampler.SoapSample ...

  9. 【Centos7裁剪】

    #!/bin/sh rootdir=`pwd` rm -rf ${rootdir}/centos* KERNEL_DIR=${rootdir}/kernel ROOTFS_DIR=${rootdir} ...

随机推荐

  1. Core Data入门

    简介 Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还原成OC对象. ...

  2. Git工作常用

    工作时,最好每次都创建一个本地分支,这样就会减少错误修改远程代码的机会. 基于远程dev分支创建分支并切到本地分支: git checkout -b <local_dev> -t orig ...

  3. mark资料-selenium断言的分类

    操作(action).辅助(accessors)和断言(assertion): 操作action: 模拟用户与 Web 应用程序的交互. 辅助accessors: 这是辅助工具.用于检查应用程序的状态 ...

  4. MAVEN ERROR : Dynamic Web Module 3.0 requires Java 1.6 or newer

    问题: 在eclipse中,通过Maven->Update Project更新项目后,出现Dynamic Web Module 3.0 requires Java 1.6 or newer错误提 ...

  5. Java-->发牌流程修改版

    --> 这一次要封装得狠一点... package com.xm.ddz; // 每一张牌的属性 public class Card { private String flowerColor; ...

  6. 232. Implement Queue using Stacks

    Implement the following operations of a queue using stacks. push(x) -- Push element x to the back of ...

  7. ASP.NET Web API与Rest web api(一)

    本文档内容大部分来源于:http://www.cnblogs.com/madyina/p/3381256.html HTTP is not just for serving up web pages. ...

  8. hilbert矩阵 分类: 数学 2015-07-31 23:03 2人阅读 评论(0) 收藏

    希尔伯特矩阵 希尔伯特矩阵是一种数学变换矩阵 Hilbert matrix,矩阵的一种,其元素A(i,j)=1/(i+j-1),i,j分别为其行标和列标. 即: [1,1/2,1/3,--,1/n] ...

  9. js部分---类型,变量;

    <script type="text/javascript">1.注释:用“//或者/**/”2.数据类型: (1)整型 int (2)小数类型 单精度float 双精 ...

  10. JavaWeb学习记录总结(二十九)--Servlet\Session\Cookie\Filter实现自动登录和记住密码

    一.Servlet package autologin.servlet.login; import java.io.IOException;import java.security.MessageDi ...