English

SafeJS: Hermetic Sandboxing for JavaScript

Programming Languages 2013-09-17 v1 Cryptography and Security

Abstract

Isolating programs is an important mechanism to support more secure applications. Isolating program in dynamic languages such as JavaScript is even more challenging since reflective operations can circumvent simple mechanisms that could protect program parts. In this article we present SafeJS, an approach and implementation that offers isolation based on separate sandboxes and control of information exchanged between them. In SafeJS, sandboxes based on web workers do not share any data. Data exchanged between sandboxes is solely based on strings. Using different policies, this infrastructure supports the isolation of the different scripts that usually populate web pages. A foreign component cannot modify the main DOM tree in unexpected manner. Our SafeJS implementation is currently being used in an industrial setting in the context of the Resilience FUI 12 project.

Cite

@article{arxiv.1309.3914,
  title  = {SafeJS: Hermetic Sandboxing for JavaScript},
  author = {Damien Cassou and Stéphane Ducasse and Nicolas Petton},
  journal= {arXiv preprint arXiv:1309.3914},
  year   = {2013}
}
R2 v1 2026-06-22T01:27:43.795Z