当前位置: 首页 > 编程日记 > 正文

SharePoint 2010 自定义日志

How to log to the SharePoint ULS Logs

(Clean Debugging and Error Logging broken down into steps)

By: Philip Stathis

原文地址 http://www.thesharepointblog.net/Lists/Posts/Post.aspx?ID=122

This article is meant to introduce a simple error logging routine that can really simplify your debugging when needed.

I am assuming for this post that you know that SharePoint has ULS logs and that there is a nice tool called ULSViewer (http://archive.msdn.microsoft.com/ULSViewer ) that you can use to examine errors.

So let’s get to it, step by step process of spitting statements to ULS.

You need to create a new class anywhere in your project, and it can be called ULSLog2010.cs .

I pasted the code that you need to place in the class below, this is not a piece I authored myself but I can vouch for the results and ease of use.

Here’s what you need to do:

1.       Create a new class called ULSLog2010.cs

2.       Paste code below code in

3.       Replace GWStandard.Logging with the namespace that your code is using to make it available where you need it

4.       Replace SharePointCustomSolution with the name of your desired product.

5.       Use the code to record debugging statements or errors like so:

ULSLog2010.LogDebug("I am a debugging string");

//Input Error ex from catch

catch (Exception ex)

   {ULSLog2010.LogError(ex);}

6.       Filter ULS log by Product = SharePointCustomSolution (or the custom name)

7.       Cake

using System;

using System.Collections.Generic;

using Microsoft.SharePoint;

using Microsoft.SharePoint.Administration;

namespace GWStandard.Logging

{

    /// <summary>

    /// Used for logging into Uls in 2010

    /// </summary>

    public class ULSLog2010 : SPDiagnosticsServiceBase

    {

        public const string PRODUCT_NAME = "SharePointCustomSolution";

        private static ULSLog2010 _Current;

       

        public static ULSLog2010 Current

        {

            get

            {

                if (_Current == null)

                {

                    _Current = new ULSLog2010();

                }

                return _Current;

            }

        }

        private ULSLog2010()

            : base(PRODUCT_NAME, SPFarm.Local)

        {

        }

        protected override IEnumerable<SPDiagnosticsArea> ProvideAreas()

        {

            List<SPDiagnosticsArea> areas = new List<SPDiagnosticsArea>       

            {           

                new SPDiagnosticsArea(PRODUCT_NAME, new List<SPDiagnosticsCategory>           

                {               

                    new SPDiagnosticsCategory("Error", TraceSeverity.High, EventSeverity.Error),

                    new SPDiagnosticsCategory("Warning", TraceSeverity.Medium, EventSeverity.Warning),

                    new SPDiagnosticsCategory("Logging", TraceSeverity.Verbose, EventSeverity.Verbose),

                    new SPDiagnosticsCategory("Debugging", TraceSeverity.Verbose, EventSeverity.Verbose)

                })       

            };

            return areas;

        }

        private string MapTraceSeverity(TraceSeverity traceSeverity)

        {

            switch (traceSeverity)

            {

                case TraceSeverity.High: return "Error";

                case TraceSeverity.Medium: return "Warning";

                default:

                case TraceSeverity.Verbose:

                    return "Debugging";

            }

        }

        public static void Log(TraceSeverity traceSeverity, Exception ex)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Error"];

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.Message);

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.ToString());

        }

        public static void Log(TraceSeverity traceSeverity, string message, Exception ex)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Error"];

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.Message);

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.ToString());

        }

        public static void LogError(Exception ex)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Error"];

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.Message);

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.ToString());

        }

        public static void LogError(Exception ex, string message)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Error"];

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.Message);

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, ex.ToString());

        }

        public static void LogError(string message, string stackTrace)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Error"];

            ULSLog2010.Current.WriteTrace(0, category, TraceSeverity.High, message);

        }

        public static void LogWarning(string message)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Warning"];

            ULSLog2010.Current.WriteTrace(1, category, TraceSeverity.Medium, message);

        }

        public static void LogMessage(string message)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Logging"];

            ULSLog2010.Current.WriteTrace(1, category, TraceSeverity.Verbose, message);

        }

        public static void LogDebug(string message)

        {

            SPDiagnosticsCategory category = ULSLog2010.Current.Areas[PRODUCT_NAME].Categories["Debugging"];

            ULSLog2010.Current.WriteTrace(1, category, TraceSeverity.Verbose, message);

        }

    }

}

By: Philip Stathis

转载于:https://www.cnblogs.com/ahghy/archive/2013/01/24/2874883.html

相关文章:

使用Bot Service创建Bot Framework

创建Bot Service&#xff1a;进入至Azure控制台中&#xff0c;新建Bot Service&#xff0c;如不知道Bot Service在哪个选项中&#xff0c;可以先查找Bot Service再创建 在弹出的查询结果中&#xff0c;选择Bot Service&#xff0c;点击后会进入至下一个步骤 在弹出的Bot Servic…

[转]大三下,我们该做什么?一篇被转万次的日志,你值得一看

大三下&#xff0c;我们该做什么&#xff1f;一篇被转万次的日志&#xff0c;你值得一看 还有几个月&#xff0c;你就不得不参加考研、就业大军了&#xff0c;你做好准备了么&#xff1f;你知道211学校、985学校和非211、985的主要区别么&#xff1f;找工作机会一定是不均等的。…

如何在DataGrid里面产生滚动条而不滚动题头

作者Blog&#xff1a;http://blog.csdn.net/cuike519/ 我们在开发的时候一定遇到&#xff0c;使用DataGrid的时候由于不想分页&#xff08;数据没有那么多&#xff09;但是又显示不在一页里面&#xff0c;此时我们希望在DataGrid里面出现一个滚动条&#xff0c;可以上下滚动Dat…

“小霸王学习机”再现?树莓派400正式发布,售价70美元

整理 | 高卫华出品 | AI科技大本营头图 | CSDN 下载自视觉中国11月2日&#xff0c;树莓派 4 的制造商正式推出了树莓派 400&#xff0c;这是一款集成了 4GB 内存树莓派 4 的紧凑型键盘。有了树莓派 400&#xff0c;只需使用其两个微型HDMI端口之一&#xff0c;将其插入电视或显…

display的block、none、inline属性及解释

常会用到display对应值有block、none、inline这三个值 参数&#xff1a; block :块对象的默认值。用该值为对象之后添加新行。之前也添加一行。 none :隐藏对象。与visibility属性的hidden值不同&#xff0c;其不为被隐藏的对象保留其物理空间 inline :内联对象的默认值。用该值…

datagrid分页问题(前后跳页)《控件版》

在ASCX中写的。 在CSDN上看了很多的DATAGRID分页问题&#xff0c;当然DATAGRID有自己的分页项&#xff0c;功能是很有限的&#xff0c;我也在CSDN上看了很多自己分页的代码&#xff0c;发现都是用C#写的&#xff0c;我写了一个用ASP。NET中VB语言写的。以下代码供大家参考。 HT…

F5第一个10000台

F5中国第一个累积销售10000台&#xff0c;花了整整9年时间。下一个累积销售10000台需要多少时间&#xff0c;5年&#xff0c;3年&#xff0c;甚至更短的时间&#xff1f;让我们拭目以待。转载于:https://blog.51cto.com/f5555/1126095

java内存溢出的情况解决方法

内存溢出虽然很棘手&#xff0c;但也有相应的解决办法&#xff0c;可以按照从易到难&#xff0c;一步步的解决。  第一步&#xff0c;就是修改JVM启动参数&#xff0c;直接增加内存。这一点看上去似乎很简单&#xff0c;但很容易被忽略。JVM默认可以使用的内存为64M&#xff…

DataGrid基于Access的快速分页法

DataGrid基于Access的快速分页法撰文/ 黎波DataGrid是一个功能非常强大的ASP.NET Web服务器端控件&#xff0c;它除了能够方便地按各种方式格式化显示表格中的数据&#xff0c;还可以对表格中的数据进行动态的排序、编辑和分页。使Web开发人员从繁琐的代码中解放。实现DataGrid…

urlrewrite使用小结

urlrewrite顾名思义&#xff0c;就是对URL进行重写&#xff0c;用户得到的全部都是经过处理后的URL地址&#xff0c;这样做我觉得好处有三&#xff1a;一&#xff1a;提高安全性&#xff0c;可以有效的避免一些参数名、ID等完全暴露在用户面前&#xff0c;如果用户随便乱输的话…

性能超越图神经网络,将标签传递和简单模型结合实现SOTA

译者 | 刘畅出品 | AI科技大本营头图 | CSDN付费下载自视觉中国图神经网络&#xff08;GNNs&#xff09;是图学习中一种主流的技术。然而&#xff0c;对于GNN为什么在实际使用中很成功以及它们是否是优异性能所必需的技术&#xff0c;了解相对较少。本文展示了许多标准的传导节…

模仿VIMD的模式的简化代码示例

按numpad0来切换模式&#xff0c;按t显示不同的结果&#xff1b; Numpad0:: tfmode:!tfmode aaa:(tfmode1?"AAAA":"BBBB") SplashImage Off SplashImage, "",X500 Y500 W200 B fs10 CT00FFFF CW000000,%aaa%, , 切换模式提示 WinSet, Tr…

DataGrid连接Access的快速分页法(1)——需求与现状

作者&#xff1a;黎波一、需求分析 DataGrid是一个功能强大的ASP.NET Web服务器端控件&#xff0c;它除了能够按各种方式格式化显示数据&#xff0c;还可以对数据进行动态的排序、编辑和分页。大大减轻了广大Web程序员的工作量。实现DataGrid的分页功能一直是很多入门者感到棘手…

CSDN公众号新功能上线,居然还能搜出小姐姐???

为了给各位打工人更好的搜索体验CSDN总是在学习新技能这次CSDN公众号又给大家带来了一项全新的搜索技能在CSDN旗下的公众号内回复消息就能自动回复想搜索的内容啦小编来给大家演示一下&#xff0c;在公众号内输入“mysql安装教程”&#xff0c;就能得到CSDN全站内关于mysql安装…

p2v、v2v 转换-windows篇

问题&#xff1a;如何把 xenserver的虚拟机转成Esxi的虚拟机 如何把物理机转成Esxi的虚拟机答案&#xff1a;↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓首先介绍一下实验环境。一台xenserver主机上两台虚拟机 win03和win08 转到Esxi5.0的一台主机上。Esxi5.0在某个…

WebViewJavascriptBridge原理解析

基本说明 我们的项目是一个OC与javascript重度交互的app&#xff0c;OC与javascript交互的那部分是在WebViewJavascriptBridge的github地址的基础上修改的&#xff0c;WebViewJavascriptBridge应该是当前最流行最成功的OC与Web交互实现了。最近看了一下他的实现原理&#xff0c…

DataGrid连接Access的快速分页法(2)——SQL语句的选用(升序与降序)

作者&#xff1a;黎波 一、相关概念 在 ACCESS 数据库中&#xff0c;一个表的主键&#xff08;PRIMARY KEY&#xff0c;又称主索引&#xff09;上必然建立了唯一索引&#xff08;UNIQUE INDEX&#xff09;&#xff0c;因此主键字段的值是不会重复的。并且索引页依据索引列的值…

从谷歌AutoML到百度EasyDL,AI大生产时代,调参师不再是刚需

出品 | AI科技大本营头图 | 付费下载于视觉中国2018 年&#xff0c;Google Cloud 宣布将 AutoML 作为机器学习产品的一部分。至此&#xff0c;AutoML 开始进入大众的视野。 实际上&#xff0c;2013 年AutoWEKA的发布可以算作AutoML的开端&#xff1b;2014 年&#xff0c;ICML开…

Python 语法小知识

为什么80%的码农都做不了架构师&#xff1f;>>> 序列解包 将含有多个值的序列解开&#xff0c;然后把值存放到变量中&#xff0c;当函数或者方法返回元组时这个特性很有用&#xff0c;可以把返回的序列值直接赋值给变量&#xff0c;在序列解包时等号两边的元素个数…

CSS布局之-水平垂直居中

对一个元素水平垂直居中&#xff0c;在我们的工作中是会经常遇到的&#xff0c;也是CSS布局中很重要的一部分&#xff0c;本文就来讲讲CSS水平垂直居中的一些方法。另外&#xff0c;文中的css都是用less书写的&#xff0c;如果看不懂less&#xff0c;可以把我给的demo链接打开&…

DataGrid连接Access的快速分页法——动态生成SQL语句

作者&#xff1a;黎波using System;using System.Text;namespace Paging{/// <summary>/// FastPaging 的摘要说明。/// </summary>public class FastPaging {private FastPaging() {}/// <summary>/// 获取根据指定字段排序并分页查询的 SELECT 语句。/// &…

一文读懂机器学习“数据中毒”

作者 | Ben Dickson翻译 | 火火酱~出品 | AI科技大本营头图 | 付费下载于视觉中国在人类的眼中&#xff0c;下面的三张图片分别展示了三样不同的东西&#xff1a;一只鸟、一只狗和一匹马。但对于机器学习算法来说&#xff0c;这三者或许表示同样的东西:一个有黑边的白色小方框。…

chartee

2019独角兽企业重金招聘Python工程师标准>>> 一个绘制图表的类库&#xff0c;支持绘制股票的K线图&#xff0c;还可以绘制曲线、柱状图等等。 Code4App编译测试&#xff0c;测试环境&#xff1a;Xcode 4.3, iOS 5.0。 转载:http://www.adobex.com/ios/source/detail…

C语言存储类关键字

1、static这个关键字有三种用法&#xff1a;&#xff08;1&#xff09;第一种是用来修饰局部变量&#xff0c;使之成为静态局部变量&#xff1b;静态局部变量存储在数据段/bss段中&#xff0c;作用域是代码块作用域&#xff0c;生命周期是程序生命周期&#xff0c;链接属性是无…

显示DataGrid序号的一个适用的方法

作者Blog&#xff1a;http://blog.csdn.net/wangj2001/如果数据量小的话没有问题&#xff0c;一旦数据量大&#xff0c;显示特别慢&#xff0c;还有个缺点就是拖动行高时行号不随行高的变化而变动&#xff0c;出现是几个序号在一个单元格中显示。我自己对他们的算法进行总结&am…

Integer的自动缓存

2019独角兽企业重金招聘Python工程师标准>>> Interger装箱有个自动缓存的概念 Integer a 100;Integer b 100;Integer c 200;Integer d 200;System.out.println(a b); //trueSystem.out.println(c d); //false Integer是对象&#xff0c;比较的是对象在内存中…

崩溃!双十一第 4 天,某互联网公司黄了?

01打折这么狠是不是要黄了&#xff1f;&#xff1f;今年的双十一&#xff0c;开始地比以往早一些&#xff01;不知道各位程序员小哥哥们的战绩如何&#xff0c;是不是已经被一轮又一轮的定金、尾款&#xff0c;折腾到数学细胞耗尽&#xff1f;付款了也不清楚自己有没有真正的「…

FreeBSD设备驱动管理介绍(BSP: Ti AM335x)

这段时间一直在忙FreeBSD驱动移植的项目&#xff0c;因此对FreeBSD做了一定的了解&#xff0c;鉴于网上对于FreeBSD的设备驱动资料较少&#xff0c;在这里给出本人对于FreeBSD驱动管理的理解心得&#xff08;主要是USB驱动管理&#xff09;&#xff0c;希望能对开源开发者有所帮…

视障人士体验自动驾驶:携导盲犬登车,未来有望“自己开”

6月27日&#xff0c;滴滴出行首次面向公众开放自动驾驶服务。用户可通过滴滴APP线上报名&#xff0c;审核通过后&#xff0c;将能在上海自动驾驶测试路段&#xff0c;免费呼叫自动驾驶车辆进行试乘体验。现阶段&#xff0c;滴滴自动驾驶载人测试范围仅限于在上海开放测试道路上…