- 浏览: 70825 次
- 性别:
- 来自: 深圳
最新评论
-
dudong0726:
不错
flex MP3播放器开发二(单歌曲播放) -
三尺寒冰:
楼主能共享一下源代码吗???
flex MP3播放器开发三(进度条显示) -
狂放不羁:
引用 另外 Hibernate 生成的 sql 也实在是太难看 ...
我为什么选择 iBatis 而不是 Hibernate(对于正在选型的人的建议) -
jimzhao:
有一个gif,按你的方法处理了一下,可以动画的时候,中间出现很 ...
imagick 处理 gif 切割 或者是 缩放 -
bigplum:
好东西
imagick 处理 gif 切割 或者是 缩放
平台: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");
?>
首先安装好平台,这个不用多说的。之后去
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");
?>
发表评论
-
我的淘宝群号
2011-05-31 12:40 2500人超级群,.淘宝互刷群,互刷信誉,群号码10461296 ... -
HttpClient 爬数据时 出现部分中文编码问题
2010-09-01 22:30 1308<html> <head> <m ... -
java 邮件群发
2010-08-13 22:38 1160摘 要:邮件群发是消息在Internet传递的最好办法,同时 ... -
关于struts2资源文件在页面动态取值问题
2010-04-20 20:16 972类似<s:text name="$ ... -
使用 XStream 把 Java 对象序列化为 XML
2009-05-21 15:04 973XML 序列化用处很多,包括对象持久化和数据传输。但是一些 X ... -
通过 Axis2 开发 Web 服务,第 1 部分: 通过 Axis2 运行时部署和使用简单 Web
2009-05-20 16:37 864本文介绍 Axis2 的新体系结构,并说明如何通过 Axis2 ... -
Axis2:会话(Session)管理
2009-05-20 16:07 1577WebService给人最直观的感 ... -
AXIS2中OMElement和Java对象之间的转换
2009-05-20 15:46 1459文章有错误,我要报错 ... -
axis2 开发
2009-05-19 22:03 10851,如果是单独开发,。axis2支持pring的装载,具体参见 ... -
Tomcat6下Log4j的log4j:ERROR Failed to rename错误解决办法
2009-05-09 00:25 2160Tomcat6下配置log4j log4j配置到tomca ... -
使用dom4j的xpath解析xlm文件
2009-05-08 21:10 1176package com.njusc.xmlTest; ... -
Java和PHP一致的DES编码
2009-05-08 20:38 1678最近在做一个项目需要实现一个SSO,这个项目是由两个Team共 ... -
java 和 php共享memcached数据注意问题
2009-05-08 20:36 1119在很多时候,一台memcached server中的数据,需要 ... -
hibernate-memcached--在Hibernate中使用Memcached作为...
2009-05-08 20:33 1111今天在网上看到一个用Memcached作为Hibernate二 ... -
dom4j实战(一)——使用dom4j从XML中读取数据源配置
2009-05-08 20:30 961目前XML文件的应用越来越广泛,而操作XML的技术更有不少,其 ... -
Java操作XML文件 dom4j 篇
2009-05-08 11:30 832在项目中,我们很多都用到了xml文件,无论是参数配置还是与其它 ...
相关推荐
当我们需要将已有的Java类或方法整合到PHP项目中时,就需要实现PHP调用JAVA类的功能。下面将详细探讨这一技术实现。 1. **JavaBridge**:PHP调用Java最常用的方法之一是通过JavaBridge,这是一个PHP扩展,允许PHP...
总的来说,选择PHP调用Java类的方式取决于具体需求。如果追求简洁和快速的原型开发,PHP的Java扩展模块可能是个不错的选择。然而,对于需要高性能、稳定性和企业级功能的应用,minij2ee应用服务器和SJOP协议提供了更...
用php-java-bridge配置php调用java类的环境,里面包含了php-java-bridge5.4.5版本,以及我总结的配置方法,我已经配置成功了。官方网站下载的最新php-java-bridge会有点问题。
"php调用java类JavaBridge"就是解决这个问题的一个解决方案。本文将详细探讨PHP通过JavaBridge调用Java类的过程、配置方法以及测试代码的实现。 JavaBridge,全称为PHP/Java Bridge,是一个开源项目,它提供了一种...
本次我们讨论的主题是如何让PHP调用Java编写的加密解密算法。 首先,我们要理解,尽管PHP本身具有一定的加密解密功能,但在某些复杂的加密算法上可能不够强大或者效率不高。例如,Java在加密解密领域广泛使用,并...
php调用java类的方法 需要将java工程打包称jar包之后调用
### PHP调用Java方法介绍 #### 一、背景与需求 在实际开发过程中,有时我们需要在PHP环境中调用Java的方法来实现特定的功能。这可能是由于Java在某些领域(如企业级应用、大数据处理等)拥有更为成熟和高效的解决...
标题中的“PHP调用JAVA的SMS4类tomcat包”涉及到的是在PHP应用程序中通过Java Bridge与Java的SMS4类进行交互,以便实现发送短信的功能。这个过程通常用于Web服务,其中PHP作为前端处理用户请求,而Java后端提供业务...
【PHP调用Java类库】涉及的技术点包括PHP与Java的交互、JavaBridge的使用以及相关的环境配置。本文将详细阐述这些技术要点。 首先,PHP调用Java类库主要是通过PHP Java Bridge(简称JavaBridge)实现的。JavaBridge...
标题为"php调用Java工具",描述中提到由于很多对接接口是Java实现的,且涉及到复杂的签名和加密过程,PHP中重新实现这些功能会相当复杂。因此,通过一个工具来简化这个过程显得尤为重要。 首先,我们需要理解PHP...
JNI允许Java代码调用C/C++编写的本地方法,从而间接实现PHP调用Java。在提供的文件中,“jni”标签可能代表了这一技术的应用。使用JNI需要编写C/C++的桥接代码,将PHP的调用转化为Java方法调用,然后在Java端处理...
在跨语言开发环境中,有时我们需要让PHP调用Java代码来实现特定功能。本篇将详细介绍一种非HTTP桥接的方式——利用`JavaBridge.jar`实现PHP与Java之间的交互。这种方式不仅避免了HTTP请求所带来的额外开销,还能够更...
### Java调用PHP的Webservice知识点详解 #### 一、Webservice简介 Webservice是一种用于不同应用程序之间进行通信的技术标准,通常使用XML作为数据交换格式。它可以被部署在不同的平台上,并且可以使用不同的编程...
通过运行`php调用Java.docx`文档中的步骤,你可以在本地环境中验证PHP调用Java的功能是否正常工作。 总的来说,PHP通过JavaBridge调用Java是一种强大的技术,使得PHP应用能够利用Java的丰富库和服务。通过熟练掌握...
在PHP调用Java Web服务的场景中,通常使用SOAP协议,因为Java的JAX-WS(Java API for XML Web Services)框架提供了SOAP Web服务的实现。PHP可以通过使用SoapClient类来访问SOAP Web服务。以下是一些关键步骤: 1. ...
4.目前的版本是VMBridge了,要php调用java类,要先启动JavaBridge,为了以后启动方便,我在ext/下新建了一个bat文件内容如下: @echo off start javaw -jar JavaBridge.jar 保存后,双击启动 会有一个提示框选择...
2. **Java.inc**:这是一个PHP扩展文件,包含PHP端的接口,用于在PHP代码中调用JavaBridge.jar中的类和方法。 三、集成与使用 在项目中使用PHP-Java-Bridge通常涉及以下步骤: 1. **安装JavaBridge.jar和Java.inc...
有时候,我们需要在PHP项目中利用Java的功能,例如调用一些Java库或者服务,这时就会涉及到PHP调用Java的jar包。本文将深入探讨如何在PHP环境中集成和调用Java的jar包及其依赖。 首先,`composer.json`和`composer....
如果想调用自己的jar包,请把自己的jar包放到jre目录的lib/ext目录中,即扩展目录中,如果jar有依赖和包含,要把相应的jar包都放到这个目录里面,防止产生依赖而找不到类名或文件,造成调用失败。
- 找到R的扩展包目录`\Rserve\java`中的JAR文件(REngine.jar、RserveEngine.jar),并将其添加到Eclipse项目的类路径中。 2. **启动Rserve服务器:** - **Windows环境下**,在R环境中运行以下命令启动: ```R ...