BrowserShield: Vulnerability-driven filtering of dynamic HTML

  • Authors:
  • Charles Reis;John Dunagan;Helen J. Wang;Opher Dubrovsky;Saher Esmeir

  • Affiliations:
  • University of Washington, Seattle, WA;Microsoft, Redmond, WA;Microsoft, Redmond, WA;Microsoft, Redmond, WA;Technion

  • Venue:
  • ACM Transactions on the Web (TWEB)
  • Year:
  • 2007

Quantified Score

Hi-index 0.00

Visualization

Abstract

Vulnerability-driven filtering of network data can offer a fast and easy-to-deploy alternative or intermediary to software patching, as exemplified in Shield [Wang et al. 2004]. In this article, we take Shield's vision to a new domain, inspecting and cleansing not just static content, but also dynamic content. The dynamic content we target is the dynamic HTML in Web pages, which have become a popular vector for attacks. The key challenge in filtering dynamic HTML is that it is undecidable to statically determine whether an embedded script will exploit the browser at runtime. We avoid this undecidability problem by rewriting web pages and any embedded scripts into safe equivalents, inserting checks so that the filtering is done at runtime. The rewritten pages contain logic for recursively applying runtime checks to dynamically generated or modified web content, based on known vulnerabilities. We have built and evaluated BrowserShield, a general framework that performs this dynamic instrumentation of embedded scripts, and that admits policies for customized runtime actions like vulnerability-driven filtering. We also explore other applications on top of BrowserShield.