47

From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

  • Upload
    others

  • View
    4

  • Download
    0

Embed Size (px)

Citation preview

Page 1: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 2: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 3: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

From: Trustwave Advisories

Sent: Tuesday, February 9th 2010 23:41

...SpiderLabs has documented view state tampering

vulnerabilities ... View states are used by some

web application frameworks to store the state of

HTML GUI controls. View states are typically

stored in hidden client-side input fields,

although server-side storage is widely supported.

Credit: David Byrne of Trustwave's SpiderLabs

Page 4: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

Executive Summary

... An attacker who successfully exploited this

vulnerability could read data, such as the view

state, which was encrypted by the server. This

vulnerability can also be used for data tampering,

which, if successfully exploited, could be used to

decrypt and tamper with the data encrypted by the

server.

Microsoft .NET Framework versions prior to Microsoft

.NET Framework 3.5 Service Pack 1 are not affected

by the file content disclosure portion of this

vulnerability.

Page 6: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

<script runat="server">

protected void Page_Load(object sender, Event...

if (!IsPostBack) {

myLabel.Text = "Here you can download...

}

}

</script>

<asp:Content runat="server" ContentPlaceHolderID...

<asp:Label ID="myLabel" runat="server">

</asp:Label>

Page 7: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

<form name="aspnetForm" method="post" id="asp...

<input type="hidden" name="__VIEWSTATE“ id="__V...

value="/wEP0aWpA45OkQLP9+4sT2...YW1lcw=" />

...

Download tool</span></h1>

</div>

...

<div class="entry">

<span id="ctl00_plhContent_myLabel">

Here you can download everything you wan...

</span>

Page 8: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

...

<input type="hidden" name="__VIEWSTATE“ id="__V...

value="/wEP0aWpA45OkQLP9+4sT2...YW1lcw=" />

Page 9: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 10: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 11: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 12: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 13: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 14: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 15: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

__VIEWSTATE

Text InnerHTML

Page 16: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 17: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 18: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 19: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 20: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 21: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

<form id="Form1" method="GET" runAt="server,...

<label for="inpSearch">Search: </label>

<input value='<%=Request.QueryString["search"]%>'

type='text' id='search' name='search'>

<input type="submit" />

</form>

Page 22: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

internal static bool IsDangerousString(…) {

char ch = s[num2];

if (ch != '&') {

if ((ch == '<') && ((IsAtoZ(s[num2 + 1]) ||

(s[num2 + 1] == '!')) || ((s[num2 + 1] == '/')

|| (s[num2 + 1] == '?'))))

return true;

}

else if (s[num2 + 1] == '#')

return true;

Page 23: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 24: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 25: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

Server.HtmlEncode("<b>") => &lt;b&gt;

Page 26: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 27: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

<form id="Form1" method="GET" runAt="server...

<label for="inpSearch">Search: </label>

<input value='<%=Server.HtmlEncode(

Request.QueryString["search"]) %>'

type='text' id='search' name='search'>

<input type="submit" />

</form>

Page 28: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

// Now in System.Net.WebUtility with .NET 4.0

public static unsafe void HtmlEncode(…) {

...

switch (ch) {

case '&': {

output.Write("&amp;");

continue;

}

case '\'': {

output.Write("&#39;");

continue;

}

case '"': …

case '<': …

case '>': …

…}

Page 29: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 30: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 31: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 32: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 33: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 34: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are

<!-- web.config file of DotNetNuke

latest version -->

<system.web>

<machineKey

validationKey="F60E6580AE5E29E10C

F592A687E87F1D09280611"

decryptionKey="8A3D693693DB497480

7AC0078A2564C1ED8A19121BCB342C"

decryption="3DES"

validation="SHA1"

/>

Page 35: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 36: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 37: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 38: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 39: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 40: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 41: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 42: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 43: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 44: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 45: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 46: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are
Page 47: From: Trustwave Advisories · From: Trustwave Advisories Sent: Tuesday, February 9th 2010 23:41 ...SpiderLabs has documented view state tampering vulnerabilities ... View states are