java 怎样捕获异常后,程序不中止,继续执行,返回参数

java 怎样捕获异常后,程序不中止,继续执行,返回参数,第1张

你把 temp定义到try之外。然后在遇到异常后,给temp赋值,不要在catch中写什么return就行。

例如:

……………………

Document objDOM = DocumentHelper.createDocument()

String temp =""

try{

……

}catch (DocumentException e)

{

temp = "error"

}

Node node = objDOM.selectSingleNode("//"+temp)

……………………

通过FiddlerScript实现根据条件重发请求

Fiddler是个强大的Web调试工具,具体的功能不在此多述,可以参考后面的链接以及Fiddler官网的手册。本文主要介绍Fiddler的重发请求功能,并通过自定义脚本实现根据条件来重发请求。 在进行Web调试时,经常会遇到浏览器请求正常但是程序请求异常的情况,这时我们常常需要使用Fiddler对比这两个请求的异同,然后将一个请求改变参数或HTTP头进行重发来查看返回结果的差异,这样可以确定哪个参数或哪个HTTP头导致的问题。如下图重发可以有多种不同的选择,常用的有三个:

Reissue Requests: 直接重发选定请求

Reissue and Edit: 重发选定请求,并在请求之前断点,可以对请求进行修改

Reissue from Composer: 将选定请求送到Composer窗口,和将请求拖拽到Composer效果是一样的,在Composer窗口中可以对请求有更精确的控制

请点击输入图片描述

只简单的重发指定请求,或在指定请求上进行编辑往往是不够的,在项目中我们偶尔会遇到这样的情形:先发送请求A,然后根据请求A结果中的某个值来发送请求B,譬如有这样的两个接口:get_random_server.php接口通过接收的数据随机返回一个服务器ID,get_data.php接口则根据刚刚的服务器ID来获取数据。下面是一个示例:

localhost/get_random_server.php?data=Hello ->返回JSON结果:{ success: true, sid: 2 }

localhost/get_data.php?sid=2

这个时候Fiddler的可扩展性就能大显神威了,可以通过两种方式实现Fiddler的扩展:FiddlerScript和插件机制,这里使用FiddlerScript就足够应付了。在Fiddler的菜单项Rules中选择Customize Rules...就可以打开Fiddler的自定义脚本文件CustomRules.js,该脚本一般保存在\Documents\Fiddler2\Scripts目录下。我推荐使用Fidder ScriptEditor进行脚本的编辑,Fidder ScriptEditor具有语法高亮和语法检查的功能,并在右侧面板提供了Fiddler内置的函数列表。 通过展开浏览右侧的函数列表,就基本上可以大概的了解到几个可能会用到的函数了:

FiddlerApplication.oProxy.SendRequest

FiddlerApplication.oProxy.SendRequestAndWait

FiddlerObject.utilIssueRequest

我们先通过下面的代码来练练手,将下面的代码拷贝到CustomRules.js中并保存,Fidder ScriptEditor会自动检查语法错误,并重新加载脚本,无需重启Fiddler脚本即可生效。CustomRules.js使用的是JScript.Net语法,对于Javascipt或.C#程序员应该可以很快上手。这时在Fiddler中随便选择一条请求,点击右键,会发现最上面多了一个选择项Test Send Request,选择该项可以达到和Reissue Requests同样的功能,重发指定请求。

12345678910111213   public static ContextAction("Test Send Request")function SendRequest(oSessions: Session[]) {         if (oSessions.Length == 0) return    FiddlerApplication.Log.LogString("Sending...")         var selected: Session = oSessions[0]         var oSD = new System.Collections.Specialized.StringDictionary()    var res = FiddlerApplication.oProxy.SendRequestAndWait(selected.oRequest.headers, selected.RequestBody, oSD, null)    FiddlerApplication.Log.LogString("Request has been Send.")    FiddlerApplication.Log.LogString(res.GetResponseBodyAsString())}   

SendRequest/SendRequestAndWait函数有一个不方便之处,他的两个参数oHeaders和arrRequestBodyBytes分别是HTTPRequestHeaders和Byte[]类型,为了调用这个方法必须将HTTP的header和body转换为这两个类型,不如字符串来的简便。这个时候utilIssueRequest函数正好满足我们的定制需要,可以精确的控制一个请求的细节,类似于Composer中的Raw。下面的代码是一个使用utilIssueRequest函数的实例,具体的HTTP请求以字符串的形式拼接起来。

1234567891011121314151617181920212223242526272829303132   public static ContextAction("Probe this!")function ProbeSession(oSessions: Session[]) {         if (oSessions.Length == 0) return    FiddlerApplication.Log.LogString("Probing...")         var selected: Session = oSessions[0]    var raw = ""         // methods    var method:String = selected.RequestMethod    var url:String = selected.fullUrl    var protocol = "HTTP/1.1"    FiddlerApplication.Log.LogString(method + " " + url + " " + protocol)    raw += method + " " + url + " " + protocol + "\r\n"         // headers    for (var i:int = 0i <selected.oRequest.headers.Count()i++) {        var header = selected.oRequest.headers[i]        FiddlerApplication.Log.LogString(header)        raw += header + "\r\n"    }         // body    FiddlerApplication.Log.LogString("---")    var body = selected.GetRequestBodyAsString()    FiddlerApplication.Log.LogString(body)    raw += "\r\n" + body         FiddlerObject.utilIssueRequest(raw)    FiddlerApplication.Log.LogString("Request has been Send.")}   

HTTP请求的格式如下:

1234567891011   POST http://localhost/get_random_server.php HTTP/1.1Host: localhostConnection: keep-aliveAccept: text/html,application/xhtml+xml,application/xmlq=0.9,image/webp,*/*q=0.8User-Agent: Mozilla/5.0 (Windows NT 6.1WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.122 Safari/537.36Accept-Encoding: gzip,deflate,sdchAccept-Language: zh-CN,zhq=0.8,en-USq=0.6,enq=0.4Content-Type: application/x-www-form-urlencodedContent-Length: 23 data=%E4%BD%A0%E5%A5%BD   

后面的工作就水到渠成了,通过SendRequestAndWait获取请求A的结果,解析请求A结果获取sid参数,然后拼接HTTP请求调用utilIssueRequest函数,此处从略。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8114922.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-13
下一篇 2023-04-13

发表评论

登录后才能评论

评论列表(0条)

保存