com.liferay.portal.kernel.jbi.WorkflowComponentException: java.lang.NullPointerException
at com.liferay.portlet.workflow.service.impl.WorkflowComponentServiceImpl.getDefinition(WorkflowComponentServiceImpl.java:113)
"這樣的錯誤,這是本身lifray的BUG,現在基本上都建議大家用mule-web,在lifray配置中jbi.workflow.url默認就是mule了,如果你報的"com.liferay.documentlibrary.DuplicateFileException"這個是因爲在C:\Documents and Settings\User\liferay文件夾刪了,這個文件夾裏面具體是在liferay\jackrabbit\workspace\home\data下面有很多.node.xml的文件,其中一個.node.xml文件裏面有{}0.xml把這一行刪了也可以,最簡單的方法是把整個lifray文件刪了,出現在這個錯誤的要本原因和上面那個錯誤原因是一樣的,表面上看是WorkflowComponentServiceImpl類出了問題,其實是HTTP.URLtoByteArray()方法,client.executeMethod(hostConfig, method, state);在這裏會依次調用http://localhost:8080/servicemix-web/workflow和http://localhost:8082/jbpm-web/servlet在jbpm包中servlet會調用WorkflowComponentImpl.process(HttpServletRequest req),問題就在這個方法裏,req取不出來String cmd = ParamUtil.getString(req, "cmd");所以就會發現每次返回的都是同樣的值,HTTP.URLtoByteArray()方法
if ((parts != null) && (parts.size() > 0)) {
List nvpList = new ArrayList();
Iterator itr = parts.entrySet().iterator();
while (itr.hasNext()) {
Map.Entry entry = (Map.Entry)itr.next();
String key = (String)entry.getKey();
String value = (String)entry.getValue();
if (value != null) {
nvpList.add(new NameValuePair(key, value));
}
}
NameValuePair[] nvpArray = (NameValuePair[])nvpList.toArray(
new NameValuePair[nvpList.size()]);
PostMethod postMethod = (PostMethod)method;
postMethod.setRequestBody(nvpArray);
}
這裏給request正確的賦了值,可是爲什麼到了process()什麼也沒了,找了一兩天也沒有找出爲什麼,後來在官網的論壇上看到說servicemix有缺陷,建議使用mule-web,有興趣的朋友可以找一下爲什麼會出現這樣的問題.
最後總結一句話:"花了五天的時間,就發現了這個,要重頭來過,被BOSS吼了,鬱悶啊!!! :cry: :cry: "