本文说到的是用php-java-bridge技术实现jasperreport web报表的输出。
jasperreport(http://jasperforge.org/),是一个强大、灵活的报表生成工具,能够展示丰富的页面内容,并将之转换成pdf,html,或者xml格式。该库完全由java写成,可以用于在各种java应用程序,包括j2ee,web应用程序中生成动态内容。
附带报表设计工具是ireport(免费的),该工具可以实现可视化报表设计,可以输出pdf,html,word的常用格式报表,保存后的文件为.jrxml后缀,需要java环境才可以正常运行,php不能直接调用。
既然php不能直接调用,这就不得不借助于php-java-bridge技术。具体可以参考http://php-java-bridge.sourceforge.net/pjb/index.php
1、安装tomcat,如果是选择exe安装版,安装的时候会自动安装jre环境,如果是压缩版tomcat,需要另外安装java环境,配置也更繁琐,推荐用安装版的tomcat。
把tomcat的端口配置6000,默认的8080端口被占用,站点根目录为tomcat下面的webapps
2、下载php-java-bridge包,地址http://php-java-bridge.sourceforge.net/pjb/download.php,下载后解压,里面有一个javabridge.war的文件,将这个文件拷贝到tomcat的webapps,运行http://localhost:6000/javabridge/之后,会在webapps生成一个javabridge的目录。
3、安装ireport3.0(有更新的版本) 拷贝c:\program files\jaspersoft\ireport-3.0.0\lib 中的所有内容,拷贝到tomcat的webapps/javabridge/web-inf/lib/下,这些包需要能被javabridge找得到才行。
4、从生成的javabridge目录下拷贝java目录到php站点下(或者找到php.ini这个文件,将里面的allow_url_include参数改为on,直接引用javabridge下的java/java.inc)。下载报表文件http://www.rjohnson.id.au/download/jasper/test.jrxml放在php站点下。
然后在php站点下建立一个php文件
ireport.php(代码中涉及到端口的,需要根据个人情况更改)
view code
1 1024)) ? $_server['server_port'] : '6000'; 13 //echo $port; 14 $port = 6000; 15 if ($sapi_type == cgi || $sapi_type == cgi-fcgi || $sapi_type == cli) 16 { 17 if(!(php_shlib_suffix==so && @dl('java.so'))&&!(php_shlib_suffix==dll && @dl('php_java.dll'))&&!(@include_once(java/java.inc))&&!(require_once(http://127.0.0.1:$port/javabridge/java/java.inc))) 18 { 19 return java extension not installed.; 20 } 21 } 22 else 23 { 24 if(!(@include_once(java/java.inc))) 25 { 26 27 require_once(http://127.0.0.1:$port/javabridge/java/java.inc); 28 } 29 } 30 } 31 if(!function_exists(java_get_server_name)) 32 { 33 return the loaded java extension is not the php/java bridge; 34 } 35 36 return true; 37 } 38 39 /** 40 * convert a php value to a java one... 41 * @param string $value 42 * @param string $classname 43 * @returns boolean success 44 */ 45 function convertvalue($value, $classname) 46 { 47 // if we are a string, just use the normal conversion 48 // methods from the java extension... 49 try 50 { 51 if ($classname == 'java.lang.string') 52 { 53 $temp = new java('java.lang.string', $value); 54 return $temp; 55 } 56 else if ($classname == 'java.lang.boolean' || 57 $classname == 'java.lang.integer' || 58 $classname == 'java.lang.long' || 59 $classname == 'java.lang.short' || 60 $classname == 'java.lang.double' || 61 $classname == 'java.math.bigdecimal') 62 { 63 $temp = new java($classname, $value); 64 return $temp; 65 } 66 else if ($classname == 'java.sql.timestamp' || 67 $classname == 'java.sql.time') 68 { 69 $temp = new java($classname); 70 $javaobject = $temp->valueof($value); 71 return $javaobject; 72 } 73 } 74 catch (exception $err) 75 { 76 echo ( 'unable to convert value, ' . $value . 77 ' could not be converted to ' . $classname); 78 return false; 79 } 80 81 echo ( 'unable to convert value, class name '.$classname. 82 ' not recognised'); 83 return false; 84 } 85 86 87 checkjavaextension(); 88 89 $compilemanager = new javaclass(net.sf.jasperreports.engine.jaspercompilemanager); 90 $report = $compilemanager->compilereport(realpath(test.jrxml)); 91 92 $fillmanager = new javaclass(net.sf.jasperreports.engine.jasperfillmanager); 93 94 $params = new java(java.util.hashmap); 95 $params->put(text, this is a test string); 96 $params->put(number, 3.00); 97 $params->put(date, convertvalue(2007-12-31 0:0:0, java.sql.timestamp)); 98 99 $emptydatasource = new java(net.sf.jasperreports.engine.jremptydatasource);100 $jasperprint = $fillmanager->fillreport($report, $params, $emptydatasource);101 102 $outputpath = realpath(.)./.output.pdf;103 104 $exportmanager = new javaclass(net.sf.jasperreports.engine.jasperexportmanager);105 $exportmanager->exportreporttopdffile($jasperprint, $outputpath);106 107 header(content-type: application/pdf);108 readfile($outputpath);109 110 unlink($outputpath);111 112 ?>
5、访问php站点,http://localhost:8080/ireport.php,就可以输出pdf文档。