Wednesday, April 16, 2014

IIS 7 HTTP status codes and details

The HTTP status codes
This section describes the HTTP status codes that IIS 7.0 uses.

Note This article does not list every possible HTTP status code as dictated in the HTTP specification. This article includes only the HTTP status codes that IIS 7.0 can send. For example, a custom Internet Server API (ISAPI) filter or a custom HTTP module can set its own HTTP status code.
1xx - Informational
These HTTP status codes indicate a provisional response. The client computer receives one or more 1xx responses before the client computer receives a regular response.

IIS 7.0 uses the following informational HTTP status codes:
100 - Continue.
101 - Switching protocols.
2xx - Success
These HTTP status codes indicate that the server successfully accepted the request.

IIS 7.0 uses the following success HTTP status codes:
200 - OK. The client request has succeeded.
201 - Created.
202 - Accepted.
203 - Nonauthoritative information.
204 - No content.
205 - Reset content.
206 - Partial content.
3xx - Redirection
These HTTP status codes indicate that the client browser must take more action to fulfill the request. For example, the client browser may have to request a different page on the server. Or, the client browser may have to repeat the request by using a proxy server.

IIS 7.0 uses the following redirection HTTP status codes:
301 - Moved permanently.
302 - Object moved.
304 - Not modified.
307 - Temporary redirect.
4xx - Client error
These HTTP status codes indicate that an error occurred and that the client browser appears to be at fault. For example, the client browser may have requested a page that does not exist. Or, the client browser may not have provided valid authentication information.

IIS 7.0 uses the following client error HTTP status codes:
400 - Bad request. The request could not be understood by the server due to malformed syntax. The client should not repeat the request without modifications.

IIS 7.0 defines the following HTTP status codes that indicate a more specific cause of a 400 error:
400.1 - Invalid Destination Header.
400.2 - Invalid Depth Header.
400.3 - Invalid If Header.
400.4 - Invalid Overwrite Header.
400.5 - Invalid Translate Header.
400.6 - Invalid Request Body.
400.7 - Invalid Content Length.
400.8 - Invalid Timeout.
400.9 - Invalid Lock Token.
401 - Access denied.

IIS 7.0 defines several HTTP status codes that indicate a more specific cause of a 401 error. The following specific HTTP status codes are displayed in the client browser but are not displayed in the IIS log:
401.1 - Logon failed.
401.2 - Logon failed due to server configuration.
401.3 - Unauthorized due to ACL on resource.
401.4 - Authorization failed by filter.
401.5 - Authorization failed by ISAPI/CGI application.
403 - Forbidden.

IIS 7.0 defines the following HTTP status codes that indicate a more specific cause of a 403 error:
403.1 - Execute access forbidden.
403.2 - Read access forbidden.
403.3 - Write access forbidden.
403.4 - SSL required.
403.5 - SSL 128 required.
403.6 - IP address rejected.
403.7 - Client certificate required.
403.8 - Site access denied.
403.9 - Forbidden: Too many clients are trying to connect to the Web server.
403.10 - Forbidden: Web server is configured to deny Execute access.
403.11 - Forbidden: Password has been changed.
403.12 - Mapper denied access.
403.13 - Client certificate revoked.
403.14 - Directory listing denied.
403.15 - Forbidden: Client access licenses have exceeded limits on the Web server.
403.16 - Client certificate is untrusted or invalid.
403.17 - Client certificate has expired or is not yet valid.
403.18 - Cannot execute requested URL in the current application pool.
403.19 - Cannot execute CGI applications for the client in this application pool.
403.20 - Forbidden: Passport logon failed.
403.21 - Forbidden: Source access denied.
403.22 - Forbidden: Infinite depth is denied.
404 - Not found.

IIS 7.0 defines the following HTTP status codes that indicate a more specific cause of a 404 error:
404.0 - Not found.
404.1 - Site Not Found.
404.2 - ISAPI or CGI restriction.
404.3 - MIME type restriction.
404.4 - No handler configured.
404.5 - Denied by request filtering configuration.
404.6 - Verb denied.
404.7 - File extension denied.
404.8 - Hidden namespace.
404.9 - File attribute hidden.
404.10 - Request header too long.
404.11 - Request contains double escape sequence.
404.12 - Request contains high-bit characters.
404.13 - Content length too large.
404.14 - Request URL too long.
404.15 - Query string too long.
404.16 - DAV request sent to the static file handler.
404.17 - Dynamic content mapped to the static file handler via a wildcard MIME mapping.
405 - Invalid verb.
406 - Client browser does not accept the MIME type of the requested page.
408 - Request timed out.
412 - Precondition failed.
5xx - Server error
These HTTP status codes indicate that the server cannot complete the request because the server encounters an error.

IIS 7.0 uses the following server error HTTP status codes:
500 - Internal server error.

IIS 7.0 defines the following HTTP status codes that indicate a more specific cause of a 500 error:
500.0 - Module or ISAPI error occurred.
500.11 - Application is shutting down on the Web server.
500.12 - Application is busy restarting on the Web server.
500.13 - Web server is too busy.
500.15 - Direct requests for Global.asax are not allowed.
500.19 - Configuration data is invalid.
500.21 - Module not recognized.
500.22 - An ASP.NET httpModules configuration does not apply in Managed Pipeline mode.
500.23 - An ASP.NET httpHandlers configuration does not apply in Managed Pipeline mode.
500.24 - An ASP.NET impersonation configuration does not apply in Managed Pipeline mode.
500.100 - Internal ASP error.
501 - Header values specify a configuration that is not implemented.
502 - Web server received an invalid response while acting as a gateway or proxy.

IIS 7.0 defines the following HTTP status codes that indicate a more specific cause of a 502 error:
502.1 - CGI application timeout.
502.2 - Bad gateway.
503 - Service unavailable.

IIS 7.0 defines the following HTTP status codes that indicate a more specific cause of a 503 error:
503.0 - Application pool unavailable.
503.2 - Concurrent request limit exceeded.
Back to the top
Common HTTP status codes and the causes
The causes of some common HTTP status codes are as follows:
200 - OK. IIS 7.0 successfully processed the request.
304 - Not modified. The client browser requests a document that is already in the cache, and the document has not been modified since the document was cached. The client browser uses the cached copy of the document instead of downloading the document from the server.
400 - Bad request. The Http.sys file blocks IIS 7.0 from processing the request because of a problem in the request. Typically, this HTTP status code means that the request contains characters or sequences that are not valid or that the request contradicts the security settings in the Http.sys file.
401.1 - Logon failed. The logon attempt is unsuccessful probably because of a user name or a password that is not valid. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942044 (http://support.microsoft.com/kb/942044/ ) Error message when you try to run a Web application that is hosted on IIS 7.0: "HTTP Error 401.1 - Not Found"
401.2 - Logon failed due to server configuration. This HTTP status code indicates a problem in the authentication configuration settings on the server. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942043 (http://support.microsoft.com/kb/942043/ ) Error message when you try to visit a Web page that is hosted on IIS 7.0: "HTTP Error 401.2 - Unauthorized"
401.3 - Unauthorized due to ACL on resource. This HTTP status code indicates a problem in the NTFS file system permissions. This problem may occur even if the permissions are correct for the file that you are trying to access. For example, this problem occurs if the IUSR account does not have access to the C:\Winnt\System32\Inetsrv directory. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942042 (http://support.microsoft.com/kb/942042/ ) Error message when you try to browse a Web page that is hosted on a server that is running IIS 7.0: "HTTP Error 401.3 - Unauthorized"
401.4 - Authorization failed by filter. An ISAPI filter does not let the request be processed because of an authorization problem. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942079 (http://support.microsoft.com/kb/942079/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 401.4 - Authorization failed by filter"
401.5 - Authorization failed by ISAPI/CGI application. An ISAPI application or a Common Gateway Interface (CGI) application does not let the request be processed because of an authorization problem. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942078 (http://support.microsoft.com/kb/942078/ ) Error message when you visit a Web site that is hosted on a computer that is running IIS 7.0: "HTTP Error 401.5 - Authorization failed by ISAPI/CGI application"
403.1 - Execute access forbidden. The appropriate level of the Execute permission is not granted. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942065 (http://support.microsoft.com/kb/942065/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.1 - Forbidden"
403.2 - Read access forbidden. The appropriate level of the Read permission is not granted. Verify that you have set up IIS 7.0 to grant the Read permission to the directory. Additionally, if you use a default document, verify that the default document exists. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942036 (http://support.microsoft.com/kb/942036/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.2 - Forbidden"
403.3 - Write access forbidden. The appropriate level of the Write permission is not granted. Verify that the IIS 7.0 permissions and the NTFS file system permissions are set up to grant the Write permission to the directory. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942035 (http://support.microsoft.com/kb/942035/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.3 – Forbidden"
403.4 - SSL required. The request is made over a nonsecure channel, and the Web application requires a Secure Sockets Layer (SSL) connection. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942070 (http://support.microsoft.com/kb/942070/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.4 - Forbidden"
403.5 - SSL 128 required. The server is configured to require a 128-bit SSL connection. But, the request is not sent by using 128-bit encryption. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942069 (http://support.microsoft.com/kb/942069/ ) Error message when you try to browse a Web page that is hosted on IIS 7.0: "HTTP Error 403.5 - Forbidden"
403.6 - IP address rejected. The server is configured to deny access to the current IP address. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942068 (http://support.microsoft.com/kb/942068/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.6 - IP Address Rejected"
403.7 - Client certificate required. The server is configured to require a certificate for client authentication. But, the client browser does not have an appropriate client certificate installed. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942067 (http://support.microsoft.com/kb/942067/ ) Error message when you try to run a Web application that is hosted on a server that is running IIS 7.0: "HTTP Error 403.7 - Forbidden"
403.8 - Site access denied. The server is configured to deny requests based on the Domain Name System (DNS) name of the client computer. For more information about how to resolve this problem, click the following article number to view the article in the Microsoft Knowledge Base:
942066 (http://support.microsoft.com/kb/942066/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.8 - Forbidden"
403.12 - Mapper denied access. The page that you want to access requires a client certificate. But, the user ID that is mapped to the client certificate is denied access to the file. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942064 (http://support.microsoft.com/kb/942064/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.12 - Client Certificate Denied"
403.13 - Client certificate revoked. The client browser tries to use a client certificate that was revoked by the issuing certification authority. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942063 (http://support.microsoft.com/kb/942063/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.13 - Forbidden"
403.14 - Directory listing denied. The server is not configured to display a content directory listing, and a default document is not set. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942062 (http://support.microsoft.com/kb/942062/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.14 - Forbidden"
403.16 - Client certificate is untrusted or invalid. The client browser tries to use a client certificate that is not trusted by the server that is running IIS 7.0 or that is not valid. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942061 (http://support.microsoft.com/kb/942061/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.16 - Forbidden"
403.17 - Client certificate has expired or is not yet valid. The client browser tries to use a client certificate that is expired or that is not yet valid. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942038 (http://support.microsoft.com/kb/942038/ ) Error message when you try to visit a Web page that is hosted on Internet Information Services 7.0: "HTTP Error 403.17 (Forbidden) - The client certificate has expired"
403.18 - Cannot execute requested URL in the current application pool. A custom error page is configured, and the custom error page resides in a different application pool than the application pool of the requested URL. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942037 (http://support.microsoft.com/kb/942037/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.18 - Forbidden"
403.19 - Cannot execute CGI applications for the client browser in this application pool. The identity of the application pool does not have the Replace a process level token user right. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942048 (http://support.microsoft.com/kb/942048/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 403.19 - Forbidden"
404.0 - Not found. The file that you are trying to access was moved or does not exist. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942041 (http://support.microsoft.com/kb/942041/ ) Error message when you try to open a Web page that is hosted on IIS 7.0: "HTTP Error 404.0 - Not Found"
404.2 - ISAPI or CGI restriction. The requested ISAPI resource or the requested CGI resource is restricted on the computer. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942040 (http://support.microsoft.com/kb/942040/ ) Error message when you try to visit a Web page that is hosted on a computer that is running IIS 7.0: "HTTP Error 404.2 – Not Found"
404.3 - MIME type restriction. The current MIME mapping for the requested extension type is not valid or is not configured. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942032 (http://support.microsoft.com/kb/942032/ ) Error message when users visit a Web site that is hosted on a server that is running Internet Information Services 7.0: "HTTP Error 404.3 - Not Found"
404.4 - No handler configured. The file name extension of the requested URL does not have a handler that is configured to process the request on the Web server. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942052 (http://support.microsoft.com/kb/942052/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.4 - Not Found"
404.5 - Denied by request filtering configuration. The requested URL contains a character sequence that is blocked by the server. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942053 (http://support.microsoft.com/kb/942053/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.5 - URL Sequence Denied"
404.6 - Verb denied. The request is made by using an HTTP verb that is not configured or that is not valid. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942046 (http://support.microsoft.com/kb/942046/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.6 - VERB_DENIED"
404.7- File extension denied. The requested file name extension is not allowed. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942045 (http://support.microsoft.com/kb/942045/ ) Error message when you try to browse a Web page that is hosted on IIS 7.0: "HTTP Error 404.7 - FILE_EXTENSION_DENIED"
404.8 - Hidden namespace. The requested URL is denied because the directory is hidden. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942047 (http://support.microsoft.com/kb/942047/ ) Error message when you try to visit a Web page that is hosted on IIS 7.0: "HTTP Error 404.8 - HIDDEN_NAMESPACE"
404.9 - File attribute hidden. The requested file is hidden. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942049 (http://support.microsoft.com/kb/942049/ ) Error message when you try to visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.9 - File Attribute Hidden"
404.10 - Request header too long. The request is denied because the request headers are too long. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942077 (http://support.microsoft.com/kb/942077/ ) Error message when you visit a Web site that is hosted on a server that is running Internet Information Services 7.0: "HTTP Error 404.10 - REQUEST_HEADER_TOO_LONG"
404.11 - Request contains double escape sequence. The request contains a double escape sequence. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942076 (http://support.microsoft.com/kb/942076/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.11 - URL_DOUBLE_ESCAPED"
404.12 - Request contains high-bit characters. The request contains high-bit characters, and the server is configured not to allow high-bit characters. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942075 (http://support.microsoft.com/kb/942075/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.12 - URL_HAS_HIGH_BIT_CHARS"
404.13 - Content length too large. The request contains a Content-Length header. The value of the Content-Length header is larger than the limit that is allowed for the server. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942074 (http://support.microsoft.com/kb/942074/ ) Error message when you visit a Web site that is hosted on a server that is running Internet Information Services 7.0: "HTTP Error 404.13 - CONTENT_LENGTH_TOO_LARGE"
404.14 - Request URL too long. The requested URL exceeds the limit that is allowed for the server. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942073 (http://support.microsoft.com/kb/942073/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 404.14 - URL_TOO_LONG"
404.15 - Query string too long. The request contains a query string that is longer than the limit that is allowed for the server. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942071 (http://support.microsoft.com/kb/942071/ ) Error message when you visit a Web site that is hosted on a server that is running IIS 7.0: "HTTP Error 404.15 - Not Found"
405.0 - Method not allowed. The request is made by using an HTTP method that is not valid. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942051 (http://support.microsoft.com/kb/942051/ ) Error message when a user visits a Web site that is hosted on a server that is running Internet Information Services 7.0: "HTTP Error 405.0 - Method not allowed"
406.0 - Invalid MIME type. The request is made by using an Accept header that contains a MIME value that is not valid. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942050 (http://support.microsoft.com/kb/942050/ ) Error message when you visit a Web site that is hosted on a server that is running Internet Information Services 7.0: "HTTP Error 406 - Not Acceptable"
412.0 - Precondition failed. The request is made by using an If-Match request header that contains a value that is not valid. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942056 (http://support.microsoft.com/kb/942056/ ) Error message when you visit a Web site that is hosted on Internet Information Services (IIS) 7.0: "HTTP Error 412 - Precondition failed"
500 - Internal server error. This HTTP status code may occur for many server-side reasons. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942031 (http://support.microsoft.com/kb/942031/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 500.0 - Internal Server Error"
500.11 - Application is shutting down on the Web server. The request is not processed because the destination application pool is shutting down. Wait for the worker process to finish shutting down, and then try the request again. If this problem persists, the Web application may be experiencing problems that prevent the Web application from shutting down correctly.
500.12 - Application is busy restarting on the Web server. The request is not processed because the destination application pool is restarting. This HTTP status code should disappear when you refresh the page. If this HTTP status code appears again after you refresh the page, the problem may be caused by antivirus software that is scanning the Global.asa file. If this problem persists, the Web application may be experiencing problems that prevent the Web application from restarting correctly.
500.13 - Web server is too busy. The request is not processed because the server is too busy to accept any new incoming requests. Typically, this HTTP status code means that the number of incoming concurrent requests exceeds the number that the IIS 7.0 Web application can process. This problem may occur because the performance configuration settings are set too low, the hardware is insufficient, or a bottleneck occurs in the IIS 7.0 Web application. A common troubleshooting method is to generate a memory dump file of the IIS 7.0 processes when the error is occurring and then to debug the memory dump file.
500.15 - Direct requests for Global.asax are not allowed. A direct request for the Global.asa file or for the Global.asax file is made. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942030 (http://support.microsoft.com/kb/942030/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 500.15 - Direct request for global.asa are not allowed"
500.19 - Configuration data is invalid. This HTTP status code occurs because of a problem in the associated Applicationhost.config file or in the associated Web.config file. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942055 (http://support.microsoft.com/kb/942055/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 500.19 - Internal Server Error"
500.100 - Internal ASP error. An error occurs during the processing of an Active Server Pages (ASP) page. To obtain more specific information about the error, disable friendly HTTP error messages in the Web browser. Additionally, the IIS log may show an ASP error number that corresponds to the error that occurs. For more information about ASP error messages and about the meaning of ASP error messages, click the following article number to view the article in the Microsoft Knowledge Base:
294271 (http://support.microsoft.com/kb/294271/ ) ASP error codes
501.0 - Not implemented. The client browser sends an HTTP-Trace verb, and the server is not configured to process the HTTP-Trace verb. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942058 (http://support.microsoft.com/kb/942058/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 501.0 - Not Implemented"
502.1 - CGI application timeout. A CGI application does not return a valid HTTP response in the configured time limit. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942059 (http://support.microsoft.com/kb/942059/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 502.1 - Bad Gateway"
502.2 - Bad gateway. A CGI application returns an HTTP response that is not valid to the server that is running IIS 7.0. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
942057 (http://support.microsoft.com/kb/942057/ ) Error message when you visit a Web site that is hosted on IIS 7.0: "HTTP Error 502.2 - Bad Gateway"
503.0 - Service unavailable. The request is sent to an application pool that is currently stopped or that is currently disabled. To resolve this issue, make sure that the destination application pool is started. The event log may give information about why the application pool is stopped or disabled.
503.2 - Concurrent request limit exceeded. The appConcurrentRequestLimit property is set to a value that is lower than the current number of concurrent requests. IIS 7.0 does not allow more concurrent requests than the value of the appConcurrentRequestLimit property.

Thursday, August 22, 2013

HTTP request length -- when trying to send large amount of data

Every Application must face the HTTP request length to small, whether it to upload big file or send request/response with large data.

 

Before IIS6

Add the below setting to webconfig of the receive service/app

 

<system.web>

    <httpRuntime maxRequestLength="2097151" executionTimeout="3600" />

 

For IIS6 and above

In addition to previous setting also add the below one in the same file

 

<system.webServer>

  <security>

    <requestFiltering>

      <requestLimits maxAllowedContentLength="4294967295" ></requestLimits>

    </requestFiltering>

  </security>

 

Source reference links

http://forums.iis.net/t/1066272.aspx

http://weblogs.asp.net/jeffwids/archive/2009/09/24/from-iis6-maxrequestlength-to-iis7-maxallowedcontentlengthfile-specifying-maximum-file-upload-size.aspx

http://stackoverflow.com/questions/4022434/how-to-set-the-maxallowedcontentlength-to-500mb-while-running-on-iis7

http://www.iis.net/configreference/system.webserver/security/requestfiltering/requestlimits

 

 

Monday, February 11, 2013

Custom GridView with AutoGenerateColumns

Problem Statement:
        If you have a requirement to keep AutoGenerateColumns="true" and still mamipulate gridview columns.
 
Solution:
Any <asp:TemplateField> with AutoGenerateColumns="true" should be generic to all rows.
On grid OnRowCreated event iterate over the row type and read item.ContainingField , this is where all the cell values are.
 
rdbSummaryReport.Checked – logic create a multiple common header and keeps the css applied to <th>
 
Below source code is a working example :
 
<asp:GridView ID="grdReconResults" runat="server" AutoGenerateColumns="true"
                    AllowPaging="false" AllowSorting="false" OnRowCreated="grdReconResults_OnRowCreated" >
                    <Columns>
                        <asp:TemplateField> //generates a ‘+’ link button in the first column of the grid
                            <ItemTemplate>
                                <asp:LinkButton ID="lnkExpand" runat="server" OnClientClick="return javascript:alert('clicked');" Text="+" />
                            </ItemTemplate>
                        </asp:TemplateField>
                    </Columns>
                </asp:GridView>
 
 
 
 
protected void grdReconResults_OnRowCreated(object sender, GridViewRowEventArgs e)
        {
            System.Drawing.Color highlighted = System.Drawing.Color.Yellow;
            if (rdbDetailReport.Checked)
            { //modification for detailed report
                if (e.Row.RowType == DataControlRowType.DataRow)
                {
                    DataRowView drv = (DataRowView)e.Row.DataItem;
                    if (drv != null)
                    {
                        DataRow dataRow = drv.Row;
                        foreach (DataControlFieldCell item in ((GridViewRow)e.Row).Controls)
                        {
                            DataControlField x = item.ContainingField;
                            if (!x.HeaderText.Equals(string.Empty)) //avoid column from markup
                            {
                                if (x.HeaderText.Contains("Diff_")) // || x.HeaderText.Contains("Hierarchy"))
                                {
                                    x.Visible = false;
                                }
                                else
                                {
                                    string[] parts = x.HeaderText.Split(new char[] { '_' }, 2);
                                    string pComputField = string.Format("Diff_{0}", parts[1]);
                                    if (dataRow.Table.Columns.IndexOf(pComputField) >= 0
                                        && ((bool)dataRow[pComputField]))
                                    {
                                        item.BackColor = highlighted;
                                    }
                                }
                            }
                        }
                    }
                }
            }
            if (rdbSummaryReport.Checked)
            { //modification for summary report
                if (e.Row.RowType == DataControlRowType.Header)
                {
                    int colSpanThree = 3;// for comparison field combined header span 3 rows
                    bool isColSpanThreeActive = false;
                    int colSpanOne = Convert.ToInt32(Decimal.One);
                    GridView grd = (GridView)sender;
                    GridViewRow gRow = (GridViewRow)e.Row;
                    GridViewRow grdHeaderRow = new GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Insert);
                    TableHeaderCell cell = null;
                    List<Control> notRequiredTH = new List<Control>();
                    foreach (DataControlFieldHeaderCell item in gRow.Controls)
                    {
                        DataControlField field = item.ContainingField;
 
                        if (field.HeaderText.Contains("Hierarchy"))
                        {
                            field.Visible = false;
                        }
                        else
                        {
                            if (isColSpanThreeActive)
                            {
                                --colSpanThree;
                                field.HeaderText = field.HeaderText.Substring(0, field.HeaderText.IndexOf('_'));
                                if (colSpanThree == Convert.ToInt32(Decimal.Zero))
                                {
                                    isColSpanThreeActive = false;
                                    colSpanThree = 3;
                                }
                            }
                            else
                            {
                                bool isComparisonCol = selectedMapping.Mappings.Exists(x => x.type == MappingRelation.MappingType.SelectSum
                                    && (field.HeaderText.Contains(x.Y) | field.HeaderText.Contains(x.X)));
                                if (isComparisonCol)
                                {
                                    cell = new TableHeaderCell();
                                    cell.Text = field.HeaderText.Split(new char[] { '_' }, 2)[1];
                                    cell.ColumnSpan = colSpanThree;
                                    cell.HorizontalAlign = HorizontalAlign.Center;
                                    grdHeaderRow.Cells.Add(cell);
                                    field.HeaderText = field.HeaderText.Substring(0, field.HeaderText.IndexOf('_'));
                                    isColSpanThreeActive = true;
                                    --colSpanThree;
                                }
                                else
                                {
                                    cell = new TableHeaderCell();
                                    cell.Text = field.HeaderText;
                                    cell.RowSpan = colSpanOne + colSpanOne;
                                    grdHeaderRow.Cells.Add(cell);
                                    notRequiredTH.Add(item);
                                }
                            }
                        }
                    }
                    notRequiredTH.ForEach(x => gRow.Controls.Remove(x));
                    grdReconResults.Controls[0].Controls.AddAt(gRow.RowIndex, grdHeaderRow);
                }
            }
        }
 
        private string GetHeaderText(string headerText, int headerLevel)
        {
            if (headerLevel == 2)
            {
                return headerText;
            }
            return headerText.Substring(0, headerText.LastIndexOf("."));
        }
 
 

DataTable based excel like PIVOTing

This is a very detailed source code for creating utility to provide column based summation data
 
Reference used :
 
 
 
 
 
CSV and DataSet Helper Classess
 
#region Using..
using System;
using System.IO;
using System.Text;
using System.Linq;
using System.Collections.Generic;
using System.Data;

Wednesday, January 30, 2013

Dynamic LINQ Extension [provided my MS]

 
 
 
Add following code in a “.cs” files and start using
 
//Copyright (C) Microsoft Corporation.  All rights reserved.
 
using System;
using System.Collections.Generic;
using System.Text;
using System.Linq;
using System.Linq.Expressions;
using System.Reflection;
using System.Reflection.Emit;
using System.Threading;
using System.Collections;
 
namespace System.Linq.Dynamic
{
    public static class DynamicQueryable
    {
        public static IQueryable Join(this IQueryable outer, IEnumerable inner, string outerSelector, string innerSelector, string resultsSelector, params object[] values)
        {
            if (inner == null) throw new ArgumentNullException("inner");
            if (outerSelector == null) throw new ArgumentNullException("outerSelector");
            if (innerSelector == null) throw new ArgumentNullException("innerSelector");
            if (resultsSelector == null) throw new ArgumentNullException("resultsSelctor");
 
            LambdaExpression outerSelectorLambda = DynamicExpression.ParseLambda(outer.ElementType, null, outerSelector, values);
            LambdaExpression innerSelectorLambda = DynamicExpression.ParseLambda(inner.AsQueryable().ElementType, null, innerSelector, values);
 
            ParameterExpression[] parameters = new ParameterExpression[] {
            Expression.Parameter(outer.ElementType, "outer"), Expression.Parameter(inner.AsQueryable().ElementType, "inner") };
            LambdaExpression resultsSelectorLambda = DynamicExpression.ParseLambda(parameters, null, resultsSelector, values);
 
            return outer.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "Join",
                    new Type[] { outer.ElementType, inner.AsQueryable().ElementType, outerSelectorLambda.Body.Type, resultsSelectorLambda.Body.Type },
                    outer.Expression, inner.AsQueryable().Expression, Expression.Quote(outerSelectorLambda), Expression.Quote(innerSelectorLambda), Expression.Quote(resultsSelectorLambda)));
        }
 
        //The generic overload.
        public static IQueryable<T> Join<T>(this IQueryable<T> outer, IEnumerable<T> inner, string outerSelector, string innerSelector, string resultsSelector, params object[] values)
        {
            return (IQueryable<T>)Join((IQueryable)outer, (IEnumerable)inner, outerSelector, innerSelector, resultsSelector, values);
        }
 
        public static IQueryable<T> Where<T>(this IQueryable<T> source, string predicate, params object[] values)
        {
            return (IQueryable<T>)Where((IQueryable)source, predicate, values);
        }
 
        public static IQueryable Where(this IQueryable source, string predicate, params object[] values)
        {
            if (source == null) throw new ArgumentNullException("source");
            if (predicate == null) throw new ArgumentNullException("predicate");
            LambdaExpression lambda = DynamicExpression.ParseLambda(source.ElementType, typeof(bool), predicate, values);
            return source.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "Where",
                    new Type[] { source.ElementType },
                    source.Expression, Expression.Quote(lambda)));
        }
 
        public static IQueryable Select(this IQueryable source, string selector, params object[] values)
        {
            if (source == null) throw new ArgumentNullException("source");
            if (selector == null) throw new ArgumentNullException("selector");
            LambdaExpression lambda = DynamicExpression.ParseLambda(source.ElementType, null, selector, values);
            return source.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "Select",
                    new Type[] { source.ElementType, lambda.Body.Type },
                    source.Expression, Expression.Quote(lambda)));
        }
 
        public static IQueryable<T> OrderBy<T>(this IQueryable<T> source, string ordering, params object[] values)
        {
            return (IQueryable<T>)OrderBy((IQueryable)source, ordering, values);
        }
 
        public static IQueryable OrderBy(this IQueryable source, string ordering, params object[] values)
        {
            if (source == null) throw new ArgumentNullException("source");
            if (ordering == null) throw new ArgumentNullException("ordering");
            ParameterExpression[] parameters = new ParameterExpression[] {
                Expression.Parameter(source.ElementType, "") };
            ExpressionParser parser = new ExpressionParser(parameters, ordering, values);
            IEnumerable<DynamicOrdering> orderings = parser.ParseOrdering();
            Expression queryExpr = source.Expression;
            string methodAsc = "OrderBy";
            string methodDesc = "OrderByDescending";
            foreach (DynamicOrdering o in orderings)
            {
                queryExpr = Expression.Call(
                    typeof(Queryable), o.Ascending ? methodAsc : methodDesc,
                    new Type[] { source.ElementType, o.Selector.Type },
                    queryExpr, Expression.Quote(Expression.Lambda(o.Selector, parameters)));
                methodAsc = "ThenBy";
                methodDesc = "ThenByDescending";
            }
            return source.Provider.CreateQuery(queryExpr);
        }
 
        public static IQueryable Take(this IQueryable source, int count)
        {
            if (source == null) throw new ArgumentNullException("source");
            return source.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "Take",
                    new Type[] { source.ElementType },
                    source.Expression, Expression.Constant(count)));
        }
 
        public static IQueryable Skip(this IQueryable source, int count)
        {
            if (source == null) throw new ArgumentNullException("source");
            return source.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "Skip",
                    new Type[] { source.ElementType },
                    source.Expression, Expression.Constant(count)));
        }
 
        public static IQueryable<T> GroupBy<T>(this IQueryable source, string keySelector, string elementSelector, params object[] values)
        {
            if (source == null) throw new ArgumentNullException("source");
            if (keySelector == null) throw new ArgumentNullException("keySelector");
            if (elementSelector == null) throw new ArgumentNullException("elementSelector");
            LambdaExpression keyLambda = DynamicExpression.ParseLambda(source.ElementType, null, keySelector, values);
            LambdaExpression elementLambda = DynamicExpression.ParseLambda(source.ElementType, null, elementSelector, values);
            return source.Provider.CreateQuery<T>(
                Expression.Call(
                    typeof(Queryable), "GroupBy",
                    new Type[] { source.ElementType, keyLambda.Body.Type, elementLambda.Body.Type },
                    source.Expression, Expression.Quote(keyLambda), Expression.Quote(elementLambda)));
        }
 
        public static IQueryable GroupBy(this IQueryable source, string keySelector, string elementSelector, params object[] values)
        {
            if (source == null) throw new ArgumentNullException("source");
            if (keySelector == null) throw new ArgumentNullException("keySelector");
            if (elementSelector == null) throw new ArgumentNullException("elementSelector");
            LambdaExpression keyLambda = DynamicExpression.ParseLambda(source.ElementType, null, keySelector, values);
            LambdaExpression elementLambda = DynamicExpression.ParseLambda(source.ElementType, null, elementSelector, values);
            return source.Provider.CreateQuery(
                Expression.Call(
                    typeof(Queryable), "GroupBy",
                    new Type[] { source.ElementType, keyLambda.Body.Type, elementLambda.Body.Type },
                    source.Expression, Expression.Quote(keyLambda), Expression.Quote(elementLambda)));
        }
 
        public static bool Any(this IQueryable source)
        {
            if (source == null) throw new ArgumentNullException("source");
            return (bool)source.Provider.Execute(
                Expression.Call(
                    typeof(Queryable), "Any",
                    new Type[] { source.ElementType }, source.Expression));
        }
 
        public static int Count(this IQueryable source)
        {
            if (source == null) throw new ArgumentNullException("source");
            return (int)source.Provider.Execute(
                Expression.Call(
                    typeof(Queryable), "Count",
                    new Type[] { source.ElementType }, source.Expression));
        }
    }
 
    public abstract class DynamicClass
    {
        public override string ToString()
        {
            PropertyInfo[] props = this.GetType().GetProperties(BindingFlags.Instance | BindingFlags.Public);
            StringBuilder sb = new StringBuilder();
            sb.Append("{");
            for (int i = 0; i < props.Length; i++)
            {
                if (i > 0) sb.Append(", ");
                sb.Append(props[i].Name);
                sb.Append("=");
                sb.Append(props[i].GetValue(this, null));
            }
            sb.Append("}");
            return sb.ToString();
        }
    }
 
    public class DynamicProperty
    {
        string name;
        Type type;
 
        public DynamicProperty(string name, Type type)
        {
            if (name == null) throw new ArgumentNullException("name");
            if (type == null) throw new ArgumentNullException("type");
            this.name = name;
            this.type = type;
        }
 
        public string Name
        {
            get { return name; }
        }
 
        public Type Type
        {
            get { return type; }
        }
    }
 
    public static class DynamicExpression
    {
        public static Expression Parse(Type resultType, string expression, params object[] values)
        {
            ExpressionParser parser = new ExpressionParser(null, expression, values);
            return parser.Parse(resultType);
        }
 
        public static LambdaExpression ParseLambda(Type itType, Type resultType, string expression, params object[] values)
        {
            return ParseLambda(new ParameterExpression[] { Expression.Parameter(itType, "") }, resultType, expression, values);
        }
 
        public static LambdaExpression ParseLambda(ParameterExpression[] parameters, Type resultType, string expression, params object[] values)
        {
            ExpressionParser parser = new ExpressionParser(parameters, expression, values);
            return Expression.Lambda(parser.Parse(resultType), parameters);
        }
 
        public static Expression<Func<T, S>> ParseLambda<T, S>(string expression, params object[] values)
        {
            return (Expression<Func<T, S>>)ParseLambda(typeof(T), typeof(S), expression, values);
        }
 
        public static Type CreateClass(params DynamicProperty[] properties)
        {
            return ClassFactory.Instance.GetDynamicClass(properties);
        }
 
        public static Type CreateClass(IEnumerable<DynamicProperty> properties)
        {
            return ClassFactory.Instance.GetDynamicClass(properties);
        }
    }
 
    internal class DynamicOrdering
    {
        public Expression Selector;
        public bool Ascending;
    }
 
    internal class Signature : IEquatable<Signature>
    {
        public DynamicProperty[] properties;
        public int hashCode;
 
        public Signature(IEnumerable<DynamicProperty> properties)
        {
            this.properties = properties.ToArray();
            hashCode = 0;
            foreach (DynamicProperty p in properties)
            {
                hashCode ^= p.Name.GetHashCode() ^ p.Type.GetHashCode();
            }
        }
 
        public override int GetHashCode()
        {
            return hashCode;
        }
 
        public override bool Equals(object obj)
        {
            return obj is Signature ? Equals((Signature)obj) : false;
        }
 
        public bool Equals(Signature other)
        {
            if (properties.Length != other.properties.Length) return false;
            for (int i = 0; i < properties.Length; i++)
            {
                if (properties[i].Name != other.properties[i].Name ||
                    properties[i].Type != other.properties[i].Type) return false;
            }
            return true;
        }
    }
 
    internal class ClassFactory
    {
        public static readonly ClassFactory Instance = new ClassFactory();
 
        static ClassFactory() { }  // Trigger lazy initialization of static fields
 
        ModuleBuilder module;
        Dictionary<Signature, Type> classes;
        int classCount;
        ReaderWriterLock rwLock;
 
        private ClassFactory()
        {
            AssemblyName name = new AssemblyName("DynamicClasses");
            AssemblyBuilder assembly = AppDomain.CurrentDomain.DefineDynamicAssembly(name, AssemblyBuilderAccess.Run);
#if ENABLE_LINQ_PARTIAL_TRUST
            new ReflectionPermission(PermissionState.Unrestricted).Assert();