This header ensures that the browser will refuse to connect if there is a certificate problem like in an invalid certificate presented by a MIM attack coming from a malware in a user's computer. Without this header the user will be giving away absolutely all "secure" traffic to the attacker. Additionally this header will make sure the browser uses only https protocol which means no insecure/unencrypted/plain text communication happens with the server.
The motivation for not using this header could be to allow mixing insecure content in your pages or to allow using self signed certificates in non production servers. I believe such motivation is dangerous when you consider the risk. Your application will be more secure if you address security in the backend and in the front end, the same way you should do validations in the front end and the backend.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Header unset ETag | |
Header set X-Frame-Options: sameorigin | |
Header set X-XSS-Protection: "1; mode=block" | |
Header set X-Content-Type-Options: nosniff | |
Header set X-WebKit-CSP: "default-src 'self'" | |
Header set X-Permitted-Cross-Domain-Policies: "master-only" | |
Header set Strict-Transport-Security "max-age=31536000; includeSubDomains" |
No comments:
Post a Comment