设置:
有问题的程序试图通过 AJAX 调用将表单数据发布到包含在与调用者相同的包中的目标过程。这是为使用安全连接 (HTTPS) 的站点完成的。这里使用的技术是PLSQL和 DOJO JavaScript 库。开发工具为basically a text editor .
代码片段:
> function testPost() {
>> dojo.xhrPost( {
url: ''dr_tm_w_0120.test_post'',
form: ''orgForm'',
load: testPostXHRCallback,
error: testPostXHRError
});
}
> function testPostXHRCallback(data,ioArgs) {
>> alert(''post callback'');
try{
dojo.byId("messageDiv").innerHTML = data;
}
catch(ex){
if(ex.name == "TypeError")
{
alert("A type error occurred.");
}
}
return data;
}
>
function testPostXHRError(data, ioArgs) {
>> alert(data);
alert(''Error when retrieving data from the server!'');
return data;
}
问题:
使用 IE6(整个用户群都在使用)时,从服务器发回的响应是 404 错误。
观察:
该程序在 Firefox 中运行良好。
调用过程不能以同一包内的任何过程为目标。
调用程序可以针对外部站点(http、https)。
包中不是表单数据发布的其他 AJAX 调用工作正常。
我搜索了互联网并咨询了资深团队成员,但没有发现任何令人满意的解决问题的方法。
*试过Q&A在 Dojo 支持论坛上。
问题:
您推荐哪些故障排除技术?
对于 HTTPS 分析,您推荐哪些故障排除工具?
关于问题可能是什么的任何假设?
对于不是完全(坏)黑客的变通办法有什么想法吗?
埃德。解决方案
lomaxx,感谢 fiddler提示。您不知道获得它并将其用作调试工具有多棒。启动后,这是我发现的以及我如何修复它(至少在短期内):
> ef Fri, 8 Aug 2008 14:01:26 GMT dr_tm_w_0120.test_post: SIGNATURE (parameter names) MISMATCH VARIABLES IN FORM NOT IN PROCEDURE: SO1_DISPLAYED_,PO1_DISPLAYED_,RWA2_DISPLAYED_,DD1_DISPLAYED_ NON-DEFAULT VARIABLES IN PROCEDURE NOT IN FORM: 0
在看到来自服务器的消息后,我更多地使用了 Fiddler,看看我还能从中学到什么。发现有一个 WebForms 选项卡显示 Web 表单中的值。你不知道吗,上面的“xxx_DISPLAYED_
”字段就在其中。
我还不太明白为什么会存在这些字段,因为我没有在网络 PLSQL
代码中明确创建它们。但我现在明白目标程序必须将它们作为参数包含在内才能正常工作。同样,这仅适用于我的 IE6
,因为 Firefox 运行良好。
好吧,这是短期的答案并通过破解来修复它。希望在这个领域做更多的工作可以更好地理解这里发生的基本原理。
最佳答案
第一个停靠点是启动 Fiddler并分析进出浏览器的数据。
查看 header 、实际调用的 url 以及传递给 AJAX 方法的参数(如果有),并在到达服务器之前查看一切是否正常。
如果一切正常,您是否可以通过日志记录或 AJAX 方法跟踪来验证它是否确实在访问服务器?
ed:我会尝试的另一件事是搭建一个测试页面,使用基于非 ajax 的调用在服务器上调用 AJAX 方法,并分析 fiddler 中的流量并比较两者。
关于ajax - 调试:IE6 + SSL + AJAX + post form = 404错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5619/