この記事では、PHP-Java-Bridge テクノロジを使用して JasperReport Web レポートの出力を実現する方法について説明します。
JasperReport (http://jasperforge.org/) は、豊富なページ コンテンツを表示し、PDF、HTML、または XML 形式に変換できる、強力で柔軟なレポート生成ツールです。このライブラリは完全に Java で書かれており、J2EE や Web アプリケーションを含むさまざまな Java アプリケーションで動的コンテンツを生成するために使用できます。
付属のレポート設計ツールは 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. http://php-java- で php-java-bridge パッケージをダウンロードします。 Bridge.sourceforge .net/pjb/download.php をダウンロードして解凍すると、中に JavaBridge.war ファイルが含まれています。 http://localhost:6000/JavaBridge/ を実行すると、JavaBridge が作成されます。 webappディレクトリに生成されます。
3. ireport3.0 をインストールします (更新バージョンがあります)。C:Program FilesJasperSoftiReport-3.0.0lib の内容をすべて 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 サイト
ireport.php の下に PHP ファイルを作成します (コードにはポートが含まれているため、個人の状況に応じて変更する必要があります)
コードを表示する
1 <?php 2 3 /** 4 * see if the java extension was loaded. 5 */ 6 function checkJavaExtension() 7 { 8 if(!extension_loaded('java')) 9 { 10 $sapi_type = php_sapi_name(); 11 12 //$port = (isset($_SERVER['SERVER_PORT']) && (($_SERVER['SERVER_PORT'])>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文書を出力できます。