Release Notes
  In this topic
 

Release Notes   Release Notes
J/Direct   Introduction

 


J/Direct Information

Microsoft® J/Direct™ is a very powerful mechanism that allows Java code to call functions exported from any Windows DLLs. The code in the DLLs need not be aware of the Java environment. The most obvious use of this scheme is to call Win32 APIs or APIs in third party DLLs. This mechanism automatically translates common data types, such as strings and structures to forms typically expected by C functions. This dramatically reduces any glue code or wrapper DLLs that need to be written. In short J/Direct exposes the richness of the Windows platform to the Java programmer. It also makes calling functions in DLLs as simple as possible.

Any class that uses J/Direct calls requires permissions for maximum trust from the system. This is best explained by looking at the various scenarios:

  • An applet can use J/Direct calls only if it is signed and has "fully trusted" permissions.
  • An untrusted applet cannot resolve to a class that uses J/Direct calls, unless that class has been appropriately marked as a class that can protect itself from malicious use. Please see the "Security Issues" section of the "About J/Direct" article for more information on how to mark your class as safe for use from an untrusted applet.
  • A class on the CLASSPATH, or a package managed class with the "fully trusted" permission, can be a wrapper class that protects another class that uses J/Direct calls from malicious use. Such a wrapper or proxy class can be called from an applet.

A J/Direct call should be treated as a native call. Do not expose access to J/Direct functionality any more freely than access to native code. Security checks should be made through the security manager when exposing J/Direct functionally to untrusted code.

Please refer to the articles "Mixing Java and Native Code" and "About J/Direct" in the SDK for Java documentation for more information.

Win32 API Classes for J/Direct

The Win32 API Classes for J/Direct (the com.ms.win32.* package) provide direct, low-overhead access to commonly used Windows APIs. These classes use the new J/Direct feature and therefore require either Internet Explorer 4.0, or the Microsoft SDK for Java 2.0.

The Win32 API Classes for J/Direct are an optional component in the SDK install. When these classes are installed the com.ms.win32 package is copied into the %windir%\java\classes directory. The sources (.java files) for these classes are also provided as part of the Microsoft SDK for Java 2.0.

If your application requires an api not covered in these classes, J/Direct makes it very easy to write declarations on your own. Complete documentation and samples on using J/Direct can be found in the Microsoft SDK for Java 2.0.

Packages included in this CAB:

com.ms.win32 J/Direct declarations for common Win32 APIs and constants

Classes included in this CAB:

The classes included in com.ms.win32 package fall into three main categories:

Constants

The win class contains the numeric constants used in Win32. For example, the system path length limit (MAX_PATH) can be accessed from Java as follows:

import com.ms.win32.*;

System.out.println("MAX_PATH = " + win.MAX_PATH);

Performance tip:

Do not include the win class in the extends or implements clause of your application's classes. This trick is commonly used to avoid having to type the class name in front of each constant usage. The price for this convenience is that the win class will need to be loaded at runtime, which can significantly impact application start up time. To avoid this overhead, use the qualified name for each constant reference. The Microsoft compiler for Java will inline constant references and will not create a runtime dependency on the win class.

Functions

The Win32 APIs are divided into classes according to the DLL they are exported from.

Kernel32.java KERNEL32.DLL (base API)
Gdi32.java GDI32.DLL (graphics)
User32.java USER32.DLL (user interface)
Advapi32.java ADVAPI32.DLL (crypto API, event logging)
Shell32.java SHELL32.DLL (interface to the Windows Explorer)
Winmm.java WINMM.DLL (multimedia)
Spoolss.java SPOOLSS.DLL (spooling)

Structures

Win32 structures are represented by Java classes that bear the same name as the structure.

Known Issues

If the Win32 API classes for J/Direct were installed as part of the SDK for Java 2.0, they would reside in %windir%\java\classes\com\ms\win32. The SDK setup does not delete these older classes. Please feel free to delete them with a command of the form:

	c:
	cd %windir%\java\classes
	deltree com


Top © 1998 Microsoft Corporation. All rights reserved. Terms of use.