This site is the archived OWASP Foundation Wiki and is no longer accepting Account Requests.
To view the new OWASP Foundation website, please visit https://owasp.org
Difference between revisions of "CRV2 FrameworkSpecIssuesASPClassic"
(Created page with "=CLASSIC ASP= Unlike Java and .NET, classic ASP pages do not have structured error handling in try-catch blocks. Instead they have a specific object called "err". This make e...") |
|||
(2 intermediate revisions by the same user not shown) | |||
Line 9: | Line 9: | ||
Page_Error is page level handling which is run on the server side. Below is an example but the error information is a little | Page_Error is page level handling which is run on the server side. Below is an example but the error information is a little | ||
too informative and hence bad practice. | too informative and hence bad practice. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | The text in the example above has a number of issues: Firstly, it redisplay the HTTP request to the user in the form of | + | [[File:Classic-asp.png]] |
− | Request.Url.ToString() Assuming there has been no data validation prior to this point, we are vulnerable to cross site | + | |
− | + | The text in the example above has a number of issues: Firstly, it redisplay the HTTP request to the user in the form of Request.Url.ToString() Assuming there has been no data validation prior to this point, we are vulnerable to cross site mscripting attacks!! Secondly the error message and stack trace is displayed to the user using Server.GetLastError().ToString() which divulges internal information regarding the application. | |
− | which divulges internal information regarding the application. |
Latest revision as of 02:54, 22 September 2013
CLASSIC ASP
Unlike Java and .NET, classic ASP pages do not have structured error handling in try-catch blocks. Instead they have a specific object called "err". This make error handling in a classic ASP pages hard to do and prone to design errors on error handlers, causing race conditions and information leakage. Also, as ASP uses VBScript (a subtract of Visual Basic), sentences like "On Error GoTo label" are not available.
Vulnerable Patterns for Error Handling
Page_Error
Page_Error is page level handling which is run on the server side. Below is an example but the error information is a little too informative and hence bad practice.
The text in the example above has a number of issues: Firstly, it redisplay the HTTP request to the user in the form of Request.Url.ToString() Assuming there has been no data validation prior to this point, we are vulnerable to cross site mscripting attacks!! Secondly the error message and stack trace is displayed to the user using Server.GetLastError().ToString() which divulges internal information regarding the application.