【发布时间】:2013-10-17 01:32:34
【问题描述】:
自从我从 CF9 升级到 CF10 以来,我一直在与 cflocation 的一个错误作斗争。我已经做了很多次,但总是放弃,但今天终于让我很恼火,是时候解决问题了(我希望)。
首先,很抱歉,因为我试图编写一个简单的测试用例来重现这个问题,但到目前为止我无法在原始代码之外重现它。
我有一个应该在一夜之间运行的多步骤导入过程。该过程由大约 10 个链接在一起的文件组成。当通过计划任务调用进程时,还会传递一个 URL 参数(计划任务)。如果参数不存在,则在每一步结束时它会停止并等待用户单击指向下一步的链接。如果参数确实存在,它使用 cflocation 移动到下一步。
在所有步骤中,第二个步骤是最复杂和最耗时的(来自多个 Web 服务请求的数据,然后需要加入、清理和插入数据库)。移至 CF10 后,这第二步出现了问题。该页面似乎工作正常,因为它到达了 cflocation 标签所在的页面的最底部,但它从不触发 cflocation。我添加了一个 cfmail 标记,以便在调用 cflocation 时向我发送电子邮件,该标记始终会发送,但 cflocation 再次不会触发。
没有比这更基本的了:
<cfif scheduledtask EQ "true">
<cfmail from="xxxxx” to="xxxx” subject="About to call duplicate" type="text/html">
<p>calling duplicate check - scheduledtask</p>
</cfmail>
<cflocation url="importDupCheck.cfm?scheduledtask=true" addtoken="false">
</cfif>
我知道 cfflush 和 cflocation 有问题,我已经检查过了。
作为测试,我尝试将上述逻辑移到页面上,以便在 web 服务检索到所有数据之后但在处理数据之前,这次 cflocation 起作用了。我想这可能是一个超时问题,即使页面被允许完全加载,计划任务引擎也放弃了等待。我尝试通过一个基本文件来测试它:
<cfset sleep(240000)>
* 4 minutes
在调用 cflocation 之前,它运行良好。
该过程中的其他步骤与 cflocation 一样,但不是这个。所有这些代码在 CF9 下运行良好,只是在 CF10 下失败。
有人对我应该看的地方有一些指示吗?
问候 标记
* 更新 * 所以我现在想出了如何用几行代码轻松地重现它。原来它与计划任务无关。
index.cfm
<h1>Testing cflocation</h1>
<cfloop index="i" from="1" to="7000" ><!--- For me it stops working once the loop goes beyond 6808 rows --->
row <cfoutput>#i#</cfoutput>: abcdefghijklmnopqrstuvwxyz0123456789abcdefghijklmnopqrstuvwxyz0123456789abcdefghijklmnopqrstuvwxyz0123456789abcdefghijklmnopqrstuvwxyz0123456789<br/>
</cfloop>
<p>Now loading resultpage via cflocation</p>
<cflocation url="resultpage.cfm" addtoken="false">
结果页.cfm
<h1>Made it!</h1>
<p>Reload the <a href="index.cfm">first page</a></p>
在我的测试中,我发现如果我循环 6808 次它可以工作,但 6809 次失败。对于 7000 条记录,我们只讨论 36 KB 的文件……为什么这仅在 CF10 中失败?
我应该注意的最后一件事,以防它产生影响 - 我所做的一切都是通过 https 完成的。
【问题讨论】:
-
我很惊讶
cflocation在作为计划任务运行时能正常工作。基本上它所做的只是将重定向标头发送回浏览器以请求后续页面。用于计划任务的“浏览器”相当有限。我没有任何参考资料,但我认为在计划任务中使用cflocation是不行的。我通常将.cfm主页面用于我的计划任务,然后让它使用cfhttp标记调用其他页面(URL)。这也允许对可能正在处理的不同 URL 设置不同的超时/错误处理。我猜它以前是否有效?? -
嗨米格尔-F。我的假设是,计划任务的行为类似于 cfhttp,因为它像浏览器一样运行,因此它可以理解对 http 标头等的更改。除了它似乎以这种方式工作之外,没有什么可以支持这一点。无论如何,我已经更新了我原来的问题,因为它与计划任务无关。
标签: coldfusion cfml cflocation