• Get application security done the right way! Detect, Protect, Monitor, Accelerate, and more…
  • Protect WordPress website from XSS, Clickjacking and some other attacks

    Securing your site is essential for your online business presence. Over the weekend, I did a security scan on my WordPress website through Acunetix and Netsparker and found the following vulnerabilities.

    • Missing X-Frame-Options Header
    • Cookie Not Marked as HttpOnly
    • Cookie without Secure flag set

    If you are on dedicated, Cloud or VPS hosting, then you can directly inject these headers in Apache or Nginx to mitigate it. However, to do this directly in WordPress – you can do the following.

    Note: post-implementation, you can use the Secure Headers Test tool to verify the results.

    X-Frame-Options Header in WordPress

    Having this injected in the Header will prevent Clickjacking attacks. Below was discovered by Netsparker.

    missing-x-frame-wordpress

    Solution:

    • Go to the path where WordPress is installed. If you are on shared hosting, you can log into cPanel >> File Manager
    • Take a backup of wp-config.php
    • Edit the file and add the following line
    header('X-Frame-Options: SAMEORIGIN');
    • Save and refresh your website to verify.

    Cookie with HTTPOnly and Secure flag in WordPress

    Having Cookie with HTTPOnly instructs the browser to trust the cookie only by the server, which adds a layer of protection against XSS attacks.

    httponly-cookie-wordpress

    The secure flag in cookie instructs the browser that cookie is accessible over secure SSL channels, which add a layer of protection for the session cookie.

    cookie-secure-flag

    Note: This would work on the HTTPS website. If you are still on HTTP, then you may consider switching to HTTPS for better security.

    Solution:

    • Take a backup of wp-config.php
    • Edit the file and add the following line
    @ini_set('session.cookie_httponly', true); 
    @ini_set('session.cookie_secure', true); 
    @ini_set('session.use_only_cookies', true);
    • Save the file and refresh your website to verify it.

    If you don’t like to hack the code, then alternatively, you can use Shield plugin, which will help you to block iFrames & and protect from XSS attacks.

    Once you install the plugin, go to HTTP headers and enable them.

    shield-http-headers

    I hope the above helps you in mitigating WordPress vulnerabilities.

    Wait before you go…

    Are you looking to implement more secure headers?

    There are 10 OWASP recommended secure headers, and if using VPS or Cloud, then check out this implementation guide for Apache and Nginx. However, if on shared hosting or want to do it within WordPress, then try this plugin.

    Conclusion

    Securing a site is challenging, and it requires on-going efforts. If you are looking to offload the security headache to the expert, then you may try SUCURI WAF, who looks after complete website protection and performance for you.