如何对SharePoint里OOB的JavaScript文件进行Debug 之一
使用一篇文章的做法,开始了对SharePoint JavaScript的debugging,发现VS2010中打开的JavaScript都挤在一起,非常难以阅读和debug。
笔者记得14 hive\layouts文件夹下有debug版的JavaScript的。却不知道如何使用它们。
经过研究,发现MSDN上文章的对这个问题进行了描述,摘抄如下。
SharePoint Foundation also installs unminified, debug versions of the .js files in the same directory, for example, SP.debug.js, SP.Core.debug.js, SP.Ribbon.debug.js, and SP.Runtime.debug.js, and you can specify whether the debug versions are used. Default master pages in SharePoint Foundation insert a ScriptManager control in Web pages, and the ScriptMode property of this control is set to Auto by default.
You can override this default setting and use the debug .js files by adding <deployment retail="false" /> to the system.web section of the web.config file, which is located in the %inetpub%\wwwroot\wss\VirtualDirectories\80 directory.
注意MSDN描述retail值为true的影响如下:
When retail is set to true, ASP.NET disables certain configuration settings such as trace output, custom errors, and debug capabilities.
而且,默认值本来就是false。先不多想了,照着做先。
于是,笔者按照该文章的说法,直接修改web.config如下:
保存后,打开任意网页都报错。修改web.config, 关掉其CustomError选项, 得到具体错误信息如下:
错误信息:
It is an error to use a section registered as allowDefinition='MachineOnly' beyond machine.config.
再搜索,发现这篇文章对这个错误信息有如下的解释:
This message is displayed when a section definition specifies that it may only be provided in the Machine.Config file. The Identity section is not normally set this way, but it is possible for your ISP to change it in Machine.Config is they don't want users to be able to override the sections. Normally the admin should use a location tag with allow override=false to accomplish this, but the results are pretty much the same, the web.config may not contain the section in question. If you control the server you should check the configuration section definitions to see if the MachineOnly attribute is set on the section you are having problems. Removing the section that is causing the error will solve the problem, although you will not be able to change the attributes of that section.
这个选项看来是只在machine.config中提供的。目的是为了防止用户修改这个选项。
在路径C:\Windows\Microsoft.NET\Framework\v2.0.50727\CONFIG下寻找到machine.config, 发现有如下的条目:
<section name="deployment" type="System.Web.Configuration.DeploymentSection, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" allowDefinition="MachineOnly"/>
笔者直接删掉了allowDefinition="MachineOnly",问题依旧。继续研究,发现在对IIS7.0的配置体系介绍的文章中,对MachineOnly选项介绍如下:
MachineOnly The section can be set only in ApplicationHost.config or Machine.config. Because this is the default setting, a section that doesn’t have an allowDefinition attribute uses this setting automatically.
笔者尝试修改该选项为MachineToApplication,AppHostOnly均告失败。笔者还添加了allowoverride="true",还是不行。
还原web.config, 单独修改machine.config,结果debugger中加载的还是普通的js,而不是debug版的js文件。
咨询了IIS的专家,得到答复说这个选项是不能在web.config中定义的。而且我的测试也证明了实在是无法解决这项冲突。
IIS专家说,你要load debug版的javascript,其实只要<compilation batch="false" debug="true">里的debug设为true即可。
IIS专家的说法经过了笔者测试。
有图有真相
花费了一个下午的时间,结果证明Client Object Model Distribution and Deployment 这篇文章完全在胡说八道。
而我的debug任务才只开了个头。
坑爹呀~~
链接
=====================
如何对SharePoint里OOB的JavaScript文件进行Debug 之二
参考资料
=====================
Client Object Model Distribution and Deployment
http://msdn.microsoft.com/en-us/library/ie/ee539757.aspx
Scripting Debugging in Internet Explorer
http://blogs.msdn.com/b/ie/archive/2004/10/26/247912.aspx
deployment Element (ASP.NET Settings Schema)
http://msdn.microsoft.com/en-us/library/ms228298.aspx
Introducing IIS 7.0 Configuration Architecture
http://technet.microsoft.com/en-us/library/cc268239.aspx
ScriptManager.ScriptMode Property
http://msdn.microsoft.com/EN-US/library/system.web.ui.scriptmanager.scriptmode
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
2010-01-20 线程已被中止- “Thread was being aborted”
2010-01-20 .NET中线程同步相关的一些类