PHP5中调用Java类

平台:Windows xp + apache2.0 + PHP 5.1 + jdk1.5
首先安装好平台,这个不用多说的。之后去
http://sourceforge.net/project/showfiles.php?group_id=117793&package_id =170256&release_id=475534下载一个php-java-bridge连接桥。解压php-java-bridge- 3.0.8_j2ee之后,将目录下面的JavaBridge.war更名为JavaBridge.jar,解压JavaBridge.jar,将 JavaBridge\WEB-INF\cgi目录下的java-x86-windows.dll拷贝到php扩展目录(我的是c:\php\ext目录),重命名为php_java.dll,将JavaBridge\WEB-INF\lib\JavaBridge.jar也拷贝到php扩展目录。

配置php.ini文件
在Windows Extensions段添加如下内容。(我的加在;extension=php_mbstring.dll前面)
extension=php_java.dll
[Java]
java.class.path = "C:\php\ext\JavaBridge.jar;e:\www\java"
java.java_home = "C:\jdk1.5.0_09"
java.library.path = "c:\php\ext;e:\www\java"

重启apache服务器

创建test.php
header("content-type:text/html; charset=utf-8");
// 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'));
?>

结果如下:
Java version=1.5.0_09
Java vendor=Sun Microsystems Inc.
S=Windows XP 5.1 on x86
[o(String):"星期三, 一月 17, 2007 at 2:18:58 下午 中国标准时间"]

使用自己的java类(test.java)
public class test
{

public String rsStr;
public static void main(String[] args)
{
System.out.println("Hello World!");
}
public void setString( String param ){
if( param.equals("") ) {
rsStr = "Hello,how are you!";
}else{
rsStr = param;
}
}

public String getString(){
return rsStr;
}
}
编译test.java,将test.class复制到java.class.path(我这里是e:\www\java)目录下,创建test.php内容如下:

java_require( 'e:\www\java' );
$myj = new Java("test");

$myj->setString("");
$str = $myj->getString();
echo $str."
";
$str = $myj->rsStr;
echo $str."
";
?>

运行结果:
Hello,how are you!
Hello,how are you!

使用php调用java的jdbc操作mysql数据库
首先去www.mysq.com下载一个jdbc驱动,解压驱动,将驱动拷贝到java.class.path(我这里是e:\www\java)目录下
编写数据库查询类SqldbConn.java
import java.sql.*;
/*
* SqldbConn.java
*
* Created on 2007年1月17日, 下午3:48
*
* To change this template, choose Tools | Template Manager
* and open the template in the editor.
*
* 说明:数据库连接类,数据库对象连接,SQL查询!
*/

/**
*
* @author Administrator
*/
public class SqldbConn {
private String driver = "org.gjt.mm.mysql.Driver";
private String url = "jdbc:mysql://localhost:3306/db_mydb";
private String userName = "root";
private String userPassword = "1314521";

private Connection conn = null;
private Statement stmt = null;
private ResultSet rs = null;

/** Creates a new instance of testdb */
public SqldbConn() {
}

/**
* 设置链接
* @param String url:数据库连接
*/
public void setUrl( String url ){
this.url = url;
}//end

/**
* 设置连接用户名
* @param String username:用户名
*/
public void setUserName( String username ){
this.userName = username;
}//end

/**
* 设置连接密码
* @param String password:用户密码
*/
public void setUserPassword( String password ){
this.userPassword = password;
}//end

/**
* 初始化数据库连接
*/
public void init(){
//get Connection
try{
Class.forName( this.driver );
conn = DriverManager.getConnection( url,userName,userPassword );
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
}catch(ClassNotFoundException ex){
System.out.println("装载 JDBC/ODBC 驱动程序失败。");
System.exit(0);
}catch(SQLException ex){
System.out.println("无法连接数据库");
System.exit(0);
}//end try catch
}//end

/**
* 执行sql Select语句并返回结果
* @param String Sql:Sql语句
*/
public ResultSet query(String sql){
this.rs = null;
if( this.conn.equals(null)){
init();
}//end
try{
this.rs = this.stmt.executeQuery(sql);
}catch( SQLException ex){
System.out.println( sql+"查询失败" );
System.exit(0);
}
return rs;
}//end

/**
* 执行修改,删除添加语句
* @param String sql:sql语句
*/
public boolean execute(String sql){
if( this.conn.equals(null)){
init();
}//end
try
{
stmt.executeUpdate(sql);
return true;
}
catch(SQLException e)
{
System.out.print("Update:"+e.getMessage());
return false;
}
}//end

/**
* 关闭数据库连接
*/
public void closse(){
this.conn = null;
this.rs = null;
this.stmt = null;
}
}


调用类MainIn.java
import java.sql.*;
/*
* MainIn.java
*
* Created on 2007年1月17日, 下午5:12
*
* To change this template, choose Tools | Template Manager
* and open the template in the editor.
*/

/**
*
* @author Administrator
*/
public class MainIn {

/** Creates a new instance of MainIn */
public SqldbConn db;
public String str;

public MainIn() {
getSqlConn();
}

/**
* 取得数据库连接对象
*/
public void getSqlConn(){
this.db = new SqldbConn();
db.init();
}//end

public String getRs( String sql,String cuname ){
try{
ResultSet rs = this.db.query(sql);
while( rs.next() ){
str += rs.getString(cuname)+"\n";
}
}catch( SQLException ex ){
System.out.print( sql+"查询失败失败!" );
str = null;
}
return str;
}

public static void main(String []args){
MainIn mainin = new MainIn();
String sql = "SELECT * FROM test LIMIT 100";
String s = mainin.getRs(sql,"name");
System.out.print(s);
}

}
将以上两个类文件编译并拷贝到java.class.path(我这里是e:\www\java)目录下

创建test.php
java_require( 'e:\www\java' );
$myj = new Java("MainIn");
echo $myj->getRs("SELECT * FROM test LIMIT 10","name");
?>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值