博客首页 | 排行榜 |

天水一方

即日起我的官方博客迁往http://www.kokkowon.cn/ 欢迎光临!!!

个人档案
博文分类
PHP5中调用Java类  2007-01-17 14:23
平台: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


结果如下:
Java version=1.5.0_09
Java vendor=Sun Microsystems Inc.
OS=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内容如下:



运行结果
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


输出:test tes test tst test test tes test tst test
|
上一篇:Can you help me? | 下一篇:日本的服装模特
以下网友评论只代表其个人观点,不代表本网站的观点或立场