No | Risk Details |
1 |
Version Disclosure (ASP.NET) Description: This information can be found in HTTP Response Header which can help the attacker to build profile against your site which then they can search for common public issues from sites like “National Vulnerability Database” https://web.nvd.nist.gov/view/vuln/search or for zero-day attacks. This information can be helpful in hacking phase but it doesn’t mean your site will be exploited. Fix: Add the following setting inside the <system.web> element in your application’s Web.config file <httpRuntime enableVersionHeader=”false” /> References: http://www.4guysfromrolla.com/articles/120209-1.aspx |
2 |
Version Disclosure (SharePoint) Description: Same as point 1. Fix: It’s not recommended to remove these headers and it’s better to accept the risk in this case because these will affect the SharePoint crawling and other features except you have an anonymous website with limited features. References: http://www.wictorwilen.se/sharepoint-mythbusting-the-response-header-contains-the-current-sharepoint-version http://www.wictorwilen.se/sharepoint-2013-sharepoint-health-score-and-throttling-deep-dive http://dirkvandenberghe.com/2011/06/07/remove-http-response-headers-for-internet-facing-sharepoint-sites.html http://blog.michelbarneveld.nl/michel/archive/2009/11/08/x-sharepointhealthscore-a-new-sharepoint-2010-http-header.aspx |
3 |
ASP.NET Identified Description: Same as point 1. Fix: Add the following setting in your application's Web.config file
<httpProtocol> <customHeaders> <remove name="X-Powered-By" />References: https://ict.ken.be/removing-x-powered-by-aspnet-and-other-version-headers |
4 |
Version Disclosure (IIS) Description: Same as point 1. Fix: Create custom HTTP Module as following: namespace MyNamespace { public class HttpHeadersCleanup : IHttpModule { public void Init(HttpApplication context) { context.PreSendRequestHeaders += PreSendRequestHeaders; } private static void PreSendRequestHeaders(object sender, EventArgs e) { HttpContext.Current.Response.Headers.Remove("Server"); } public void Dispose() { } } }Then add the following setting in web.config <system.webServer>
<modules>
<add name="HttpHeadersCleanup " type="MyNamespace.HttpHeadersCleanup, MyAssembly"/> </modules>
References:http://www.frederikvig.com/2010/11/removing-http-headers-for-asp-net-sites/ |
5 |
ViewState is not Encrypted Description: SharePoint doesn’t use Viewstate to store any sensitive data such as user tokens or other so just give your security department justification and explain that Viewstate required to be existed in SharePoint because it’s build on top of Asp.Net Web forms. Note: In case you have custom code using Viewstate , make sure to avoid storing sensitve data in Viewstate because it’s readable and represented by base64 encoding and In case you need to use it then make sure to enable Encryption and MAC encoding for integrity. |
6 |
Cookie Not Marked as HttpOnly Description: In General, it’s always recommended to set HttpOnly flag to cookies to prevent XSS script risk against these cookies like Auth Token Cookie which then it can be used in hijacking and other attacks. In SharePoint if you are using Form authentication then by default SharePoint flag Auth Token with HttpOnly but there are some cookie in SharePoint not flagged with HttpOnly like “wss_keepsessionauthenticated” . Fix: Add this setting to web.config <system.web> <httpCookies httpOnlyCookies="true" requireSSL="true" />References: http://murmurofawebmaster.blogspot.com/2013/07/ wsskeepsessionauthenticated.html |
7 |
Accessing _layout/ folder Description: For anonymous SharePoint website , it’s better to prevent users from accessing application pages which exists under _layout folder like /layout/Viewlsts.aspx .By default SharePoint has an enabled feature called “ViewFormPagesLockDown” which prevent anonymous users from accessing these pages. Fix: In case it’s disable then you can activate it by the following command Enable-SPFeature ViewFormPagesLockDown -Url http://youSite References: http://www.c-sharpcorner.com/uploadfile/Roji.Joy/how-to-secure-external-anonymous-access-to-sharepoint-2010-sites |
8 |
Insufficient Transport Layer Protection Description: “HTTPs everywhere”, it’s a top priority to protect the information in transit by using TLS/SSL to provide secure communication. Also In case of anonymous site, it’s helpful to you to increase the site rank in Google search engine using HTTPs and by the way HTTPs (represents top layer of TLS/SSL) which provides 3 goals:
References: http://googlewebmastercentral.blogspot.com.au/2014/08/https-as-ranking-signal.html https://www.owasp.org/index.php/Transport_Layer_Protection_Cheat_Sheet http://www.troyhunt.com/2011/11/owasp-top-10-for-net-developers-part-9.html |
9 |
Separation of duties Description: Separation of Duties is a security principle which the process of separate sharing of more than one individual in one single task to prevent fraud and error. In case of anonymous websites this policy it can be very important and it can applies in SharePoint in many ways for examples:
|
10 |
Stack Trace and Errors Disclosure (ASP.NET) Description: It’s recommended to stop disclosing information because of unhandled errors, trace and debug .With easy steps , you can prevent leaking these information which might help an attacker to gain more information and potentially focus on the development of further attacks. Fix: Change these settings in web.config
|
11 |
_vti_inf.html , _vti_bin , _vti_pvt and _vti_bin/spsdisco.aspx Description: If your SharePoint application is anonymously accessible then it’s recommended to consider implementing authorization rule to restrict access to web services , or resources under _vti_bin, _vti_pvt , /_vti_bin/spsdisco.aspx … to at least prevent attacker from accessing these resources to gain information like SharePoint version or FrontPage configuration information … etc Fix: Add this setting to web.config <location path="_vti_inf.html"> <system.web> <authorization> <deny users="?" /> <allow users="*" /> </authorization> </system.web> </location> <location path="_vti_pvt"> <system.web> <authorization> <deny users="?" /> <allow users="*" /> </authorization> </system.web> </location> <location path="_vti_bin"> <system.web> <authorization> <deny users="?" /> <allow users="*" /> </authorization> </system.web> </location>References: http://thuansoldier.net/?p=4267 http://thuansoldier.net/?p=4298 |
12 |
Clickjacking Description: It’s recommended to prevent clickjacking risk on your website and you can find more details about it in this article – Clickjacking in OWASP https://www.owasp.org/index.php/Clickjacking Fix: The easiest fix for this risk to add this header X-Frame-Options to HTTP Response but remember this way is not supported in all browsers. Configure IIS to add an X-Frame-Options header to all responses for a given site, follow these steps:
Note: By default SharePoint 2013 configured with this header
References:http://blog.kotowicz.net/2009/12/5-ways-to-prevent-clickjacking-on-your.html https://www.owasp.org/index.php/Clickjacking https://support.microsoft.com/en-us/kb/2694329 http://styledpoint.com/blog/including-sharepoint-2013-in-an-iframe-without-x-frame-options-error/ |
13 |
ASP.NET Security Vulnerability Description: Any security vulnerabilities apply to Asp.net, it will be applied to SharePoint because SharePoint built on top of Asp.Net technologies. The below are the Common security vulnerabilities: Padding oracle vulnerability: (Asp.Net v1.0 to v3.5), most probably this vulnerability exists in non-patched SharePoint 2010 and older version. To know about this vulnerability you can check http://weblogs.asp.net/scottgu/important-asp-net-security-vulnerability or http://www.troyhunt.com/2010/09/fear-uncertainty-and-and-padding-oracle.html Fix: Update your SharePoint with the latest new version of CU to address this and other issues or you can install the direct fix https://technet.microsoft.com/library/security/ms10-070 Hash DoS vulnerability: (resolved with the release of .NET 4.5) Allows an attacker to make a POST request with a very large number of parameters constructed to cause hash collisions when parsed by ASP.NET. To know about this vulnerability you can check http://www.troyhunt.com/2011/12/has-hash-dos-patch-been-installed-on.html Fix: Update your SharePoint with the latest new version of CU to address this and other issues or you can install the direct fix https://technet.microsoft.com/library/security/ms11-100 Note: you can test your SharePoint site if it has the above vulnerabilities using the following link https://asafaweb.com (I recommended you to use this site for testing and also read all things written by the owner of this site Mr.Troy Hunt http://troyhunt.com) |
14 |
Validation Request Description: Request validation, a feature of ASP.NET since version 1.1, prevents the server from accepting content containing un-encoded HTML. This feature is designed to help prevent some script-injection attacks whereby client script code or HTML can be unknowingly submitted to a server, stored, and then presented to other users. Fix: SharePoint like other .NET content management systems which has a lot of places where rich text needs to be submitted to the server so By default Microsoft disable ValidateRequest in web.config and if you try to enable it then you will not able to create pages with Html editors contents.In this case you need to accept the risk and keep this feature disable but take care for your SharePoint and make sure it’s patched with up to date fixes and In case you have custom code , make sure to validate and encode the input at the client and server sides using libraries like AntiXSS and others. References: https://msdn.microsoft.com/en-us/library/hh882339(v=vs.110).aspx http://www.asp.net/whitepapers/request-validation http://www.troyhunt.com/2010/03/request-validation-dotnetnuke-and.html https://www.nuget.org/packages/AntiXss/ |
15 |
Critical Security Updates Description: SharePoint is prone to exploitation since new threats are discovered so there is a need to fix the vulnerabilities and security problems. SharePoint patches can be in three form:
|
16 |
Max Upload Document / Max Request length Description: It’s recommended to decrease the amount in these settings “Maximum Upload Size” and “maxRequestLength” to limit the impacts of the load, response time and data capacity in the server especially in case of DoS attacks. Fix: You can follow steps in the following link https://support.microsoft.com/en-us/kb/925083 and make sure these values meet your business requirements. References: https://technet.microsoft.com/en-us/library/ee424404(office.14).aspx#Section3c |
17 |
Search Misconfiguration Description: Exclude Allitems.aspx Some contents like http://*allitems.aspx should not be accessed by a public user in the SharePoint search result Fix: We can create Crawl Rules to hide them from search result and It’s recommended to create the following crawl rules: http://*allitems.aspx http://*editform.aspx http://*dispform.aspx http://*my-sub.aspx http://*mod-view.aspx http://*itemsonhomepage.aspx http://*thumbnails.aspx References: https://technet.microsoft.com/en-us/library/jj219686.aspx Default content access account This account that the SharePoint Search service uses by default for crawling the contents. Avoid Grant this service account Full Control. Fix: This service account needs full read access to each web application. Under “User Policy” of a Web application , make sure this account only has “Full Read” permission. References: Persistent XSS flaw in SharePoint 2013 Description: This particular vulnerability, CVE-2015-2522, is caused by insufficiently sanitizing user-supplied input in a number of input points like notes, keywords, and comments. For more details you can check this link http://blog.fortinet.com/post/sharepoint-2013-xss-vulnerability-discovered Fix: Update your SharePoint with the latest new version of CU to address this and other issues. Note: Only SharePoint 2013 with version build 15.0.4571.1502 and before should update as soon as possible. |
19 |
Disable loopback check Description: The feature prevents access to a web application using a fully qualified domain name (FQDN) if an attempt to access it takes place from a machine that hosts that application. The end result is a 401.1 Access Denied from the web server and a logon failure in the event log.People go around this issue by wrong way (even me) because Microsoft consider this as a security feature. Fix: Don’t use “DisableLoopbackCheck” and instead of that fix it using the following registry key “BackConnectionHostNames“. You can follow the steps in this post https://support.microsoft.com/en-us/kb/896861 [First Method] Note: You can go with “DisableLoopbackCheck” option in the development and testing servers. References: http://blogs.technet.com/b/sharepoint_foxhole/archive/2010/06/21/disableloopbackcheck-lets-do-it-the-right-way.aspx |
20 |
Health Check(Security) Description: SharePoint Health Analyzer is a feature that enables administrators to schedule regular, automatic checks for potential configuration, performance, and usage problems in the server farm. SharePoint has four Health check rules related to Security as following:
Most of the below rules are best practices so fix these issues which has detected by the SharePoint Health Analyzer and in case you want to ignore them then make sure to have a good reason.
References:
|
21 | DR + Documentation
Description: Fix: |
22 |
The server farm account should not be used for other services. Description: The account used for the SharePoint timer service and the central administration site, is highly privileged and should not be used for any other services on any machines in the server farm. In SharePoint Health Analyzer you could find similar warning like Accounts used by application pools or service identities are in the local machine Administrators group or others warnings and all related to inappropriate setup service accounts. Fix: To install SharePoint ,you have to have appropriate administrative and service accounts on servers running SharePoint and SQL Server. Plan for administrative and service accounts in SharePoint 2013 https://technet.microsoft.com/en-us/library/cc263445.aspx References: https://technet.microsoft.com/en-us/library/cc678863.aspx https://technet.microsoft.com/EN-US/library/hh377944.aspx |
23 |
TCP/IP Ports of SharePoint 2013 Description: Learn about security hardening for SharePoint web server, application server, and database server roles,including specific hardening requirements for ports, protocols, and services. References: https://technet.microsoft.com/en-us/library/cc262849.aspx#PortProtocolService http://blog.blksthl.com/2013/02/21/tcpip-ports-of-sharepoint-2013/ |
24 |
Require Use Remote Interfaces permission Description: It’s recommended to prevent Anonymous user from accessing Client Object Model interfaces. When this option is checked, it simply means that the user must possess the Use Remote Interfaces permission which allows access to SOAP, Web DAV and Client Object Model. Note:By default this option is checked in SharePoint 2013 References: http://blogs.msdn.com/b/kaevans/archive/2013/10/24/what-every-developer-needs-to-know-about-sharepoint-apps-csom-and-anonymous-publishing-sites.aspx |
25 |
Enable Client Integration? Description: It’s recommended to disable Client integration in case of anonymous site but it will effectively block SharePoint from being a useful collaboration tool, and block all Office client interaction with SharePoint and also prevent you to work with SharePoint Designer and using Windows Explorer View. Note: Don’t go with this option except you evaluate the client business requirements and you extend the SharePoint site to work with SharePoint Designer and other client features. References: https://support.microsoft.com/en-us/kb/2758444 https://support.microsoft.com/en-us/kb/981223 |
Thursday, November 3, 2016
Protecting SharePoint Server Applications/SharePoint public website penetration testing issue fixes
Subscribe to:
Post Comments (Atom)
Image noise comparison methods
1. using reference image technique - peak_signal_noise_ratio (PSNR) - SSI 2. non-reference image technique - BRISQUE python pac...
-
No Risk Details 1 Version Disclosure (ASP.NET) Description: This information can be found in HTTP Response Header w...
-
Artificial Intelligence is the broader umbrella under which Machine Learning and Deep Learning come. And you can also see in the diagram th...
-
Recently, I had a requirement to copy users from one SharePoint group to another group. Unfortunately, SharePoint doesn't support nest...
Amazing Blog
ReplyDeletePentesting Pretty good post. I just stumbled upon your blog and wanted to say that I have really enjoyed reading your blog posts. Any way I'll be subscribing to your feed and I hope you post again soon. Big thanks for the useful info.
ReplyDeleteThanks for sharing
ReplyDelete