OpenCms文件導(dǎo)入過(guò)程初探
發(fā)表時(shí)間:2024-02-16 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]在OpenCms的安裝過(guò)程中有一個(gè)文件導(dǎo)入的過(guò)程。由于工作原因,本人對(duì)這個(gè)導(dǎo)入過(guò)程做了點(diǎn)研究。有點(diǎn)收獲寫出來(lái)和大家共享。在系統(tǒng)中安裝過(guò)程是通過(guò)run_import.jsp文件(該文件位于sourcpath1\opencms_src_5.0.1\opencms\web\ocsetup)觸發(fā)的。在該頁(yè)...
在OpenCms的安裝過(guò)程中有一個(gè)文件導(dǎo)入的過(guò)程。由于工作原因,本人對(duì)這個(gè)導(dǎo)入過(guò)程做了點(diǎn)研究。有點(diǎn)收獲寫出來(lái)和大家共享。
在系統(tǒng)中安裝過(guò)程是通過(guò)run_import.jsp文件(該文件位于sourcpath1\opencms_src_5.0.1\opencms\web\ocsetup)觸發(fā)的。在該頁(yè)中她使用了
<frameset rows="100%,*">
<frame src="display_import.jsp" name="display">
<frame src="about:blank" name="data">
</frameset>
這樣的結(jié)構(gòu)來(lái)完成導(dǎo)入和顯示的功能。看到name為display很容易猜想他是用來(lái)向用戶顯示處理結(jié)果的,name 為data 的frame肯定是用來(lái)處理文件導(dǎo)入的了。這只是猜想,具體如何還有待證實(shí)。下面我們就去看看display_import.jsp這個(gè)文件。
在display_import.jsp服務(wù)端基本沒(méi)有什么處理,客戶端的處理倒是不少。這一句<body <% if(setupOk){ out.print("onload='enable();'");} %>>倒是很重要。我們先來(lái)看看enable()這個(gè)函數(shù)。
/* indicates if the document has been loaded */
function enable() {
enabled = true;
parent.data.location.href="data_import.jsp";
document.forms[0].info.value = message;
}
在這個(gè)函數(shù)中有parent.data.location.href="data_import.jsp";這一句。他把name 為data 的frame的location.href設(shè)為"data_import.jsp"。從文件名來(lái)看應(yīng)該是由該文件處理文件的導(dǎo)入工作。到底是不是,我們進(jìn)去看看。
在data_import.jsp頁(yè)面中除了有個(gè)com.opencms.boot.CmsSetup的session范圍的JavaBean外還有一個(gè)com.opencms.boot.CmsSetupThread的session范圍的JavaBean。那么這個(gè)CmsSetupThread到底是什么玩意。去看源碼吧!
package com.opencms.boot;
import java.io.File;
import java.io.IOException;
import java.io.PipedOutputStream;
import java.io.PrintStream;
// CmsSetupThread是一個(gè)線程。
public class CmsSetupThread extends Thread {
public void run() {
/* save the original out and err stream */
m_tempOut = System.out;
m_tempErr = System.err;
/* redirect the streams */
System.setOut(new PrintStream(m_pipedOut));
System.setErr(new PrintStream(m_pipedOut));
/* start the logging thread */
m_lt.start();
/* start importing the workplace */
CmsMain.startSetup(basePath + "WEB-INF/ocsetup/cmssetup.txt", basePath + "WEB-INF/");
/* stop the logging thread */
try {
sleep(1000);
m_lt.stopThread();
m_pipedOut.close();
}
catch (InterruptedException e) {
m_lt.stopThread();
e.printStackTrace(m_tempErr);
}
catch (IOException e) {
m_lt.stopThread();
e.printStackTrace(m_tempErr);
}
/* restore to the old streams */
System.setOut(m_tempOut);
System.setErr(m_tempErr);
}
… …… ……
}
從上面的代碼中的public void run() 方法中可以看出系統(tǒng)的確用該類來(lái)處理文件導(dǎo)入的工作。主要分為一下幾個(gè)步驟來(lái)完成。這里就驗(yàn)證了我們前面name為display的frame向用戶顯示處理結(jié)果的,name 為data 的frame來(lái)處理文件導(dǎo)入的猜想。。
1、 備份系統(tǒng)的標(biāo)準(zhǔn)輸出和系統(tǒng)的錯(cuò)誤輸出
m_tempOut = System.out;
m_tempErr = System.err;
2、 將系統(tǒng)輸出重新定向到一個(gè)PipedOutputStream實(shí)例(instance)
System.setOut(new PrintStream(m_pipedOut));
System.setErr(new PrintStream(m_pipedOut));
這樣一來(lái)說(shuō)有的系統(tǒng)輸出都會(huì)定向到m_pipedOut到這個(gè)對(duì)象上來(lái)了。要顯示處理信息只需要處理是用System.out.println()之類方法打印出來(lái)。在前面讀取m_pipedOut就可以了。是不是這樣實(shí)現(xiàn)還有待證實(shí)。
3、 啟動(dòng) CmsSetupLoggingThread 線程;
4、 開(kāi)始導(dǎo)入工作。有代碼為證
/* start importing the workplace */
CmsMain.startSetup(basePath + "WEB-INF/ocsetup/cmssetup.txt", basePath + "WEB-INF/");
5、 停止CmsSetupLoggingThread 線程。
6、 還原系統(tǒng)的標(biāo)準(zhǔn)輸出和系統(tǒng)的錯(cuò)誤輸出。
下面就是還不清楚CmsSetupLoggingThread到底是什么玩意。通過(guò)查看源碼可以發(fā)現(xiàn)他就是用來(lái)收集CmsSetupThread線程的處理信息的。并且就是通過(guò)PipedOutputStream來(lái)完成這兩個(gè)線程的通信。這一點(diǎn)可以從他的構(gòu)造函數(shù)知道。
public CmsSetupLoggingThread(PipedOutputStream pipedOut) {
messages = new Vector();
m_stopThread = false;
try {
m_pipedIn = new PipedInputStream();
m_pipedIn.connect(pipedOut);
m_LineReader = new LineNumberReader(new BufferedReader(new InputStreamReader(m_pipedIn)));
}
catch (Exception e) {
messages.addElement(e.toString());
}
}
為了方便jsp頁(yè)面方便的得到這些信息CmsSetupLoggingThread還特地提供了一個(gè)private static Vector messages;和靜態(tài)的getMessages()方法來(lái)處理他。這一點(diǎn)在data_import.jsp中的
messages = com.netmarch.infopub.pubServletCon.LogginThread.getMessages();語(yǔ)句可以得到驗(yàn)證。最后messages通過(guò)
<script language="Javascript">
var output = new Array();
<% for(int i = 0; i < (size-offset) ;i++) {
out.println("output[" + i + "] = \"" + messages.elementAt(i+offset).toString() + "\";");
}
%>
function send() {
parent.display.start(output);
}
</script>傳到客戶端。完成了處理信息的顯示。
我寫的是我的知道的,我還很菜。歡迎高手指出我的錯(cuò)誤。我的E-mail是jetgeng@hotmail.com 謝謝。
注 1、cms的源碼在http://www.opencms.org/opencms/en/download/opencms.html處下載。Sourcpath是你下載OpenCms 5.0.1 Source Distribution解壓后的目錄。