We found a match
Your institution may have access to this item. Find your institution then sign in to continue.
- Title
Extending .NET security to unmanaged code.
- Authors
Klinkoff, Patrick; Kirda, Engin; Kruegel, Christopher; Vigna, Giovanni
- Abstract
The number of applications that are downloaded from the Internet and executed on-the-fly is increasing every day. Unfortunately, not all of these applications are benign, and, often, users are unsuspecting and unaware of the intentions of a program. To facilitate and secure this growing class of mobile code, Microsoft introduced the .NET framework, a new development and runtime environment where machine-independent byte-code is executed by a virtual machine. An important feature of this framework is that it allows access to native libraries to support legacy code or to directly invoke the Windows API. Such native code is called unmanaged (as opposed to managed code). Unfortunately, the execution of unmanaged native code is not restricted by the .NET security model, and, thus, could provide the attacker with a mechanism to completely circumvent the framework’s security mechanisms if the user decides to grant execute permission to the .NET application. The approach described in this paper uses a sandboxing mechanism to prevent an attacker from executing malicious, unmanaged code that is not permitted by the security policy. Our sandbox is implemented as two security layers, one on top of the Windows API and one in the kernel. Also, managed and unmanaged parts of an application are automatically separated and executed in two different processes. This ensures that potentially unsafe code can neither issue system calls not permitted by the .NET security policy nor tamper with the memory of the .NET runtime. Our proof-of-concept implementation is transparent to applications and secures unmanaged code with a generally acceptable performance penalty. To the best of our knowledge, the presented architecture and implementation is the first solution to secure unmanaged code in .NET.
- Subjects
COMPUTER security research; MICROSOFT .NET Framework; DATA protection; COMPUTER access control; ELECTRONIC information resources; ACCESS control
- Publication
International Journal of Information Security, 2007, Vol 6, Issue 6, p417
- ISSN
1615-5262
- Publication type
Article
- DOI
10.1007/s10207-007-0031-0