Breaking abstractions and unstructuring data structures

Christian Collberg, Clark Thomborson, Douglas Low

Research output: Chapter in Book/Report/Conference proceedingConference contribution

117 Scopus citations

Abstract

To ensure platform independence, mobile programs are distributed in forms that are isomorphic to the original source code. Such codes are easy to decompile, and hence they increase the risk of malicious reverse engineering attacks. Code obfuscation is one of several techniques which has been proposed to alleviate this situation. An obfuscator is a tool which - through the application of code transformations - converts a program into an equivalent one that is more difficult to reverse engineer. In a previous paper [5] we have described the design of a control flow obfuscator for Java. In this paper we extend the design with transformations that obfuscate data structures and abstractions. In particular, we show how to obfuscate classes, arrays, procedural abstractions and built-in data types like strings, integers, and booleans.

Original languageEnglish (US)
Title of host publicationProceedings of the IEEE International Conference on Computer Languages
PublisherIEEE Comp Soc
Pages28-38
Number of pages11
ISBN (Print)0818684542
DOIs
StatePublished - 1998
Externally publishedYes
EventProceedings of the 1998 International Conference on Computer Languages - Chicago, IL, USA
Duration: May 14 1998May 16 1998

Other

OtherProceedings of the 1998 International Conference on Computer Languages
CityChicago, IL, USA
Period5/14/985/16/98

ASJC Scopus subject areas

  • Software

Fingerprint

Dive into the research topics of 'Breaking abstractions and unstructuring data structures'. Together they form a unique fingerprint.

Cite this