42

我已经遇到这个问题已经有一段时间了,并决定尝试通过在此处发布问题来一劳永逸地彻底解决问题。我在位于此处的 .net 4 网站中有一个图像处理程序:

https://www.amadeupurl.co.uk/ImageHandler.ashx?i=3604 (为保护隐私而删除了实际域)

现在这工作正常,并且可以毫无问题地从 Web 服务器提供图像,我说没有问题,因为如果我访问它工作正常的 URL,图像加载,不会产生异常。但是,昨天确实有人访问了这个确切的 URL,并且引发了以下几行的异常:

Exception Generated
Error Message:
A potentially dangerous Request.Path value was detected from the client (?).
Stack Trace:
at System.Web.HttpRequest.ValidateInputIfRequiredByConfig() at System.Web.HttpApplication.PipelineStepManager.ValidateHelper(HttpContext context)

Technical Information:
DATE/TIME: 23/01/2013 03:50:01
PAGE: www.amadeupurl.co.uk/ImageHandler.ashx?i=3604

我理解错误消息,这不是问题我只是不明白为什么它会在这里生成,更糟糕的是我无法复制它,就像我说我点击图片加载的链接一样,没有例外。我正在使用 URL 路由并注册了要忽略的处理程序,以防这导致以下代码出现问题:

routes.Ignore("{resource}.ashx")

我不确定为什么我会收到错误或其他什么尝试。

4

3 回答 3

97

Asp.Net 4.0+ 带有非常严格的内置请求验证,其中一部分是 url 中可能用于 XSS 攻击的潜在危险字符。以下是 url 中默认的无效字符:

< > * % & : \ ?

您可以在配置文件中更改此行为:

<system.web>
    <httpRuntime requestPathInvalidCharacters="<,>,*,%,&,:,\,?" />
</system.web>

或者回到 .Net 2.0 验证:

<system.web>
    <httpRuntime requestValidationMode="2.0" />
</system.web>

一个非常常见的无效字符是%,所以如果有任何机会(攻击、网络爬虫或只是一些非标准浏览器)url 被转义,你会得到:

www.amadeupurl.co.uk/ImageHandler.ashx/%3Fi%3D3604

而不是这个:

www.amadeupurl.co.uk/ImageHandler.ashx/?i=3604

请注意,这%3F是 的转义字符?。Asp.Net 请求验证器认为该字符无效并引发异常:

A potentially dangerous Request.Path value was detected from the client (?).

虽然在错误消息中,您会看到字符 (%3F) 的未转义版本,它又?

这是一篇关于请求验证以及如何处理它的好文章

于 2013-01-23T21:13:13.243 回答
0

即使我遇到了这个问题,但对我来说,我不小心输入了 & 而不是 ? 在网址中

例如:

example.com/123123¶meter1=value1&paameter2=value2

但实际上它必须是:

example.com/123123?parameter1=value1&paameter2=value2

于 2019-09-26T08:14:16.223 回答
0

一个超级旧的线程,但这有效:

return RedirectToAction("MyAction", new { @myParameterName = "MyParameterValue" });

如果请求将发送到不同的控制器,您还可以在操作名称之后添加控制器名称,并且还可以通过在它们之间用逗号链接它们来添加更多查询字符串参数。

于 2021-04-09T04:34:59.887 回答