`
wxw850227
  • 浏览: 70825 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

PHP5中调用Java类

    博客分类:
  • 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");
?>

分享到:
评论

相关推荐

    php调用JAVA类

    当我们需要将已有的Java类或方法整合到PHP项目中时,就需要实现PHP调用JAVA类的功能。下面将详细探讨这一技术实现。 1. **JavaBridge**:PHP调用Java最常用的方法之一是通过JavaBridge,这是一个PHP扩展,允许PHP...

    PHP调用java类的两种方法

    总的来说,选择PHP调用Java类的方式取决于具体需求。如果追求简洁和快速的原型开发,PHP的Java扩展模块可能是个不错的选择。然而,对于需要高性能、稳定性和企业级功能的应用,minij2ee应用服务器和SJOP协议提供了更...

    php调用java类

    用php-java-bridge配置php调用java类的环境,里面包含了php-java-bridge5.4.5版本,以及我总结的配置方法,我已经配置成功了。官方网站下载的最新php-java-bridge会有点问题。

    php调用java类JavaBridge

    "php调用java类JavaBridge"就是解决这个问题的一个解决方案。本文将详细探讨PHP通过JavaBridge调用Java类的过程、配置方法以及测试代码的实现。 JavaBridge,全称为PHP/Java Bridge,是一个开源项目,它提供了一种...

    php调用java方法.pdf

    本次我们讨论的主题是如何让PHP调用Java编写的加密解密算法。 首先,我们要理解,尽管PHP本身具有一定的加密解密功能,但在某些复杂的加密算法上可能不够强大或者效率不高。例如,Java在加密解密领域广泛使用,并...

    php调用java jar包

    php调用java类的方法 需要将java工程打包称jar包之后调用

    php调用java方法介绍

    ### PHP调用Java方法介绍 #### 一、背景与需求 在实际开发过程中,有时我们需要在PHP环境中调用Java的方法来实现特定的功能。这可能是由于Java在某些领域(如企业级应用、大数据处理等)拥有更为成熟和高效的解决...

    PHP调用JAVA的SMS4类tomcat包

    标题中的“PHP调用JAVA的SMS4类tomcat包”涉及到的是在PHP应用程序中通过Java Bridge与Java的SMS4类进行交互,以便实现发送短信的功能。这个过程通常用于Web服务,其中PHP作为前端处理用户请求,而Java后端提供业务...

    PHP调用Java类库

    【PHP调用Java类库】涉及的技术点包括PHP与Java的交互、JavaBridge的使用以及相关的环境配置。本文将详细阐述这些技术要点。 首先,PHP调用Java类库主要是通过PHP Java Bridge(简称JavaBridge)实现的。JavaBridge...

    php调用Java工具

    标题为"php调用Java工具",描述中提到由于很多对接接口是Java实现的,且涉及到复杂的签名和加密过程,PHP中重新实现这些功能会相当复杂。因此,通过一个工具来简化这个过程显得尤为重要。 首先,我们需要理解PHP...

    php调用java的代码

    JNI允许Java代码调用C/C++编写的本地方法,从而间接实现PHP调用Java。在提供的文件中,“jni”标签可能代表了这一技术的应用。使用JNI需要编写C/C++的桥接代码,将PHP的调用转化为Java方法调用,然后在Java端处理...

    php调用java,不是http桥接

    在跨语言开发环境中,有时我们需要让PHP调用Java代码来实现特定功能。本篇将详细介绍一种非HTTP桥接的方式——利用`JavaBridge.jar`实现PHP与Java之间的交互。这种方式不仅避免了HTTP请求所带来的额外开销,还能够更...

    Java调用php的webservice

    ### Java调用PHP的Webservice知识点详解 #### 一、Webservice简介 Webservice是一种用于不同应用程序之间进行通信的技术标准,通常使用XML作为数据交换格式。它可以被部署在不同的平台上,并且可以使用不同的编程...

    PHP通过javabridge6.2.1调用 Java的说明及源代码(可运行)

    通过运行`php调用Java.docx`文档中的步骤,你可以在本地环境中验证PHP调用Java的功能是否正常工作。 总的来说,PHP通过JavaBridge调用Java是一种强大的技术,使得PHP应用能够利用Java的丰富库和服务。通过熟练掌握...

    php调用java写的webservice

    在PHP调用Java Web服务的场景中,通常使用SOAP协议,因为Java的JAX-WS(Java API for XML Web Services)框架提供了SOAP Web服务的实现。PHP可以通过使用SoapClient类来访问SOAP Web服务。以下是一些关键步骤: 1. ...

    php-java-bridge 配置包

    4.目前的版本是VMBridge了,要php调用java类,要先启动JavaBridge,为了以后启动方便,我在ext/下新建了一个bat文件内容如下: @echo off start javaw -jar JavaBridge.jar 保存后,双击启动 会有一个提示框选择...

    php-java-bridge_7.2.1_documentation.zip

    2. **Java.inc**:这是一个PHP扩展文件,包含PHP端的接口,用于在PHP代码中调用JavaBridge.jar中的类和方法。 三、集成与使用 在项目中使用PHP-Java-Bridge通常涉及以下步骤: 1. **安装JavaBridge.jar和Java.inc...

    php调用jar包依赖包

    有时候,我们需要在PHP项目中利用Java的功能,例如调用一些Java库或者服务,这时就会涉及到PHP调用Java的jar包。本文将深入探讨如何在PHP环境中集成和调用Java的jar包及其依赖。 首先,`composer.json`和`composer....

    php代码使用javaBridge调用java代码,调用jar包里面的类和方法

    如果想调用自己的jar包,请把自己的jar包放到jre目录的lib/ext目录中,即扩展目录中,如果jar有依赖和包含,要把相应的jar包都放到这个目录里面,防止产生依赖而找不到类名或文件,造成调用失败。

    Java调用R语言的方法

    - 找到R的扩展包目录`\Rserve\java`中的JAR文件(REngine.jar、RserveEngine.jar),并将其添加到Eclipse项目的类路径中。 2. **启动Rserve服务器:** - **Windows环境下**,在R环境中运行以下命令启动: ```R ...

Global site tag (gtag.js) - Google Analytics