Platform-Independent Dynamic Taint Analysis for Java']JavaScript

被引:28
|
作者
Karim, Rezwana [1 ]
Tip, Frank [2 ]
Sochurkova, Alena [3 ]
Sen, Koushik [4 ]
机构
[1] Samsung Res Amer, Mountain View, CA 94043 USA
[2] Northeastern Univ, Coll Comp & Informat Sci, Boston, MA 02115 USA
[3] Avast, Prague 14000, Czech Republic
[4] Univ Calif Berkeley, Berkeley, CA 94720 USA
基金
欧洲研究理事会;
关键词
Instruments; Engines; Browsers; Tools; Privacy; Gears; Data privacy; Taint analysis; dynamic analysis; !text type='Java']Java[!/text]Script; platform-independent; instrumentation;
D O I
10.1109/TSE.2018.2878020
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Previous approaches to dynamic taint analysis for JavaScript are implemented directly in a browser or JavaScript engine, limiting their applicability to a single platform and requiring ongoing maintenance as platforms evolve, or they require nontrivial program transformations. We present an approach that relies on instrumentation to encode taint propagation as instructions for an abstract machine. Our approach has two key advantages: it is platform-independent and can be used with any existing JavaScript engine, and it can track taint on primitive values without requiring the introduction of wrapper objects. Furthermore, our technique enables multiple deployment scenarios by varying when and where the generated instructions are executed and it supports indirect taint sources, i.e., situations where taint enters an application via arguments passed to dynamically registered event-listener functions. We implemented the technique for the ECMAScript 5 language in a tool called Ichnaea, and evaluated it on 22 NPM modules containing several types of injection vulnerabilities, including 4 modules containing vulnerabilities that were not previously discovered and reported. On these modules, run-time overheads range from 3.17x to 38.42x, which is significantly better than a previous transformation-based technique. We also report on a case study that shows how Ichnaea can be used to detect privacy leaks in a Tizen web application for the Samsung Gear S2 smart watch.
引用
收藏
页码:1364 / 1379
页数:16
相关论文
共 50 条
  • [1] MemInsight: Platform-Independent Memory Debugging for Java']JavaScript
    Jensen, Simon Holm
    Sridharan, Manu
    Sen, Koushik
    Chandra, Satish
    [J]. 2015 10TH JOINT MEETING OF THE EUROPEAN SOFTWARE ENGINEERING CONFERENCE AND THE ACM SIGSOFT SYMPOSIUM ON THE FOUNDATIONS OF SOFTWARE ENGINEERING (ESEC/FSE 2015) PROCEEDINGS, 2015, : 345 - 356
  • [2] AUGUR: Dynamic Taint Analysis for Asynchronous Java']JavaScript
    Aldrich, Mark W.
    Turcotte, Alexi
    Blanco, Matthew
    Tip, Frank
    [J]. PROCEEDINGS OF THE 37TH IEEE/ACM INTERNATIONAL CONFERENCE ON AUTOMATED SOFTWARE ENGINEERING, ASE 2022, 2022,
  • [3] Demo: ThingsMigrate - Platform-Independent Live-Migration of Java']JavaScript Processes
    Jung, Kumseok
    Gascon-Samson, Julien
    Pattabiraman, Karthik
    [J]. 2018 THIRD IEEE/ACM SYMPOSIUM ON EDGE COMPUTING (SEC), 2018, : 356 - 358
  • [4] ThingsMigrate: Platform-independent migration of stateful Java']JavaScript Internet of Things applications
    Jung, Kumseok
    Gascon-Samson, Julien
    Goyal, Shivanshu
    Rezaiean-Asel, Armin
    Pattabiraman, Karthik
    [J]. SOFTWARE-PRACTICE & EXPERIENCE, 2021, 51 (01): : 117 - 155
  • [5] A platform-independent distributed runtime for standard multithreaded java']java
    Factor, Michael
    Schuster, Assaf
    Shagin, Konstantin
    [J]. INTERNATIONAL JOURNAL OF PARALLEL PROGRAMMING, 2006, 34 (02) : 113 - 142
  • [6] A Platform-Independent Distributed Runtime for Standard Multithreaded Java
    Michael Factor
    Assaf Schuster
    Konstantin Shagin
    [J]. International Journal of Parallel Programming, 2006, 34 : 113 - 142
  • [7] Extracting Taint Specifications for Java']JavaScript Libraries
    Staicu, Cristian-Alexandru
    Torp, Martin Toldam
    Schafer, Max
    Moller, Anders
    Pradel, Michael
    [J]. 2020 ACM/IEEE 42ND INTERNATIONAL CONFERENCE ON SOFTWARE ENGINEERING (ICSE 2020), 2020, : 198 - 209
  • [8] Complete and Platform-Independent Calling Context Profiling for the Java']Java Virtual Machine
    Sarimbekov, Aibek
    Moret, Philippe
    Binder, Walter
    Sewe, Andreas
    Mezini, Mira
    [J]. ELECTRONIC NOTES IN THEORETICAL COMPUTER SCIENCE, 2011, 279 (01) : 61 - 74
  • [9] Platform-independent dynamic reconfiguration of distributed applications
    Almeida, JPA
    van Sinderen, M
    Pires, LF
    Wegdam, M
    [J]. 10TH IEEE INTERNATIONAL WORKSHOP ON FUTURE TRENDS OF DISTRIBUTED COMPUTING SYSTEMS, PROCEEDINGS, 2004, : 286 - 291
  • [10] Dynamic Flow Analysis for Java']JavaScript
    Naus, Nico
    Thiemann, Peter
    [J]. TRENDS IN FUNCTIONAL PROGRAMMING (TFP 2016), 2019, 10447 : 75 - 93