2007年11月9日
錯(cuò)誤信息如下:
java.lang.NoClassDefFoundError: sun.management.ManagementFactory
處理:
把sun.management.ManagementFactory替換成java.lang.management.ManagementFactory
因?yàn)?/span>ibm的jdk沒(méi)有sun.management.ManagementFactory這個(gè)對(duì)象
錯(cuò)誤信息如下:
超過(guò)最大長(zhǎng)度限制
處理:
只能插入666個(gè)中文字符。
或者更新到最新的oracle驅(qū)動(dòng)包
1:derby.jar包可能沖突,需刪除項(xiàng)目中的該包
2:MBean調(diào)用問(wèn)題
Websphere的MBean注冊(cè)路徑包括cell,nodeName和processName,具體可以銅鼓jconsole連接來(lái)查看MBean注冊(cè)的全路徑。這三個(gè)值可以通過(guò)Websphere的com.ibm.websphere.management.AdminServiceFactory這個(gè)對(duì)象來(lái)獲取,spring中的配置如下:
<!--
用于獲取websphere的MBean名稱(chēng)的cell,node,process -->
<bean id="adminService" class="com.ibm.websphere.management.AdminServiceFactory" factory-method="getAdminService"/>
<bean id="adminService.cellName" class="org.springframework.beans.factory.config.PropertyPathFactoryBean"/>
<bean id="adminService.nodeName" class="org.springframework.beans.factory.config.PropertyPathFactoryBean"/>
<bean id="adminService.processName" class="org.springframework.beans.factory.config.PropertyPathFactoryBean"/>
<bean id="websphereNamingStrategy" class="com.des.engine.mbean.WebsphereNamingStrategy">
<property name="cellName" ref="adminService.cellName"/>
<property name="nodeName" ref="adminService.nodeName"/>
<property name="processName" ref="adminService.processName"/>
</bean>
WebsphereNamingStrategy為自己創(chuàng)建的對(duì)象就包括那三個(gè)屬性
3:安全問(wèn)題
出現(xiàn)如下錯(cuò)誤,Caused by: javax.management.JMRuntimeException: ADMN0022E: 由于憑證不足或憑證為空,無(wú)法對(duì) org.apache.servicemix:Name=ServiceMgtImpl,cell=dvpbNode02Cell,Type=SystemService,ContainerName=ServiceMix,node=dvpbNode02,process=server1 MBean 的 retrieveServiceList 操作進(jìn)行訪問(wèn)。
該問(wèn)題是因?yàn)樵O(shè)置了安全控制,把控制臺(tái)的【安全性->安全管理、應(yīng)用程序和基礎(chǔ)結(jié)構(gòu)】里面的所以安全配置都去掉,然后重新啟動(dòng)服務(wù)器主機(jī)(注意是重啟主機(jī),不然安全設(shè)置不起作用),再啟動(dòng)websphere服務(wù)應(yīng)該就可以了,還有就是servicemix的應(yīng)用要跟websphere一起啟動(dòng),不要等websphere啟動(dòng)后再到控制臺(tái)啟動(dòng)
錯(cuò)誤信息如下:
jdbc在操作oracle海量數(shù)據(jù)的時(shí)候用ResultSet獲取所有的返回?cái)?shù)據(jù)出現(xiàn)內(nèi)存溢出
處理:
出錯(cuò)的原因是ResultSet用的是可滾動(dòng)結(jié)果集,正常情況下ResultSet是指針指向數(shù)據(jù)庫(kù)的數(shù)據(jù),本身是不存儲(chǔ)數(shù)據(jù)庫(kù)的數(shù)據(jù)的,默認(rèn)情況下就算是提交的sql能查詢(xún)處上億條的數(shù)據(jù)也是不消耗內(nèi)存的,但是如果用的是可滾動(dòng)結(jié)果集的ResultSet情況就不一樣了,ORACLE 是不支持可滾動(dòng)結(jié)果集的,那么我們用JDBC得到一個(gè)可滾動(dòng)的結(jié)果集就是由JDBC自己支持的,也就是說(shuō)結(jié)果集是要存放在內(nèi)存中的,所以在海量數(shù)據(jù)的情況下也就是要消耗大量?jī)?nèi)存的,因此造成內(nèi)存溢出也就是正常的了,所以如果是海量數(shù)據(jù)的話(huà)就不要用可滾動(dòng)結(jié)果集就可以了。
錯(cuò)誤信息如下:
com.ibm.websphere.ce.cm.StaleConnectionException: [ibm][db2][jcc][t4][2030][11211]
檢測(cè)到了通信錯(cuò)誤。所使用的通信協(xié)議:TCP/IP。"n所使用的通信 API:SOCKETS。
檢測(cè)到錯(cuò)誤的位置:Reply.fill()。"n用于檢測(cè)錯(cuò)誤的通信功能:InputStream.read()。
特定于協(xié)議的錯(cuò)誤代碼數(shù)據(jù)不足、* 和 0。消息:null"n
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)"n
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:67)"n at
sun.reflect.DelegatingConstructorAccessorImpl.newInstance
(DelegatingConstructorAccessorImpl.java:45)"n
at java.lang.reflect.Constructor.newInstance(Constructor.java:522)"n
at com.ibm.websphere.rsadapter.GenericDataStoreHelper.mapExceptionHelper
(GenericDataStoreHelper.java:523)"n
at com.ibm.websphere.rsadapter.GenericDataStoreHelper.mapException(GenericDataStoreHelper.java:578)"n
at com.ibm.ws.rsadapter.jdbc.WSJdbcUtil.mapException(WSJdbcUtil.java:909)"n
at com.ibm.ws.rsadapter.jdbc.WSJdbcStatement.executeQuery(WSJdbcStatement.java:898)"n
at com.newland.bi.util.db.DBUtil.executeQuery(Unknown Source)"n
at com.newland.bi.util.db.DBUtil.executeSql(Unknown Source)"n
at com.newland.bi.dao.jdbc.DaoImpl.executeQuery(DaoImpl.java:64)"n
at com.newland.bi.service.report.exp.dao.ReportExpDao.getExpList(ReportExpDao.java:72)"n
at com.newland.bi.service.report.exp.manage.ReportExpMgt.runExport(ReportExpMgt.java:91)"n
at com.newland.bi.service.report.exp.servlet.ReportExp1Servlet$1.run(ReportExp1Servlet.java:97)"n
at java.util.TimerThread.mainLoop(Timer.java:537)"n at java.util.TimerThread.run(Timer.java:487)"n
處理:
出錯(cuò)的原因可能是防火墻問(wèn)題,在websphere應(yīng)用服務(wù)器和數(shù)據(jù)庫(kù)服務(wù)器之間是否存在防火墻
防火墻是否會(huì)設(shè)置多久沒(méi)活動(dòng)的連接就自動(dòng)斷開(kāi)掉,如果是這樣的話(huà)就會(huì)有問(wèn)題,因?yàn)?/span>websphere上面的數(shù)據(jù)庫(kù)連接池可能有一段時(shí)間沒(méi)連接而被防火墻斷掉了
但對(duì)于連接池本身根本就不知道該連接是否還可用,所以web應(yīng)用從連接池獲取的連接可能就是已經(jīng)斷開(kāi)的了,所以就可能會(huì)出現(xiàn)日記中的錯(cuò)誤問(wèn)題
schedule和scheduleAtFixedRate的區(qū)別在于,如果指定開(kāi)始執(zhí)行的時(shí)間在當(dāng)前系統(tǒng)運(yùn)行時(shí)間之前,scheduleAtFixedRate會(huì)把已經(jīng)過(guò)去的時(shí)間也作為周期執(zhí)行,而schedule不會(huì)把過(guò)去的時(shí)間算上。
錯(cuò)誤信息如下:
Caused by: java.lang.ClassNotFoundException: org.apache.axis.soap.MessageFactoryImpl
at java.net.URLClassLoader$1.run(URLClassLoader.java:200)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:188)
at java.lang.ClassLoader.loadClass(ClassLoader.java:306)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:268)
at java.lang.ClassLoader.loadClass(ClassLoader.java:251)
at javax.xml.soap.MessageFactory.newInstance(MessageFactory.java:50)
... 10 more
處理:
原因是調(diào)用了axis的 soap.MessageFactoryImpl,cxf應(yīng)該用的是sun的
在注冊(cè)安全攔截器之前執(zhí)行下面代碼就可以了
System.setProperty("javax.xml.soap.MessageFactory", "com.sun.xml.messaging.saaj.soap.ver1_1.SOAPMessageFactory1_1Impl");
我們寫(xiě)程序的時(shí)候可能會(huì)想用open或者<a>來(lái)下載一個(gè)txt文件,但我們會(huì)發(fā)現(xiàn)我們用瀏覽器下載這個(gè)txt文件的時(shí)候老是在瀏覽器里面直接打開(kāi)了,而不是提示下載,這樣的話(huà)如果txt文件的內(nèi)容非常多的話(huà)肯定是不行的,可能就會(huì)導(dǎo)致瀏覽器掛掉,客戶(hù)機(jī)器死機(jī)的問(wèn)題
現(xiàn)整理了個(gè)解決辦法,代碼如下:
1.下載頁(yè)面
open(action執(zhí)行頁(yè)面,'iframeName','');
2.action執(zhí)行頁(yè)面
<a id="tempB" style="display:none" href="#" onclick=""> </a>
<iframe width=0 height=0 id="hideIframe" name="hideIframe"></iframe>

<script>
var n=0;

function go(url)
{
n==0?new function()

{
frames("hideIframe").location=url,n=1
}:null;
document.all("hideIframe").readyState!="complete"?setTimeout(go,10):so();
function so()

{
frames("hideIframe").document.execCommand("SaveAs"),n=0
};
}
var tempB = document.getElementById("tempB");
<%

if(path.toLowerCase().indexOf(".txt")>=0)
{
%>

tempB.attachEvent('onclick',function()
{go('<%=request.getContextPath()+"/tempfile/1.txt">');});
<%

}else
{
%>

tempB.attachEvent('onclick',function()
{open('<%=request.getContextPath()+"/tempfile/1.xls">','','');});
<%
}
%>
tempB.click();
</script>
websphere部署war應(yīng)用失敗正常原因是web.xml的節(jié)點(diǎn)定義循序問(wèn)題,或者一些空格,字符原因造成的
可能先定義完所有的servlet后再定義所有的servlet mapping就沒(méi)問(wèn)題了
那個(gè)轉(zhuǎn)向后的頁(yè)面已經(jīng)有用gb2312的編碼了
可能原因是在java類(lèi)里面調(diào)用了((HttpServletResponse)FacesContext.getCurrentInstance().getExternalContext().getResponse()).getWriter().write("");
然后再轉(zhuǎn)向某個(gè)頁(yè)面,這樣可能導(dǎo)致編碼格式?jīng)_突,導(dǎo)致亂碼
可以先給resonse設(shè)置下編碼格式,然后在write
HttpServletResponse httpServletResponse = (HttpServletResponse)FacesContext.getCurrentInstance().getExternalContext().getResponse();
httpServletResponse.setContentType("text/html; charset=gb2312");
httpServletResponse.setCharacterEncoding("gb2312");
httpServletResponse.getWriter().write("");
這樣應(yīng)該就可以解決了
C:\Program Files\IBM\WebSphere\AppServer\profiles\AppSrv01\config\cells\app-bi2Node01Cell\applications\appname.ear\deployments\appname\appname.war\WEB-INF\web.xml 該目錄下的web.xml的修改才是有效
應(yīng)用程序發(fā)布的目錄下的那個(gè)web.xml添加的servlet配置是無(wú)效的
可能原因:
1: form表單中的控件沒(méi)有定義name屬性
2: form表單中的控件被設(shè)置成disabled
3: form表單的enctype="multipart/form-data"是一種用于上傳文件的表單
|
解決方法:
對(duì)于第三種情況我們直接request.getParameter來(lái)取參數(shù)值是取不到的
我們可以借用apache的上傳組件來(lái)解決
用到jar包commons-fileupload-1.1.1.jar
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileItemFactory;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import
org.apache.commons.fileupload.servlet.ServletFileUpload;
/**
*獲取各種類(lèi)型表單的表單參數(shù)
*@paramrequest HttpServletRequest請(qǐng)求對(duì)像
* @paramparamName 參數(shù)名
*@return
*@throwsFileUploadException
*/
publicstatic String
getParameterValue(HttpServletRequest request,String paramName) throws
FileUploadException{
boolean
isMultipart = ServletFileUpload.isMultipartContent(request);
if(isMultipart==true){
FileItemFactory
factory = new DiskFileItemFactory();
ServletFileUpload
upload = new ServletFileUpload(factory);
List
fileItemList = upload.parseRequest(request);
if(fileItemList!=null){
for(Iterator itr=fileItemList.iterator();itr.hasNext();){
FileItem fileItem = (FileItem)itr.next();
if(fileItem.getFieldName().equalsIgnoreCase(paramName)){
return new
String(fileItem.getString().getBytes("ISO8859-1"))//中文轉(zhuǎn)碼
}
}
}
}else{
return new String(request.getParameter(paramName).getBytes("ISO8859-1"))//中文轉(zhuǎn)碼
}
return"";
}
|
1.定義一個(gè)標(biāo)簽要用到兩個(gè)java類(lèi),這個(gè)跟jsp的自定義標(biāo)簽有點(diǎn)不一樣
第一個(gè)類(lèi)繼承UIComponentTag, 用于定義標(biāo)簽的屬性和設(shè)置標(biāo)簽的所有屬性值到控件的map屬性attributes或valueBinding中
第二個(gè)類(lèi)繼承UIInput或者UIOutput,用于渲染標(biāo)簽的內(nèi)容,真正打印標(biāo)簽內(nèi)容的地方就在這里
2.這兩個(gè)類(lèi)是怎么聯(lián)系的
我們需要像定義jsf的bean的影射文件一樣,在faces-config.xml或者自己定義的xml文件里面定義第二個(gè)類(lèi)
如:
<faces-config>
<!--分頁(yè)標(biāo)簽-->
<component>
<component-type>pageTag</component-type>
<component-class>com.jsf.PageComponent</component-class>
</component>
</faces-config>
然后第一個(gè)類(lèi)要實(shí)現(xiàn)父類(lèi)的一個(gè)方法 public String getComponentType();從這里返回一個(gè)字符串pageTag,這樣就跟第二個(gè)類(lèi)聯(lián)系起來(lái)了

3.標(biāo)簽屬性的定義
標(biāo)簽屬性的定義一般都是可轉(zhuǎn)化為字符串的類(lèi)型的,除非你還是用<%=rowList%>這種jsp賦值的方式
別以為你定義的一個(gè)List類(lèi)型的屬性可以用jsf的EL表達(dá)式可以直接賦值進(jìn)來(lái),EL表達(dá)式傳進(jìn)來(lái)以后屬性接收的就是這一串EL表達(dá)式
所以就是說(shuō)你的屬性就是要字符串類(lèi)型的

4.那么jsf自定義標(biāo)簽是怎么接收EL表達(dá)式綁定的列表的
先通過(guò)父類(lèi)的isValueReference(屬性值),來(lái)判斷該屬性的值是否是一個(gè)EL的表達(dá)式
如果是則通過(guò)獲取綁定值得方式把真正的屬性的值設(shè)置到標(biāo)簽父類(lèi)的valueBinding對(duì)像中
否則直接把屬性的值添加到標(biāo)簽父類(lèi)的attributes對(duì)像中
if (isValueReference(屬性值)) {
javax.faces.el.ValueBinding vb = Util.getValueBinding(value.toString());
component.setValueBinding(name, vb); //component就是標(biāo)簽對(duì)像,name就是標(biāo)簽的屬性名稱(chēng)
} else {
component.getAttributes().put(name, 屬性值);
}
這就是個(gè)設(shè)置屬性值的過(guò)程,可以在第1點(diǎn)說(shuō)的第一個(gè)類(lèi)里面的protected void setProperties(UIComponent component)方法
5.現(xiàn)在知道標(biāo)簽屬性值的作用了嗎
是的標(biāo)簽屬性值只不過(guò)是起個(gè)作用而已,而不是我們真正所要的值
也就是說(shuō)我們是不能從這些屬性中直接取值的
6.那么我們?cè)趺慈傩缘恼嬲闹的?br />
可以先從第4點(diǎn)說(shuō)的標(biāo)簽父類(lèi)的attributes對(duì)像中取值
如果取不到值那就到標(biāo)簽父類(lèi)的valueBinding對(duì)像中取值
說(shuō)白了就是,通過(guò)第4步我們屬性的真正的值不是放在attributes就是在valueBinding中
Object obj = component.getAttributes().get(name); //component就是標(biāo)簽對(duì)像,name就是標(biāo)簽的屬性名稱(chēng)
if (obj == null) {
ValueBinding vb = component.getValueBinding(name);
if (vb != null) {
return vb.getValue(context);
} else {
return null;
}
}
這個(gè)過(guò)程就是取屬性值的過(guò)程,在第1點(diǎn)說(shuō)的第二個(gè)類(lèi)里面進(jìn)行
7.現(xiàn)在屬性值也可以取到了,那么我們要怎么打印標(biāo)簽的內(nèi)容呢
我們可以在第二個(gè)類(lèi)的encodeBegin或者encodeEnd中進(jìn)行
public void encodeBegin(FacesContext context) throws IOException
public void encodeEnd(FacesContext context) throws IOException
取屬性值的過(guò)程也可以在這里進(jìn)行,取完值后就是把值組裝到標(biāo)簽內(nèi)容的相應(yīng)位置中就完了
基本上就是這幾點(diǎn)

在本地tomcat5中這樣沒(méi)問(wèn)題
request.getRealPath("/")+"report/config/configFile/"+priv_id+".xml"
但是發(fā)布到websphere6后就出問(wèn)題了
要改成
request.getRealPath("/")+"/report/config/configFile/"+priv_id+".xml"
就是report前要加個(gè)"/" 斜杠,加了后tomcat5下也是正確的