elstar IT

Fullstack | Java | Tech Speaker | Tech Coach | Frank van der Linden

  • About me
  • Blog license
  • My Open source projects

Primefaces upload control and ClickJacking filter on IE8

11-03-2015 no responses flinden68 development

At a customer there was a security issue raised about clickjacking vulnerability in the J2EE application running on Websphere 8.5. After implementing the filter I ran into a issue with the PrimeFaces Upload control on Internet Explorer, especially version 8.

 

What is ClickJacking
At the OWASP website there is a very good explaination about clickjacking. In short is the attacker will disguise the hostile page inside a friendly page.

 

ClickJacking filter for JEE
On the OWASP website there is a ClickJacking filter for Java EE, very easy to implement.
There are to modes for this filter, DENY and SAMEORIGIN. To be on the save side I switched the mode in the web.xml to DENY.
[dropshadowbox align=”none” effect=”lifted-both” width=”400px” height=”” background_color=”#ffffff” border_width=”1″ border_color=”#dddddd” ]webxml_deny[/dropshadowbox]

When I use the upload control in FireFox, Firebug showed the response header the parameter ‘x-frame-options’ was set to DENY.

[dropshadowbox align=”none” effect=”lifted-both” width=”400px” height=”” background_color=”#ffffff” border_width=”1″ border_color=”#dddddd” ]DenyMode[/dropshadowbox]

 

The Issue on Internet Explorer 8

When I tested the upload control on IE8, I noticed that when I press the Upload button, the control will hang in the upload proces by showing the progress bar. IE8 was the only browser affected by this behaviour. Firefox and Chrome was uploading normally.

 

The solution

Next was to switch the ClickJacking Filter mode to SAMEORIGIN

[dropshadowbox align=”none” effect=”lifted-both” width=”400px” height=”” background_color=”#ffffff” border_width=”1″ border_color=”#dddddd” ]webxml_sameorigin[/dropshadowbox]

After publishing the change to the webserver first I checked the response header in Firebug

[dropshadowbox align=”none” effect=”lifted-both” width=”400px” height=”” background_color=”#ffffff” border_width=”1″ border_color=”#dddddd” ]sameoriginMode[/dropshadowbox]

When I reloaded the upload control in IE8 and uploaded a file, everything was working as expected. So issue fixed.

Apparently the PrimeFaces Upload control is using an iFrame underneath the nice UI and was affected by the ClickJackFilter on IE8.

Tags: clickjacking, j2ee, owasp, primefaces

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

  • « 6 months
  • My presentation – Don’t worry with bower »

Contact me

My name is Frank van der Linden and I am an independent software developer based in the Netherlands. The last 2 years I was awarded as IBM Champion. Also I am on the board of OpenNTF. My specialisations are Java, Web development and Domino.


If you want to hire me, please fill in the Contact form


IBM Champion web badge
Apache Logo

All the code on this blog are under the Apache License 2.0. For more details, see Apache License 2.0

Most recent posts

  • NL Portal, a open source project
  • 10th anniversary as a freelancer and more…
  • Engage 2020: Hello are you listening, There is stream for everything
  • Spring Cloud Function on Azure run locally
  • Deploy Spring Cloud Function to IBM Cloud

Latest reactions

  • Spring Cloud Function on Azure run locally - elstar IT on Deploy Spring Cloud Function to IBM Cloud
  • flinden68 on Quick XPages tip: add Fullcalendar plugin to your application
  • Rajesh samal on Quick tip: Swagger support for Spring Webflux
  • dsieyx on Quick XPages tip: add Fullcalendar plugin to your application
  • John on Named as IBM Champion 2019

Archive

  • November 2024
  • April 2024
  • March 2020
  • February 2020
  • January 2020
  • October 2019
  • September 2019
  • June 2019
  • May 2019
  • April 2019
  • March 2019
  • January 2019
  • December 2018
  • October 2018
  • September 2018
  • May 2018
  • April 2018
  • March 2018
  • February 2018
  • January 2018
  • December 2017
  • November 2017
  • October 2017
  • July 2017
  • June 2017
  • May 2017
  • April 2017
  • March 2017
  • February 2017
  • January 2017
  • December 2016
  • November 2016
  • October 2016
  • September 2016
  • August 2016
  • June 2016
  • May 2016
  • April 2016
  • March 2016
  • February 2016
  • December 2015
  • November 2015
  • October 2015
  • September 2015
  • August 2015
  • July 2015
  • June 2015
  • May 2015
  • April 2015
  • March 2015
  • February 2015
  • December 2014
  • October 2014
  • September 2014
  • August 2014
  • July 2014
  • June 2014
  • May 2014
  • April 2014
  • March 2014
  • February 2014

Category

  • bluemix
  • business
  • cloudant
  • community
  • development
  • hrassistant
  • openntf
  • running
  • salesforce
  • Springboot
  • Tesla
  • trailrunning
  • Uncategorized
  • watson
  • OpenNTF
  • Collaboration Today
  • XSnippets
  • Stackoverflow
  • IBM Collaboration Solutions
  • Social Business Toolkit
  • About me
  • Dutch curriculum vitae
  • English curriculum vitae
  • Google+
  • LinkedIn profile
  • Twitter
  • Slideshare
  • Blog license
  • My open source projects