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");
?>

你可能感兴趣的:(java,sql,PHP,mysql,ext)