gpt4 book ai didi

coldfusion - URL 中的句点导致 ColdFusion 错误

转载 作者:行者123 更新时间:2023-12-04 12:04:08 25 4
gpt4 key购买 nike

我目前遇到用户(或机器人,不确定)访问在子目录中包含三个句点的不存在链接的问题。

例如,如果有人去:
http://www.example.com/.../test/index.cfm?
然后我收到以下错误:

String index out of range: -1 null
The error occurred on line -1.

我只用 1 个周期和 2 个周期对其进行了测试,结果直接出现 404 错误。任何具有 3 个或更多句点的链接都会导致此错误。

我的问题是我能做些什么来阻止这种情况发生?我的想法是将它们发送到 404 错误页面或重定向它们。我怎么能那样做?

我在 Microsoft-IIS/7.0 上运行 ColdFusion 8.0.1。

来自 Miguel-F 的编辑

我在 IIS 7.5 上用 ColdFusion 9.0.1 复制了这个问题,并且在 PCI 扫描期间也注意到了它。

错误:
java.lang.StringIndexOutOfBoundsException

堆栈跟踪:
java.lang.StringIndexOutOfBoundsException: String index out of range: -1 at
java.lang.AbstractStringBuilder.delete(Unknown Source) at
java.lang.StringBuffer.delete(Unknown Source) at
coldfusion.util.Utils.collapseDotDots(Utils.java:647) at
coldfusion.util.Utils.canonicalizeURI(Utils.java:601) at
coldfusion.filter.PathFilter.invoke(PathFilter.java:43) at
coldfusion.filter.ExceptionFilter.invoke(ExceptionFilter.java:70) at
coldfusion.filter.ClientScopePersistenceFilter.invoke(ClientScopePersistenceFilter.java:28) at
coldfusion.filter.BrowserFilter.invoke(BrowserFilter.java:38) at
coldfusion.filter.NoCacheFilter.invoke(NoCacheFilter.java:46) at
coldfusion.filter.GlobalsFilter.invoke(GlobalsFilter.java:38) at
coldfusion.filter.DatasourceFilter.invoke(DatasourceFilter.java:22) at
coldfusion.filter.CachingFilter.invoke(CachingFilter.java:62) at
coldfusion.CfmServlet.service(CfmServlet.java:201) at
coldfusion.bootstrap.BootstrapServlet.service(BootstrapServlet.java:89) at
jrun.servlet.FilterChain.doFilter(FilterChain.java:86) at
coldfusion.monitor.event.MonitoringServletFilter.doFilter(MonitoringServletFilter.java:42) at
coldfusion.bootstrap.BootstrapFilter.doFilter(BootstrapFilter.java:46) at
jrun.servlet.FilterChain.doFilter(FilterChain.java:94) at
jrun.servlet.FilterChain.service(FilterChain.java:101) at
jrun.servlet.ServletInvoker.invoke(ServletInvoker.java:106) at
jrun.servlet.JRunInvokerChain.invokeNext(JRunInvokerChain.java:42) at
jrun.servlet.JRunRequestDispatcher.invoke(JRunRequestDispatcher.java:286) at
jrun.servlet.ServletEngineService.dispatch(ServletEngineService.java:543) at
jrun.servlet.jrpp.JRunProxyService.invokeRunnable(JRunProxyService.java:203) at
jrunx.scheduler.ThreadPool$ThreadThrottle.invokeRunnable(ThreadPool.java:428) at
jrunx.scheduler.WorkerThread.run(WorkerThread.java:66)

最佳答案

由于您使用的是 IIS,我认为您可以使用 IIS URL rewrite拦截并发送 HTTP 400 (bad request) Error .

那会在它到达 Coldfusion 之前捕获它。

关于coldfusion - URL 中的句点导致 ColdFusion 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19577387/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com