/*
* 版权归PHPSalon.com所有,未经许可,严禁任何形式转载
*
* Author: Wenlong Wu
*/
以下方法在WIN2000 SP4 + IIS6.0 + PHP-4.3.6 + J2SDK1.4.2_04环境下测试通过。
1、下载并安装J2SDK
从官方网站下一个J2SDK,安装过程非常简单,一直下一步中途只需选择安装的路径即可,笔者是安装在 d:\j2sdk1.4.2_04 目录下,安装完成后将 d:\j2sdk1.4.2_04\bin 加入到系统的环境变量PATH中。
2、安装并配置PHP
安装PHP的方法请参考网上的一些文章,本文只介绍 JAVA 的相关配置,注意要安装成 CGI 方式,否则会出现“Unable to create Java Virtual Machine”的错误信息。笔者是安装在 d:\php-4.3.6 目录下。然后按如下方法修改 php.ini 配置文件:
1) 修改内存限制 memory_limit = 100M,默认情况下是8M,对于启动JVM来说是不够,笔者这里改为100M。
2) 加入对JAVA的支持:
[Java]
extension=php_java.dll
java.class.path = "d:\php-4.3.6\extensions\php_java.jar"
java.home = "d:\j2sdk1.4.2_04\jre"
java.library = "d:\j2sdk1.4.2_04\jre\bin\server\jvm.dll"
java.library.path = "d:\php-4.3.6\extensions"
顺便提一下,笔者起先是将 java.home 设为 d:\j2sdk1.4.2_04 ,但是运行后面的代码的时候会出现“can't open d:\j2sdk1.4.2_04\lib\tzmappings.”的错误,改为 d:\j2sdk1.4.2_04\jre 后就解决了这个问题。
3) 保存php.ini
3、测试环境
查看phpinfo(),一切正常的话,即可显示如下图所示内容:
4、实例测试
以下两个例子摘自PHP MANUAL。
1) Java Example
// get instance of Java class java.lang.System in PHP
$system = new Java('java.lang.System');
// demonstrate property access
print 'Java version='.$system->getProperty('java.version').'
';
print 'Java vendor=' .$system->getProperty('java.vendor').'
';
print 'OS='.$system->getProperty('os.name').' '.
$system->getProperty('os.version').' on '.
$system->getProperty('os.arch').'
';
// java.util.Date example
$formatter = new Java('java.text.SimpleDateFormat',
"EEEE, MMMM dd, yyyy 'at' h:mm:ss a zzzz");
print $formatter->format(new Java('java.util.Date'));
?>
在CGI或CLI中运行上述代码,结果如下:
Java version=1.4.2_04
Java vendor=Sun Microsystems Inc.
OS=Windows 2000 5.0 on x86
星期四, 七月 15, 2004 at 9:00:23 下午 中国标准时间
2) AWT Example
// This example is only intented 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();
?>
运行结果如下图所示,是不是已经勾起你的兴趣了呢?
3) 使用JDBC连接MYSQL
最后我们来演示一个在PHP通过扩展JAVA使用JDBC连接MYSQL数据库的例子。
先从MYSQL的官方网站下个 mysql-connector-java-3.0.14-production.tar.gz ,并解压,笔者是安装在 d:\mysql-connector-java-3.0.14-production 目录下;然后修改 php.ini,在java.class.path一项中加入d:\mysql-connector-java-3.0.14-production\mysql-connector-java-3.0.14-production-bin.jar,至此我们已经安装完成,下面写个打印user数据表中的数据,代码如下:
<?php
$Class = new Java("java.lang.Class");
$Class->forName("com.mysql.jdbc.Driver");
$DriverManager = new Java("java.sql.DriverManager");
$conn = $DriverManager->getConnection("jdbc:mysql://localhost/mysql?user=root");
$stmt = $conn->createStatement();
$res = $stmt->executeQuery("select * from user");
while ($res->next ()) {
echo $res->getString(1);
echo "\n";
}
$res->close();
$stmt->close();
$conn->close();
exit;
?>
待续...