Building secure web applications with automatic partitioning

  • Authors:
  • Stephen Chong;Jed Liu;Andrew C. Myers;Xin Qi;K. Vikram;Lantian Zheng;Xin Zheng

  • Affiliations:
  • Cornell University;Cornell University;Cornell University;Cornell University;Cornell University;Cornell University;Cornell University

  • Venue:
  • Communications of the ACM - Inspiring Women in Computing
  • Year:
  • 2009

Quantified Score

Hi-index 0.00

Visualization

Abstract

Swift is a new, principled approach to building Web applications that are secure by construction. Modern Web applications typically implement some functionality as client-side JavaScript code, for improved interactivity. Moving code and data to the client can create security vulnerabilities, but currently there are no good methods for deciding when it is secure to do so. Swift automatically partitions application code while providing assurance that the resulting placement is secure and efficient. Application code is written as Java-like code annotated with information flow policies that specify the confidentiality and integrity of Web application information. The compiler uses these policies to automatically partition the program into JavaScript code running in the client browser and Java code running on the server. To improve interactive performance, code and data are placed on the client. However, security-critical code and data are always placed on the server. The compiler may also automatically replicate code across the client and server, to obtain both security and performance.