Atlas应用程序调试技巧

本文为翻译文章,原文地址:http://atlas.asp.net/docs/Overview/debug.aspx

     “Atlas”程序由服务器端代码和客户端代码组成,并且,浏览器可能会要去异步请求一些数据。那么,怎样才能Debug这样的web程序呢。本文将告诉你如何使用一些技术和工具来方便的完成这件事。

注:
除了Visual Studio和Internet Explorer,本文提及的一此程序是一些第三方的,微软不会提供支持的。请到这些工具的主页去阅读授权和支持信息。

为了更好的Debug,先对应用程序进行配置

要启用VS的Debug功能,请添加一个<compilation>元素在站点根目录的web.config文件中,并且设置debug属性为true。请参阅,ASP.NET Settings Schema, compilation element

None.gif<configuration>
None.gif    
<system.web>
None.gif        
<compilation debug="true">
None.gif            
<!-- etc. -->
None.gif        
</compilation>
None.gif    
</system.web>
None.gif
<configuration>
None.gif

当Degub启用后,“Atlas”会使用一个Debug脚本类,这个类库将提供附加的对话信息和一个下面将讲解的Debug帮助类。

在服务器端进行Tracing

如果你通过启用“partial rendering”进行服务器端Tracing来Debug页面(即页面中包含一个启用了EnablePartialRendering的ScriptManager和一个Mode为Conditional的UpdatePanel),那么你可以使用Trace视图(Trace.axd)来显示页面输出根踪信息。此时,你可以在页面一开始呈现时就看到根踪输出信息显示在页面的尾部,但是这些信息不会在异步Postback后进行更新,这是因为仅仅只有UpdatePanel的内容需要在变化时被更新。关于使用Trace viewer的更多信息,请参看 ASP.NET Trace.

捕获HTTP交互

当开发web应用时,观察服务器与客户端来回往返的HTTP交互是很有用的,有两个工具可以帮助我们干这件事:

      Fiddler. 这个工具工作原理是做为一个Proxy记录下所有HTTP交互的日志。它支持IE和其它的浏览器。使用Fiddler,你可以检测每个请求和响应,包括headers,cookies,和HTTP消息主体内容。
      Web Development Helper. 这个工具只能用于IE,但是它除了在日志中记录HTTP交互,还能查看HTML DOM,在一个分隔开了的窗口中显示trace信息,关闭应用,还能解码页面的View state。

Debug Helper类

当你在启用了Debug后编译你的应用程序,“Atlas”客户端类库会定义一个Debugging helper类,并且实例化一个全局的debug对象供使用。使用这个debug对象,你能在页面的尾部用易读的方式显示对象的信息,能显示trace messages,能使用断言,中断。如果你使用VS调试器附加到IE进程中,你也可以在Output窗口中查看跟踪信息。
下面的代码将显示输出一个对象的信息:

ExpandedBlockStart.gifContractedBlock.gifvar o = dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif    colors: 
dot.gif{
InBlock.gif        red: [
25500],
InBlock.gif        green: [
02550],
InBlock.gif        blue: [
00255]
ExpandedSubBlockEnd.gif    }
,
InBlock.gif    width: 
600,
InBlock.gif    title: 'debugging 
with "Atlas"'
ExpandedBlockEnd.gif}
;
None.gif
None.gifdebug.trace(
"output trace messages");
None.gifdebug.dump(o, 'object name', 
true, 'dot.gif ');
None.gif

Output:

output trace messages
... object name {Object}
... +colors {Object}
... ++red {Array}
... +++[0]: 255
... +++[1]: 0
... +++[2]: 0
... +++0: 255
... +++1: 0
... +++2: 0
... ++green {Array}
... +++[0]: 0
... +++[1]: 255
... +++[2]: 0
... +++0: 0
... +++1: 255
... +++2: 0
... ++blue {Array}
... +++[0]: 0
... +++[1]: 0
... +++[2]: 255
... +++0: 0
... +++1: 0
... +++2: 255
... +width: 600
... +title: debugging with "Atlas"

debug类提供了以下这些方法供使用:
debug.assert(condition, message, displayCaller) 
        判断condition参数是不是为true.如果为false,这个方法将使用一个Message box显示message参数。如果        displayCaller参数为true,那么调用者的信息也将显示出来。
debug.clearTrace() 
    清空输出.
debug.dump(object, name, recursive, indentationPadding) 
    在页面最后用易读的方式显示一个对象的信息。name属性用于在显示时作为显示的标签(等于是作为显示一大段对象的信息前作一个标题的作用),如果recursive为true,那么这个对象中的对象的信息也会递归显示出来。indentationPadding用于填充在每一行信息的起始处,起一个缩进的作用。
debug.fail(message) 
    中断调试器 (仅Internet Explorer).
debug.trace(text) 
    将text输出到trace.

对Internet Explorer进行配置

Internet Explorer normally ignores any problems it encounters in JavaScript. To enable debugging, from the Tools menu, select Internet Options. 默认情况下,IE会忽略掉JavaScript错误。为了支持Debug,请打开IE的Tools菜单,选择Internet Options,在Advanced选项页,清除Disable Script Debugging(Internet Explorer)和Disable Script Debugging(Other)复选框的选择,并选中Display a nofication about every script error.结果如下图所示:

 

将Visual Studio调试器附加到Internet Explorer

要调试客户端代码,你必须把一个调试器附加到IE进程去。当你在VS中使用F5或Start Debugging命令启动调试一个应用程序时,调试器会被自动的附加到IE进程。
当然你也可以把VS的调试器附加到一个正在运行中的应用程序。你可以这样来做,在Debug菜单,选择Attach to Process...,在Attach to Process对象框中,选择你想要附加调试器的IE的运行实例。

注:
如果IE被合适的配置了Debug选项,在附加调试器到IE实例进程的对话框中的类型列中,你将会看到Script,x86选项,如果你只看到x86选项,那么请检查你的IE配置。

当为IE进行了合适的脚本调试配置后,如果IE遇到一个脚本错误,而此时没有附加进来一个调试器,这时就会显示一个对话框,询问你是否要选择一个调试器附加到当前IE进程进行调试。你可以选择不附加而继续运行程序,也可以附加一个调试器步进调试当前的脚本代码。

一些已知的IE调试的问题和解决方案

      当VS调试器被附加到IE后,你可以在VS的Script Exlorer窗口中看到一个被调试的脚本的列表,(在Debug菜单中选择Windows-->Script Explorer)。从Microsoft.Web.Atals.dll中动态生成的Atlas的脚本库会作为一个以WebResource.axd?...开头资源呈现.一个已知的VS的bug会阻止你一开始就去打开这个文件,如果你在尝试打开这个文件时,VS显示出一个错误信息或当你双击这个文件名去打开这个文件时根本就没有反应,你可以先打开一个别的JavaScript文件,再去打开它。
      在调试器步进到一个Asp.net页面的代码中前,VS不允许你在这个页面中的<script>元素中设置一个断点。解决办法之一是设一个断点在方法调用处,然后步进到这个页面的Code中来,最后调试器停在该页的脚本代码的一行中,这时,你就可以正常的设置断点了, 另外一种让调试器能识别页面中脚本的方法是在页面文件中的一个方法中调用debug.fail()方法。当你调用这个方法时,调试器就会停止在调用debug.fail()的地方,然后,你就可以在任何其它地方设置断点了。第三种方法是把你写的所有脚本放在一个外部的JavaScript文件中(.js文件)。
      VS允许你在一个传统的JavaScript函数的第一行设置一个断点,但在“Atlas”使用的匿名方法中不行。如果匿名方法只有一行代码,或你本来就想在第一行设断点,这时,你可以在这个方法的第一行前插入一行空代码,然后在第二行设断点。

Firefox

Firefox没有集成到VS的调试器中,所以你不能用VS调试器步进调试客户端代码。 不过,你可以使用 Venkman 调试器, 它是Firefox的一个插件,还有另一个很有用的工具叫 Web Developer Extension, 它能让你查看DOM和CSS 样式.
Fiddler也能工作于Firefox.但是,你必须配置Firefox对于你本机8888端口路由HTTP请求,更多信息,请查阅 Configuring Clients 

转载于:https://www.cnblogs.com/think/archive/2006/03/30/362756.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/436642.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【转】Azure Messaging-ServiceBus Messaging消息队列技术系列2-编程SDK入门

各位&#xff0c;上一篇基本概念和架构中&#xff0c;我们介绍了Window Azure ServiceBus的消息队列技术的概览。接下来&#xff0c;我们进入编程模式和详细功能介绍模式&#xff0c;一点一点把ServiceBus技术研究出来。 本章我们主要介绍ServiceBus的编程SDK编程入门。 首先…

linux octave源码安装,在Linux操作系统上安装Octave的方法

本文介绍在Ubuntu、Debian、Arch Linux、Fedora、OpenSUSE操作系统上安装Octave(也称GNU Octave)的方法&#xff0c;它还支持Flatpak方式安装。简介GNU Octave是一种用于科学和数学计算操作的解释性命令语言&#xff0c;它与Matlab兼容&#xff0c;支持各种扩展&#xff0c;允许…

linux安装静默安装was7,WAS7.0 - 安装并升级WAS7.0.0.31(静默安装)

WAS7.0 - 安装并升级WAS7.0.0.31(静默安装)安装之前需要准备的文件&#xff1a;C1G35ML.tar.gz&#xff1a;WAS7.0安装包C1G36ML.tar.gz&#xff1a;WAS升级工具7.0.0-WS-WASSDK-LinuxX64-FP0000031.pak 7.0.0-WS-WAS-LinuxX64-FP0000031.pak &#xff1a;7.0.0.31升级包&…

【转】Azure云存储及存储账户概述***

本文介绍下Azure云存储及存储账户。 1、什么是微软Azure云存储 微软Azure云存储是微软提供的云端数据存储服务&#xff0c;是一种可伸缩、持久化的数据存储服务&#xff0c;可以在Internet上被访问并按实际存储容量收费。它也可以被REST API访问&#xff0c;可以保存Azure云端…

插入法排序c语言程序,插入排序算法及C语言实现

插入排序算法是所有排序方法中最简单的一种算法&#xff0c;其主要的实现思想是将数据按照一定的顺序一个一个的插入到有序的表中&#xff0c;最终得到的序列就是已经排序好的数据。直接插入排序是插入排序算法中的一种&#xff0c;采用的方法是&#xff1a;在添加新的记录时&a…

【转】Microsoft Azure存储服务:存储账户****

在正式使用 Microsoft Azure 存储服务之前&#xff0c;你至少需要有一个 Azure 订阅并创建「存储账户」。Azure 订阅账户可以访问和使用各种 Azure 服务&#xff0c;在有了 Azure 订阅之后便可以开始创建「存储账户」并开始使用前面存储类型与访问中曾介绍过的 blobs、表&#…

【转】Azure Logic App Demo

使用Azure Logic App Azure Function 完成简单的业务流程 什么是Logic App Azure 逻辑应用提供了&#xff0c;用于在云中简化并实现可缩放的集成和工作流的方式。 它提供了可视化设计器&#xff0c;用于为流程建模并将流程作为一系列步骤&#xff08;称为工作流&#xff09;…

【转】Azure应用部署方式对比

如图 azure环境应用托管方式对比 1. app service serverless azure的app service支持几乎所有语言开发的web app&#xff0c;既可以手动使用publish profile部署&#xff0c;也可以使用vsts创建一个&#xff08;CDCI&#xff09;持续集成。都非常方便。 而azure的function app…

c语言哪个方法称为程序大门,学会这8个经典小程序,就相当于跨入了C语言大门...

描述【程序1】题目&#xff1a;有1、2、3、4个数字&#xff0c;能组成多少个互不相同且无重复数字的三位数&#xff1f;都是多少&#xff1f;1.程序分析&#xff1a;可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去掉不满足条件的排列。2.程序源代码&#x…

【转】无服务计算(Serverless Computing)核心知识

Serverless Computing概念 云原生计算基金会CNCF&#xff08;Cloud Native Computing Foundation, CNCF&#xff09;Serverless Whitepaper v1.0对无服务器计算作了如下定义&#xff1a; Serverless computing refers to the concept of building and running applications tha…

c语言中指数优化,西藏东财中证医药卫生指数C净值下跌1.96% 请保持关注

来源&#xff1a;金融界基金作者&#xff1a;机器君金融界基金08月07日讯 西藏东财中证医药卫生指数型发起式证券投资基金(简称&#xff1a;西藏东财中证医药卫生指数C&#xff0c;代码008552)公布最新净值&#xff0c;下跌1.96%。本基金单位净值为1.397元&#xff0c;累计净值…

PE文件结构详解(一)基本概念

&#xff08;一&#xff09;基本概念 PE&#xff08;Portable Execute&#xff09;文件是Windows下可执行文件的总称&#xff0c;常见的有DLL&#xff0c;EXE&#xff0c;OCX&#xff0c;SYS等&#xff0c;事实上&#xff0c;一个文件是否是PE文件与其扩展名无关&#xff0c;P…

【转】.NET平台开发Mongo基础知识

NoSQL简介 NoSQL相关的技术最近越来越受欢迎&#xff0c;Mongo本身就是基于NoSQL实现的。关于NoSQL你需要了解 什么是NoSQLNoSQL和传统的关系型数据库有什么区别NoSQL的优缺点 这几个问题下面的文章有所介绍&#xff1a; http://www.runoob.com/mongodb/nosql.html http://…

android studio如何编译测试,Android Studio 进行单元测试完整教程

前言为了这个AndroidStudio的单元测试&#xff0c;从下午搞到晚上才搞明白咋操作。我学一个新知识总是那么坎坷&#xff0c;经历无数的错误路径&#xff0c;才可能找到正确的路在哪儿。我的AndroidStudio我的AndroidStudio是1.5.1版本&#xff0c;但是进行单元测试应该很早的版…

android 对话框白色样式,Android 对话框(Dialog)样式大全以及简单实现

下面是几种对话框的效果图一&#xff1a;图二&#xff1a;图三&#xff1a;图四&#xff1a;图五&#xff1a;图六&#xff1a;图七&#xff1a;图1效果&#xff1a;该效果是当按返回按钮时弹出一个提示&#xff0c;来确保无误操作&#xff0c;采用常见的对话框样式。代码&…

【转】ABP源码分析二十一:Feature

Feature是什么&#xff1f;Feature就是对function分类的方法&#xff0c;其与function的关系就比如Role和User的关系一样。 ABP中Feature具有以下属性&#xff1a; 其中最重要的属性是name&#xff0c;用以表示feature的Identity,一个feature拥有一个name. 一个Feature可以有一…

android虚拟电话号码,为何安卓手机坚持虚拟按键?这才是原因

关于屏内虚拟按键设计的好坏&#xff0c;一直都存在很大的争议。围绕着屏内虚拟按键&#xff0c;支持者与反对者之间进行了长期的争论&#xff0c;至今仍未分出胜负。然而&#xff0c;当多功能前置指纹按键开始普及的时候&#xff0c;屏内虚拟按键似乎正在逐步走向边缘化。不过…

【转】ABP源码分析二十二:Navigation

MenuDefinition&#xff1a;封装了导航栏上的主菜单的属性。 MenuItemDefinition&#xff1a;封装了主菜单的子菜单的属性。子菜单可以引用其他子菜单构成一个菜单树 UserMenu/UserMenuItem&#xff1a;封装了用于显示给用户的菜单/以及子菜单集合。 ABP通过MenuDefinition/Me…

【转】ABP源码分析二十三:Authorization

Permission&#xff1a;用于定义一个Permission&#xff0c;一个permission可以包含多个子Permission. PermissionDictionary&#xff1a;继承自Dictionary<string, Permission>类&#xff0c;很明显是一个用于存储permission对象的字典。 IPermissionDefinitionContext…

VI/VIM键盘图

转载于:https://www.cnblogs.com/sdjc/archive/2006/09/14/1949532.html