|
CVII. PHP / Java Integration
There are two possible ways to bridge PHP and Java: you can either
integrate PHP into a Java Servlet
environment, which is the more stable and efficient solution,
or integrate Java support into PHP. The former is provided by a SAPI
module that interfaces with the Servlet server, the latter by this
Java extension.
The Java extension provides a simple and effective means for creating and
invoking methods on Java objects from PHP. The JVM is created using JNI,
and everything runs in-process.
警告 | 本扩展模块是实验性的。本模块的行为,包括其函数的名称以及其它任何关于此模块的文档可能会在没有通知的情况下随
PHP 以后的发布而改变。使用本扩展模块风险自担。 |
You need a Java VM installed on your machine to use this extension.
本 PECL 扩展未绑定于 PHP 中。
在 PHP 4 中本 PECL 扩展的源程序位于
PHP 源程序中的 ext/ 目录下或者在上面的
PECL 连接中。
In order to use these functions you must compile PHP with Java support by
using the --with-java[=DIR] where DIR
points to the base install directory of your JDK. This extension can only
be built as a shared extension. Additional build extensions can be found
in php-src/ext/java/README.
Windows users will enable php_java.dll inside
of php.ini in order to use these functions.
在 PHP 4 中本 DLL 位于
PHP Windows 执行包中的 extensions/ 目录下。
可以从 PHP
下载页面或者 http://snaps.php.net/
下载此 PECL 扩展的
DLL 文件。
注:
In order to enable this module on a Windows environment with PHP <=
4.0.6, you must make jvm.dll available to your
systems PATH. No additional DLL is needed for PHP versions > 4.0.6.
这些函数的行为受 php.ini 的影响。
表格 1. Java configuration options Name | Default | Changeable | Changelog |
---|
java.class.path | NULL | PHP_INI_ALL | | java.home | NULL | PHP_INI_ALL | | java.library.path | NULL | PHP_INI_ALL | | java.library | JAVALIB | PHP_INI_ALL | |
有关 PHP_INI_* 常量进一步的细节与定义参见 附录 G。
例子 1. Java Example
<?php // get instance of Java class java.lang.System in PHP $system = new Java('java.lang.System');
// demonstrate property access echo 'Java version=' . $system->getProperty('java.version') . '<br />'; echo 'Java vendor=' . $system->getProperty('java.vendor') . '<br />'; echo 'OS=' . $system->getProperty('os.name') . ' ' . $system->getProperty('os.version') . ' on ' . $system->getProperty('os.arch') . ' <br />';
// java.util.Date example $formatter = new Java('java.text.SimpleDateFormat', "EEEE, MMMM dd, yyyy 'at' h:mm:ss a zzzz");
echo $formatter->format(new Java('java.util.Date')); ?>
|
|
例子 2. AWT Example
<?php // This example is only intended to be run as a CGI.
$frame = new Java('java.awt.Frame', 'PHP'); $button = new Java('java.awt.Button', 'Hello Java World!');
$frame->add('North', $button); $frame->validate(); $frame->pack(); $frame->visible = True;
$thread = new Java('java.lang.Thread'); $thread->sleep(10000);
$frame->dispose(); ?>
|
|
Notes:
new Java() will create an instance of a class if
a suitable constructor is available. If no parameters are passed and
the default constructor is useful as it provides access to classes
like java.lang.System which expose most of their
functionallity through static methods.
Accessing a member of an instance will first look for bean properties
then public fields. In other words, print $date.time
will first attempt to be resolved as $date.getTime(),
then as $date.time.
Both static and instance members can be accessed on an object with
the same syntax. Furthermore, if the java object is of type
java.lang.Class, then static members of the class
(fields and methods) can be accessed.
Exceptions raised result in PHP warnings, and NULL results. The
warnings may be eliminated by prefixing the method call with an
"@" sign. The following APIs may be used to retrieve and reset
the last error:
Overload resolution is in general a hard problem given the
differences in types between the two languages. The PHP Java
extension employs a simple, but fairly effective, metric for
determining which overload is the best match.
Additionally, method names in PHP are not case sensitive, potentially
increasing the number of overloads to select from.
Once a method is selected, the parameters are coerced if necessary,
possibly with a loss of data (example: double precision floating point
numbers will be converted to boolean).
In the tradition of PHP, arrays and hashtables may pretty much
be used interchangably. Note that hashtables in PHP may only be
indexed by integers or strings; and that arrays of primitive types
in Java can not be sparse. Also note that these constructs are
passed by value, so may be expensive in terms of memory and time.
The Java Servlet SAPI builds upon the mechanism defined by the Java
extension to enable the entire PHP processor to be run as a servlet.
The primary advantage of this from a PHP perspective is that web servers
which support servlets typically take great care in pooling and reusing
JVMs. Build instructions for the Servlet SAPI module can be found in
php4/sapi/README.
Notes:
While this code is intended to be able to run on any servlet engine,
it has only been tested on Apache's Jakarta/tomcat to date. Bug
reports, success stories and/or patches required to get this code
to run on other engines would be appreciated.
PHP has a habit of changing the working directory. sapi/servlet will
eventually change it back, but while PHP is running the servlet engine
may not be able to load any classes from the CLASSPATH which are
specified using a relative directory syntax, or find the work directory
used for administration and JSP compilation tasks.
| |