Loading [MathJax]/extensions/MathZoom.js
Towards a Prototype Based Explainable JavaScript Vulnerability Prediction Model | IEEE Conference Publication | IEEE Xplore

Towards a Prototype Based Explainable JavaScript Vulnerability Prediction Model


Abstract:

Security has become a central and unavoidable aspect of today's software development. Practitioners and researchers have proposed many code analysis tools and techniques ...Show More

Abstract:

Security has become a central and unavoidable aspect of today's software development. Practitioners and researchers have proposed many code analysis tools and techniques to mitigate security risks. These tools apply static and dynamic analysis or, more recently, machine learning. Machine learning models can achieve impressive results in finding and forecasting possible security issues in programs. However, most of the current approaches fall short of developer demands in two areas at least: explainability and granularity of predictions. In this paper, we propose a novel and simple yet, promising approach to identify potentially vulnerable source code in JavaScript programs. The model improves the state-of-the-art in terms of explainability and prediction granularity as it gives results at the level of individual source code lines, which is fine-grained enough for developers to take immediate actions. Additionally, the model explains each predicted line (i.e., provides the most similar vulnerable line from the training set) using a prototype-based approach. In a study of 186 real-world and confirmed JavaScript vulnerability fixes of 91 projects, the approach could flag 60% of the known vulnerable lines on average by marking only 10% of the code-base, but in particular cases, the model identified 100% of the vulnerable code lines while flagging only 8.72% of the code-base.
Date of Conference: 27-27 March 2021
Date Added to IEEE Xplore: 08 April 2021
ISBN Information:
Conference Location: Moscow, Russia

Contact IEEE to Subscribe

References

References is not available for this document.