程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> Cell插件在J2EE系統中的應用

Cell插件在J2EE系統中的應用

編輯:關於JAVA

摘要:在基於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.*;
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);
}
}
在上面的代碼中,win.call(“f”, null)調用了JavaScript中的方法f()。

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"
onClick="calculate" language="JavaScript">
(3) 假定你的Java Applet是MyApplet.java,它有一個public方法method1(),那麼就可以用如下的Java Script代碼直接調用該方法:

<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等格式的文件。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved