
Nicht jeder möchte, dass jeder sehen kann, was für ein Webserver für die eigene Homepage verwendet wird. Dies sind bzw. können schließlich auch sicherheitsrelevante Informationen darstellen.
Der IIS sowie ASP.NET verschicken aber standardmäßig ihre Versionssignaturen über die HTTP-Header an den Client.
IIS Header Bloat
Die ungeliebten Header sind hierbei
- Server Microsoft/IIS8.0
- X-AspNetMvc-Version 5.5.2
- X-AspNet-Version 4.0.30319
- X-Powered-By: ASP.NET
Um diese künftig nicht mehr zu verwenden reichen zwei Einträge in der Web-Config:
1<configuration>
2 <system.webServer>
3 <httpProtocol>
4 <customHeaders>
5 <remove name="X-Powered-By" />
6 <remove name="Server" />
Das deaktiviert die Header des IIS, also Server sowie X-Powered-By
Zusätzlich brauchen wir noch
1 <system.web>
2 <httpRuntime enableVersionHeader="false"/>
um X-AspNet-Version aus dem Header zu bekommen.
Für ASP.NET sieht das nicht ganz so einfach aus; hier müssen wir leider den Code anfassen.
Dazu müssen wir folgenden Code in die Global.asax.cs einfügen:
1public class MvcApplication : System.Web.HttpApplication
2{
3 protected void Application_Start()
4 {
5 MvcHandler.DisableMvcResponseHeader = true;
Dies entfernt den Header X-AspNetMvc-Version.
Der Webserver verschickt nun keine weiteren Header-Informationen, die ihn bzw. dessen Version entlarven könnte.
Security through Obscurity
Auch wenn dieses Vorgehen nur eine Taktik der Verschleierung darstellt sorgt es gleichermaßen für eine Erhöhung der Sicherheit. Es gibt durchaus Bots, die gezielt auf Webserver-Produkte und -Versionen ausgerichtet sind. Nimmt man diesen die Grundinformation erhöht das die Wahrscheinlichkeit, dass eine Unregelmäßigkeit in den Anfragen frühzeitig erkannt wird.
Related articles

Jan 28, 2020 · 8 min read
Warum IP-Adressen kein eindeutiges Merkmal sind
Immer wieder sieht man in Code, der für den Login eines Benutzers verwendet wird, dass mit Hilfe der IP-Adresse oder zum Beispiel auch dem …

Oct 04, 2019 · 2 min read
Using ASP.NET Core 3 in .NET libraries
With the release of ASP.NET Core 3, Microsoft has also changed the way how to use and reference ASP.NET Core dependencies. In the past you …

Mar 26, 2017 · 1 min read
Better exception details with ASP.NET Core
By default, ASP.NET Core suppresses Exceptions on Startup on external environments. So you only get Exceptions in Startup on localhost.
Let's Work Together
Looking for an experienced Platform Architect or Engineer for your next project? Whether it's cloud migration, platform modernization or building new solutions from scratch - I'm here to help you succeed.

Comments