gpt4 book ai didi

tomcat - ColdFusion 10 + IIS : Non-existant URLs that are CFM files. 执行 404 页面后检索原始 URL

转载 作者:行者123 更新时间:2023-11-28 21:50:51 24 4
gpt4 key购买 nike

我们的服务器设置如下:

  • Windows 2012 R2
  • Coldfusion 10,企业
  • IIS,配置自定义 404 页面(在服务器上执行)

自定义 404 页面(CFM 文件)处理丢失的 URL 并根据数据库中的自定义 URL 检查它们。如果找到匹配项,它将显示相关数据。当自定义 URL 映射到不存在的 CFM 文件时会出现问题;例如。

/home/map.cfm(不是真实的文件或目录)

现在,当用户请求此 URL 时,服务器会发现它是一个 CFM 文件并正确地将它传递给 ColdFusion(通过 ISAPI 重定向)。 Tomcat 发现此文件实际上并不存在,并返回 404。IIS 看到此 404 消息并执行自定义错误页面 (/errors/404.cfm)。

生成的 CGI 变量实际上不允许我们检索原始 URL(将其映射到数据库中的虚拟 URL),通常作为 CGI.QUERY_STRING 变量的一部分提供。相反,QUERY_STRING 变量包含“jakarta”目录中“isapi_rewrite.dll”文件的路径。

在 Tomcat 为所述页面返回 404 错误后,是否有任何方法保留最初请求的 URL(CFM 文件的)?

解决方案,由我自己整理,灵感来自 Thomas Gorgolione

正如所怀疑的那样,问题总是归结为转发到 ISAPI_REDIRECT 模块的请求,即使有问题的文件不存在也是如此。

正如 Thomas 所建议的,一个优雅的解决方案是在将其传递给 ISAPI_REDIRECT 模块之前利用重写来检查文件/目录是否实际存在。

虽然 Thomas 建议的软件可以解决问题,但我无法在 64 位 Windows 2012 R2 机器上安装它。然而,我设法回退到使用 IIS8(可能还有更早版本)中包含的 URL 重写模块。

请参阅下面提供解决方案的我的 web.config 条目。

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.webServer>
<httpErrors>
<remove statusCode="404" subStatusCode="-1" />
</httpErrors>
<rewrite>
<rules>
<rule name="404 HTTP">
<match url="(.*)" />
<conditions>
<add input="{REQUEST_URI}" pattern="CFFileServlet/(.*)" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
<add input="{SERVER_PORT_SECURE}" pattern="0" />
</conditions>
<action type="Rewrite" url="/404.cfm?404;http://{HTTP_HOST}:{SERVER_PORT}{REQUEST_URI}" />
</rule>
<rule name="404 HTTPS">
<match url="(.*)" />
<conditions>
<add input="{REQUEST_URI}" pattern="CFFileServlet/(.*)" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
<add input="{SERVER_PORT_SECURE}" pattern="1" />
</conditions>
<action type="Rewrite" url="/404.cfm?404;https://{HTTP_HOST}:{SERVER_PORT}{REQUEST_URI}" />
</rule>
</rules>
</rewrite>
</system.webServer>
</configuration>

上述配置文件同时考虑了 HTTP 和 HTTPS 请求。它还将考虑 ColdFusion 用于托管临时图像和 Assets 的 CFFileServlet 目录。如果 URL 以此目录开头,它将作为正常请求传递。

感谢大家的参与。

最佳答案

注意:上述问题也包含解决方案。

我认为这是 Coldfusion 连接器的错误。我会向 Adob​​e ( https://bugbase.adobe.com/) 发布错误报告。我确实有一个解决方法。我有同样的问题,但我使用 IIRF( ionic IIS 重定向器 - http://iirf.codeplex.com/),我找到了一种方法来使用它来暂时避免错误:

  1. 删除 IIS/Coldfusion 中所有先前的 404 文件配置
  2. 根据安装说明正常安装 IIRF。
  3. 在 IirfGlobal.ini 文件(通常位于 C:\Windows\System32\inetsrv\IIRF)中,添加以下行:

    RewriteFilterPriority HIGH

    这将允许 IIRF 在它到达 ColdFusion/Tomcat 之前处理 404 请求。

  4. 在特定于站点的 Iirf.ini 中(通常您在 Web 文件的根文件夹中创建一个——有关详细信息,请参阅 IIRF 文档),添加以下规则:

    RewriteCond %{SCRIPT_TRANSLATED} !-f
    RewriteCond %{SCRIPT_TRANSLATED} !-d
    RewriteRule ^(.+)$ page_to_redirect_to.cfm?404;$1 [L]

    这会将所有不存在的文件/目录重定向到 page_to_redirect_to.cfm,并像往常一样添加 404 查询字符串。

  5. 编辑:添加了以下步骤:进入 IIS 管理器并选择配置为使用 IIRF 的服务器或网站,然后进入 ISAPI 过滤器部分。点击“查看有序列表”,然后将 IIRF 过滤器移至顶部。

编辑 2: 刚刚向 Adob​​e 发布了一个错误。参见 https://bugbase.adobe.com/index.cfm?event=bug&id=3630245

希望对您有所帮助。

关于tomcat - ColdFusion 10 + IIS : Non-existant URLs that are CFM files. 执行 404 页面后检索原始 URL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18694932/

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