﻿{"id":784,"date":"2011-12-17T21:57:48","date_gmt":"2011-12-17T13:57:48","guid":{"rendered":"http:\/\/notes.zerobox.org\/?p=784"},"modified":"2011-12-17T21:57:48","modified_gmt":"2011-12-17T13:57:48","slug":"%e7%a7%91%e6%99%ae-asp-net-validaterequest-filter-rule","status":"publish","type":"post","link":"http:\/\/zerobox.org\/notes\/784.html","title":{"rendered":"\u79d1\u666e asp.net ValidateRequest filter rule"},"content":{"rendered":"<p>\u63d0\u53d6\u4e86.net4.0 \u68c0\u9a8c\u6e90\u4ee3\u7801\u5982\u4e0b\uff1a<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>\/\/\/ \u8fd9\u91cc\u4f2a\u5165\u53e3<\/p>\n<p>\/\/\/ &lt;\/summary&gt;<\/p>\n<p>\/\/\/ &lt;param name=&#8221;s&#8221;&gt;&lt;\/param&gt;<\/p>\n<p>\/\/\/ &lt;returns&gt;&lt;\/returns&gt;<\/p>\n<p>private static bool\u00a0IsDangerousString(string s)<\/p>\n<p>{<\/p>\n<p>\/\/\u5148\u53bb\u9664 \\0<\/p>\n<p>s = RemoveNullCharacters(s);<\/p>\n<p>int macount = 0;<\/p>\n<p>return IsDangerousString(s, out macount);<\/p>\n<p>}<\/p>\n<p>&nbsp;<\/p>\n<p>\/\/\/ &lt;summary&gt;<\/p>\n<p>\/\/\/ \u53bb\u9664\u5b57\u7b26\u622a\u65ad<\/p>\n<p>\/\/\/ &lt;\/summary&gt;<\/p>\n<p>\/\/\/ &lt;param name=&#8221;s&#8221;&gt;&lt;\/param&gt;<\/p>\n<p>\/\/\/ &lt;returns&gt;&lt;\/returns&gt;<\/p>\n<p>private static string\u00a0RemoveNullCharacters(string s)<\/p>\n<p>{<\/p>\n<p>if (s == null)<\/p>\n<p>{<\/p>\n<p>return null;<\/p>\n<p>}<\/p>\n<p>if (s.IndexOf(&#8216;\\0&#8217;) &gt; -1)<\/p>\n<p>{<\/p>\n<p>return s.Replace(&#8220;\\0&#8243;, string.Empty);<\/p>\n<p>}<\/p>\n<p>return s;<\/p>\n<p>}<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>&nbsp;<\/p>\n<p>static char[]startingChars = new char[] {\u00a0&#8216;&lt;&#8216;, &#8216;&amp;&#8217;\u00a0};<\/p>\n<p>&nbsp;<\/p>\n<p>private static bool\u00a0IsAtoZ(char c)<\/p>\n<p>{<\/p>\n<p>return (((c &gt;=&#8217;a&#8217;) &amp;&amp; (c &lt;=&#8217;z&#8217;)) || ((c &gt;=&#8217;A&#8217;) &amp;&amp; (c &lt;=\u00a0&#8216;Z&#8217;)));<\/p>\n<p>}<\/p>\n<p>&nbsp;<\/p>\n<p>\/\/\/ &lt;summary&gt;<\/p>\n<p>\/\/\/ 1.\u6ca1\u6709 &lt; \u548c &amp; \u4e00\u5b9a\u53ef\u4ee5<\/p>\n<p>\/\/\/ 2. &lt; \u540e\u9762\u662f\u5b57\u6bcd \u6216 ! \/ ? \u90fd\u4e0d\u53ef\u4ee5<\/p>\n<p>\/\/\/ 3. &amp; \u540e\u9762 # \u4e0d\u53ef\u4ee5<\/p>\n<p>\/\/\/ &lt;\/summary&gt;<\/p>\n<p>\/\/\/ &lt;param name=&#8221;s&#8221;&gt;&lt;\/param&gt;<\/p>\n<p>\/\/\/ &lt;param name=&#8221;matchIndex&#8221;&gt;&lt;\/param&gt;<\/p>\n<p>\/\/\/ &lt;returns&gt;&lt;\/returns&gt;<\/p>\n<p>internal static bool\u00a0IsDangerousString(string s, out int matchIndex)<\/p>\n<p>{<\/p>\n<p>matchIndex = 0;<\/p>\n<p>int startIndex = 0;<\/p>\n<p>while (true)<\/p>\n<p>{<\/p>\n<p>int num2 = s.IndexOfAny(startingChars, startIndex);<\/p>\n<p>if (num2 &lt; 0)<\/p>\n<p>{<\/p>\n<p>return false;<\/p>\n<p>}<\/p>\n<p>if (num2 == (s.Length &#8211; 1))<\/p>\n<p>{<\/p>\n<p>return false;<\/p>\n<p>}<\/p>\n<p>matchIndex = num2;<\/p>\n<p>char ch = s[num2];<\/p>\n<p>if (ch !=&#8217;&amp;&#8217;)<\/p>\n<p>{<\/p>\n<p>if ((ch ==\u00a0&#8216;&lt;&#8216;) &amp;&amp; ((IsAtoZ(s[num2 + 1]) || (s[num2 + 1] ==\u00a0&#8216;!&#8217;)) || ((s[num2 + 1] ==\u00a0&#8216;\/&#8217;) || (s[num2 + 1] ==\u00a0&#8216;?&#8217;))))<\/p>\n<p>{<\/p>\n<p>return true;<\/p>\n<p>}<\/p>\n<p>}<\/p>\n<p>else if (s[num2 + 1] ==\u00a0&#8216;#&#8217;)<\/p>\n<p>{<\/p>\n<p>return true;<\/p>\n<p>}<\/p>\n<p>startIndex = num2 + 1;<\/p>\n<p>}<\/p>\n<p>}<\/p>\n<p>&nbsp;<\/p>\n<p><strong>\u603b\u7ed3<\/strong><\/p>\n<p>1. \u4e0d\u51fa\u73b0 &lt; \u548c &amp; \u4e00\u5b9a\u662f\u5b89\u5168\u7684<\/p>\n<p>2.\u00a0\u53ea\u51fa\u73b0 &lt; \u6216 &amp; \u5355\u5b57\u7b26 \u662f\u5b89\u5168\u7684<\/p>\n<p>3. &lt; \u540e\u51fa\u73b0a-Z , \/ , ! ,? \u00a0\u662f\u4e0d\u5b89\u5168\u7684<\/p>\n<p>4. &amp; \u540e\u51fa\u73b0# \u662f\u4e0d\u5b89\u5168\u7684<\/p>\n<p>5. \u4e0a\u8ff0\u672a\u5339\u914d\u7684\u5168\u90e8\u662f\u5b89\u5168\u7684<\/p>\n<p>&nbsp;<\/p>\n<p>\u7ed3\u5408\u8fc7\u6ee4\u89c4\u5219\u548cie\u7279\u6027\uff0c\u5c31\u80fd\u627e\u51fa\u4e00\u4e9bbypass\u7684\u65b9\u6cd5\uff0c\u5982 ie6 \u4e0b<\/p>\n<p>&nbsp;<\/p>\n<p>&lt;~\/XSS\/*-*\/STYLE=xss:e\/**\/xpression(alert(&#8216;XSS&#8217;))&gt;<\/p>\n<p>&nbsp;<\/p>\n<p>\u53c2\u8003<\/p>\n<p><a href=\"http:\/\/www.procheckup.com\/vulnerability_manager\/documents\/document_1258758664\/bypassing-dot-NET-ValidateRequest.pdf\">http:\/\/www.procheckup.com\/vulnerability_manager\/documents\/document_1258758664\/bypassing-dot-NET-ValidateRequest.pdf<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u63d0\u53d6\u4e86.net4.0 \u68c0\u9a8c\u6e90\u4ee3\u7801\u5982\u4e0b\uff1a &nbsp; &nbsp; &nbsp; &hellip;<\/p>\n<p class=\"read-more\"><a href=\"http:\/\/zerobox.org\/notes\/784.html\">\u7ee7\u7eed\u9605\u8bfb &raquo;<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[184],"class_list":["post-784","post","type-post","status-publish","format-standard","hentry","tag-asp-net"],"views":948,"_links":{"self":[{"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/posts\/784","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/comments?post=784"}],"version-history":[{"count":0,"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/posts\/784\/revisions"}],"wp:attachment":[{"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/media?parent=784"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/categories?post=784"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/zerobox.org\/notes\/wp-json\/wp\/v2\/tags?post=784"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}