在开发Sharepoint Solution时,我们可以使用Attach to process来Debug我们的方案,然而一旦我们把Solution部署到了生产机上,我们就难以再使用这个最直接的方法了,如果Solution出错,我们就需要足够的手段来获取尽量明细的错误信息,USL log(Unified Logging Service)则为我们提供了一条途径来帮助我们定位用户的跟踪信息。在早期的Sharepoint2007中,虽然也有ULS随着一起发布,但我们却不能使用它,这在SharePoint2007的SDK 中明确说明了这点,它仅限于内部使用。到了SharePoint 2010则改变了这一切,我们现在也可以在我们的代码中使用它来写入我们需要捕获的跟踪信息了。
   请新建一个Sharepoint项目,在项目中创建一个Visual Web Part,如下

在按钮的Click后台代码中写入(需要引入 Microsoft.SharePoint.Administration)

protected void btnLogin_Click(object sender, EventArgs e)
        {
            try { var i = 0; var a = 2 / i; }
            catch (Exception ex) { LoggingService.LogError("WebParts", ex.Message); }
        }

Built 此项目并部署到测试网站,然后运行WebPart上的Button的Click事件,就会有错误信息写到ULS log中 (请在目录

\Program files\Common Files\Microsoft Shared\Web Server Extensions\14\Logs 下去找相关Log, 默认情况下,跟踪log名由计算机名加上日期和时间信息组成,文件类型为“文本文档”。),通常你可以使用SharePoint ULS Log Viewer打开对应的Log文件可以看到错误事件记录如下(你也可以用微软提供的ULSViewer来查看,它的用法会有一些不同):

你会注意到,在打开的Log文件中,对应的按钮事件的报错记录的Area区域值为Unkown,如果我们有多个Solution部署到服务器上,这会让我们很难识别到底是哪个Solution注册的错误,因此我们需要进一步改进我们的作法,所以,请在原项目中新创建一个类,此类继承自SPDiagnosticsServiceBase基类,如下图

此类的定义代码如下

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint.Administration; //需要引入

namespace CopyListContent
{
    public class LoggingService : SPDiagnosticsServiceBase
    {
        public static string MyDiagnosticAreaName = "MyDiagnosticTest";
        private static LoggingService _Current;
        public static LoggingService Current
        {
            get
            {
                if (_Current == null)
                { _Current = new LoggingService(); }
                return _Current;
            }
        }

private LoggingService()
            : base("MyDiagnosticTest Logging Service", SPFarm.Local)
        { }

protected override IEnumerable<SPDiagnosticsArea> ProvideAreas()
        {
            List<SPDiagnosticsArea> areas = new List<SPDiagnosticsArea>  {            
                new SPDiagnosticsArea(MyDiagnosticAreaName, new List<SPDiagnosticsCategory>
                {new SPDiagnosticsCategory("WebParts", TraceSeverity.Unexpected, EventSeverity.Error) })};
            return areas;
        }

public static void LogError(string categoryName, string errorMessage)
        {
            SPDiagnosticsCategory category = LoggingService.Current.Areas[MyDiagnosticAreaName].Categories[categoryName];
            LoggingService.Current.WriteTrace(0, category, TraceSeverity.Unexpected, errorMessage);
        }
    }

}

在此类中,我们在Area区域写入了我们当前Solution的标识名"MyDiagnosticTest",重新修改按钮事件的定义,引用我们上面定义的类来写入ULS log

protected void btnLogin_Click(object sender, EventArgs e)
        {
            try { var i = 0; var a = 2 / i; }
            catch (Exception ex)
            { SPDiagnosticsService.Local.WriteTrace(0,
                new SPDiagnosticsCategory("My Category", TraceSeverity.Unexpected, EventSeverity.Error),
                TraceSeverity.Unexpected, ex.Message, ex.StackTrace);
            }
        }

重新Built Solution并部署运行,回到ULS log中用SharePoint ULS Log Viewer查看,可以看到如下

我们可以通过识别Area字段来更加容易的找到属于我们的Solution写入的报错信息了。当然你还可以灵活的组织你需要写入的内容从而方便你更加容易地定位Solution的用户跟踪信息。

转载于:https://www.cnblogs.com/Little-Li/archive/2011/11/17/2252813.html

Sharepoint学习笔记---Debug--使用ULS Log跟踪Solution错误信息相关推荐

  1. Android学习笔记07---查看Android虚拟机输出的错误信息与如何部署应用到自己的真实手机

    Android学习笔记07---查看Android虚拟机输出的错误信息

  2. Sharepoint学习笔记---如何在Sharepoint2010网站中整合Crystal Report水晶报表(显示数据 二)...

    在Sharepoint学习笔记---如何在Sharepoint2010网站中整合Crystal Report水晶报表(显示数据一)中,解释了如何把Crystal Report整合到Sharepoint ...

  3. Sharepoint学习笔记—ECMAScript对象模型系列-- 7、获取和修改List的Lookup字段

    在前面我们提到了如何使用ECMAscript对象模型来操作普通的List Items,但如果我们操作的List包含有Lookup字段,那么我们又该怎么做呢? 首先参考此文搭建我们本文的测试环境 Sha ...

  4. Sharepoint学习笔记---Linq to Sharepoint--查询语法

    Linq to sharepoint的引入的确给我们操作Sharepoint带来了便利,首先就体现在对Sharepoint 的查询优势上.它基本可以照搬Linq to SQL的查询语法,这就大大保护了 ...

  5. Sharepoint学习笔记---Sandbox Solution-- Full Trust Proxy--开发实例之(2、在Webpart中访问Full Trust Proxy)...

    上一篇Sharepoint学习笔记---Sandbox Solution-- Full Trust Proxy--开发实例之(1.创建一个能访问DataBase的Full Trust Proxy), ...

  6. Sharepoint学习笔记—Site Definition系列-- 2、创建Content Type

    Sharepoint本身就是一个丰富的大容器,里面存储的所有信息我们可以称其为"内容(Content)",为了便于管理这些Conent,按照人类的正常逻辑就必然想到的是对此进行&q ...

  7. Sharepoint学习笔记—架构系列

     为便于查阅,这里整理并列出了我的Sharepoint学习笔记中涉及架构方面的有关文章,有些内容可能会在以后更新. Sharepoin学习笔记-架构系列--  Sharepoint的网页(Page), ...

  8. Sharepoint学习笔记—Ribbon系列

     为便于查阅,这里整理并列出了我的Sharepoint学习笔记中涉及Ribbon开发的关文章,有些内容可能会在以后更新. Sharepoint学习笔记-Ribbon系列-- 1. Ribbon的架构 ...

  9. Sharepoint学习笔记—Ribbon系列-- 2. 在Ribbon中添加新Tab

    有了上面的基础,我们来看看如何向Sharepoint网站的Ribbon中添加我们定义的Tab. 直接进入操作步骤 一.创建 SharePoint 项目 要添加新选项卡,应首先创建一个空白 ShareP ...

最新文章

  1. 逻辑回归损失函数(cost function)
  2. JavaScript总结01
  3. 190. Reverse Bits
  4. Hive的数据模型-外部表
  5. 【Filebeat】windows下安装filebeat
  6. Linux虚拟机-配置文件说明
  7. kibana服务器性能要求,Kibana停止工作,尽管kibana.service正常启动,但服务器未准备就绪...
  8. mysql多线程访问总结
  9. JAVA 经纬度转换成直角坐标系,以及直角坐标系转换成经纬度算法
  10. MATLAB打不开,选择licenses激活成功后还是要激活
  11. IIS、Asp.net 编译时的临时文件路径
  12. 未成年人勿进 谨以献给1980~1990出生的人(四)
  13. 解决 M1 MAC安装软件提示来自身份不明开发者
  14. 南京大学交叉培养计算机与金融招生人数,教务处组织召开计算机与金融工程实验班师生见面会...
  15. 微信更新,重点关注!
  16. java 一元线性回归_线性回归 - Java教程 - 找一找教程网
  17. 蜂蜜橙文案:水果蜂蜜橙的文案图片,水果蜂蜜橙朋友圈卖货文案
  18. 生肖迷宫之如何辨别福娃衰娃
  19. Access denied for user ‘‘@‘localhost‘ to database ‘mysql‘
  20. QQ抢车位的Bug:瞬间拥有顶级世界名车!(原创) (原创)

热门文章

  1. keepalive+lvs负载均衡及高可用总结
  2. 用VB如读取内存地址
  3. RabbitMQ的死信队列的应用
  4. 8个数据清洗Python代码,复制可用,最长11行 | 资源
  5. 中关村十大AI研究院 | 盘点
  6. 专栏 | 是什么成就了中国最具创新力的公司,帮他们的超脑计划孵出阿尔法蛋?...
  7. 百度黑莓宣布联手搞自动驾驶,QNX系统成Apollo平台基础
  8. eq相等 ne、neq不相等 EL表达式
  9. 为何System Idle Process 进程占用了大量有CPU资源
  10. ORA-12504:TNS:监听程序在CONNECT_DATA中未获得SERVICE_NAME