摘要:在基於J2EE平台的信息系統中,具有豐富表現能力的Java Applet是界面層的一種重要形式。但Java API對打印的支持比較弱,打印輸出復雜的單據和報表需要大量工作。本文介紹的系統通過引入一個ActiveX控件--Cell插件--來解決這個問題。該系統中,由Java Applet完成界面表現,由Cell插件完成打印輸出,兩者之間通過Sun公司的一套接口API互相通信。
一、Java Applet與Ocx控件的交互
1.1從Java Applet訪問Java Script方法和Ocx控件
Sun公司在JDK中提供了一套從Java Applet訪問Java Script的API,由此可以實現Java Applet訪問HTML頁面中的DOM對象的機制。該API以一個Jar文件的形式提供:%JAVA_HOME%\jre\lib\jaws.jar,其中%JAVA_HOME%是你安裝JDK的目錄。將該jar文件加入到環境變量classpath中,就可以用它實現從Java Applet到Java Script的調用了。下面是一段調用Java Script中的方法的代碼實例:
import netscape.javascript.*;
在上面的代碼中,win.call(“f”, null)調用了JavaScript中的方法f()。
import java.applet.*;
import java.awt.*;
class MyApplet extends Applet {
public void init() {
JSObject win = JSObject.getWindow(this);
JSObject doc = (JSObject) win.getMember("document");
win.call("f", null);
}
}
1.2從JavaScript訪問Java Applet
當使用Java Plugin1.4.x運行Java Applet時,只需把Java Applet中的方法視為Java Plugin這個控件的方法,直接在Java Script中進行調用即可。下面用一個簡單的例子進行說明:
(1) 在載入Java Plugin的Object標簽中,用參數ID指定一個名字:
<OBJECT ID="MyPlunin" WIDTH=500 HEIGHT=120
CLASSID="CLSID:8AD9C840-044E-11d1-B3E9-00805F499D93">
<PARAM NAME="code" value="MyApplet.class">
...
</OBJECT>
(2) 在HTML頁面上增加一個按鈕,點擊它時從Java Script調用Java Applet中的方法:
<input type="button" name="Button1" value="Start"
(3) 假定你的Java Applet是MyApplet.java,它有一個public方法method1(),那麼就可以用如下的Java Script代碼直接調用該方法:
onClick="calculate" language="JavaScript">
<SCRIPT language="JavaScript">
function calculate() {
document.. MyPlunin.method1()
}
</SCRIPT>
二、Cell插件簡介
華表的Cell插件是一個功能非常類似於Excel的、用於Web開發的ActiveX控件。它可以在Windows的浏覽器中顯示、編輯、打印表格。
三、系統實現
3.1 系統架構
圖一
圖一是系統的配置示意圖。由圖可見,這是一個典型的三層應用系統。在本系統中,Java Applet和Cell插件部署在Web Server上,在運行時,它們被下載到客戶端,運行在浏覽器中。
圖二是系統的運行示意圖。由圖可見,運行在客戶機上的Java Applet通過Web Server上的Servlet訪問應用服務器上的EJB,與後台交互。Java Applet作為表示層,在客戶機上顯示界面。
當需要打印輸出時,Java Applet將數據和顯示格式設置到華表插件中,並調用華表插件的打印與覽和打印方法,完成打印功能。
3.2 用Cell插件實現Java界面的打印
3.2.1在HTML頁面上嵌入華表的Cell插件
為了在Applet界面中調用華表的Cell插件,我們首先在HTML頁面上隱藏了一個Cell插件:
<OBJECT classid=clsid:3F166327-8030-4881-8BD2-EA25350E574A
id=DCellWeb1 style="HEIGHT: 0px; WIDTH: 0px">
<PARAM NAME="_Version" VALUE="65536">
<PARAM NAME="_ExtentX" VALUE="14902">
<PARAM NAME="_ExtentY" VALUE="6075">
<PARAM NAME="_StockProps" VALUE="0">
</OBJECT>
通過style="HEIGHT: 0px; WIDTH: 0px"指定Cell插件的高度和寬度都為0,從而達到隱藏Cell插件的目的。
3.2.2 在Applet中提供兩個調用接口方法
下面是一個Applet的代碼實例,其中提供了callCellMethod()和callJavaScriptMethod()兩個接口方法,分別可用來調用Cell插件的方法和JavaScript的方法:
public class MyApplet extends javax.swing.JApplet {
private JSObject win = null;
private JSObject cell = null;
public Object callCellMethod(String name, Object[] params) {
return getCell().call(name, params);
}
public Object callJavaScript(String name, Object[] params) {
return getJSwin().call(name, params);
}
private JSObject getCell() {
if (cell == null) {
try {
JSObject doc = (JSObject)getJSwin().getMember("document");
JSObject all = (JSObject)doc.getMember("all");
cell = (JSObject)all.call("item", new Object[]{"DCellWeb1"});
}
catch (Exception e) {
e.printStackTrace();
}
}
return cell;
}
private netscape.javascript.JSObject getJSwin() {
if (win == null) {
win = netscape.javascript.JSObject.getWindow(this);
}
return win;
}
}
通過getCell()這個方法,可以在Java Applet中直接獲得用JSObject表示的Cell插件,從而可以直接調用它的方法。例如,在Java Applet中向Cell插件的一個單元格寫入數據,可以如下調用:
Integer row = new Integer(1);
Integer column = new Integer(1);
Integer page = new Integer(0);
callCellMethod("SetCellString", new Object[]{column, row, page, “str”});
其中SetCellString是Cell插件提供的接口方法。這樣就實現了從Java Applet到華表的Cell插件的調用。
四、結論
在這個應用系統中,我們只利用Cell插件的打印預覽和打印兩項功能,不用它做屏幕顯示。所有打印格式和數據都在Java Applet中准備好,按單元格向Cell插件設置格式和數據,由Cell插件完成分頁和打印功能。
這是一種表現與數據分離的方式:Java Applet中只組織打印數據,所有打印的表現工作交給Cell插件完成,因此能夠大大降低工作量。
Cell插件除打印功能外,還具有輸入、顯示、編輯、圖表等非常強大的功能,可以制作出非常復雜的報表。利用Cell插件,還可以將數據導出為Excel或PDF等格式的文件。