Welcome to Snyk’s State of JavaScript frameworks security report 2019. In this blog post we’ll review security vulnerabilities found in other frontend ecosystem projects.

After reviewing Angular and React as major JavaScript frameworks, we’ll take a brief review of selected JavaScript and CSS frameworks: Vue.js, jQuery and Bootstrap.

jQuery security

jQuery took web development by storm a decade ago but since then web development have been revolutionized further with single page application technologies such as Angular, and React. That said, according to W3Techs which regularly run surveys and report on web technology usage jQuery is being used within 73% of websites they scanned in August 2019.

A Snyk study from 2017 further amplifies this when it reported that 77% of sites use at least one vulnerable JavaScript library and pointed out jQuery was detected in 79% of the top 5,000 URLs from Alexa. If you’re still not convinced, npm’s downloads for the jQuery npm module account to 120,641,977 for the last 12 months alone.

In total, we tracked six security vulnerabilities affecting jQuery across all of its releases to date, four of which are medium severity Cross-Site Scripting vulnerabilities, one is a medium severity Prototype Pollution vulnerability, and lastly, one is a low Denial of Service vulnerability. If you’re not using jQuery 3.4.0 and above which was released only recently, on 10th of Apr, 2019, then you are using vulnerable jQuery versions.

Since jQuery is usually found in web applications as a legacy component it is important to also understand its version usage patterns and their state of security.

W3Techs reports that of all websites using jQuery, it’s 1.x release is dominating with 83.4% of share and version 2 and 3 lag far behind with roughly 8% of all jQuery usage. When looking at the known security vulnerabilities and map them out to jQuery versions we found that four medium severity Cross-Site Scripting vulnerabilities are affecting jQuery v1 which is potentially concerning considering the 83.4% market share for anybody not employing software composition analysis to find and fix vulnerabilities in their open source components.

Are you one of the 84% affected? By submitting this form you consent to us emailing you occasionally about our products and services.You can unsubscribe from emails at any time, and we will never pass your email onto third parties. Privacy Policy

Many websites and web applications will further make use of jQuery libraries to extend the capabilities of jQuery and will turn to community- powered libraries to do so.

We found 13 vulnerable jQuery libraries as provided in the following table and offer the following observations:

Three jQuery libraries are malicious versions of open source community modules. As we can’t account for the downloads of the actual vulnerable versions since this isn’t available from the npm registry, we should call out jquery.js which is a malicious package and accounted for 5,444 downloads in the past 12 months.

jQuery libraries jquery-mobile, jquery-file-upload and jquery-colorbox account to more than 340,000 downloads in the past 12 months, despite including Arbitrary Code Execution and Cross-Site Scripting security vulnerabilities and not having any upgrade path to remediate them.

jQuery library name Vulnerability type Disclosure date Vulnerability severity Yearly module downloads Fix exists? jquery-airload Malicious Package 2019-08-06 high 322 n/a jquery.json-viewer Cross-Site Scripting 2019-07-03 medium 17,898 ✅ github-jquery-widgets Malicious Package 2019-06-07 high 232 n/a jquery-mobile Cross-Site Scripting 2019-05-04 medium 54,991 ❌ jquery-file-upload Arbitrary Code Execution 2018-11-02 low 19,442 ❌ jquery.terminal Cross-Site Scripting 2018-08-19 medium 79,982 ✅ jquery.csssr.validation Regular Expression Denial of Service (ReDoS) 2018-02-13 high 3,069 ✅ jquery-colorbox Cross-Site Scripting 2017-11-14 medium 268,513 ❌ jquery.js Malicious Package 2017-08-02 high 5,444 n/a jquery-ui Cross-Site Scripting 2016-07-21 high 8,934,683 ✅ jquery-ujs Cross-Site Request Forgery (CSRF) 2015-06-24 medium 5,763,710 ✅ jquery-migrate Cross-Site Scripting 2013-04-18 medium 1,831,735 ✅ jquery-ui Cross-Site Request Forgery (CSRF) 2012-11-26 medium 8,934,683 ✅ jquery-mobile Cross-Site Scripting 2012-08-01 medium 54,991 ✅ jquery-ui Cross-Site Scripting 2010-09-02 medium 8,934,683 ✅

*malicious packages have no fix information.

We highly recommend to download the full version of the report in its digital format, but have also made the following general sections available as blog posts: