Hackernoon logoUnsafe use of target=”_blank” by@sachindra149

Unsafe use of target=”_blank”

Author profile picture


Front End Engineer

Developers have been frequently using this attribute to open a new webpage. But this attribute, though looks pretty simple, can create a major security threat to your application.

The threat associated is called Reverse Tabnabbing. The issue is the webpage that we are linking our existing page to gains a partial access to the linking page, or in other words, the target page or url gains a partial access to our parent page from where the user is redirected to a new url.

This happens through the window.opener object of Javascript. The attacker can change the 

 to some malicious page and also the parent page. In case the parent page has the same look and feel of the user intended page, he might end up sharing credentials or secure information assuming that the webpage is secure.

To prevent pages from misusing window.opener property, we use

. This ensures that window.opener is assigned to NULL.

This works in Chrome 49 and above, Opera 36 and above, Firefox 52 and above, Desktop Safari 10.1+ and iOS Safari 10.3+. Though for older browsers,

 works pretty fine. So, as a combination, we can use 
rel="noopener noreferrer"

Also, remember, whenever we open a new window using

property, we’re also vulnerable to this, so, its always advisable to reset the 


Join Hacker Noon

Create your free account to unlock your custom reading experience.