我在使用worklight和多线程方面遇到了一些问题。
我们有一个需要每天运行一次的批量导入器 到目前为止我们做了什么
除了调用HTTP适配器之外,代码中的所有内容都能正常工作。每次调用适配器时,都会返回错误消息“BaseProjectLocal为null”。 如果它由另一个worklight适配器启动,代码可以正常工作。
似乎错误存在,因为他不知道如何访问适配器(我假设)
java.lang.RuntimeException: BaseProjectLocal is null
at com.worklight.common.util.BaseProjectLocal.get(BaseProjectLocal.java:41)
at com.worklight.server.util.ProjectLocal.get(ProjectLocal.java:55)
at com.worklight.server.util.ProjectLocal.getWorklightBundlesS(ProjectLocal.java:113)
at com.worklight.server.bundle.api.WorklightBundles.getInstance(WorklightBundles.java:28)
at com.ibm.nl.wwdw.server.util.AdapterCaller.doCall(AdapterCaller.java:25)
at com.ibm.nl.wwdw.server.connections.CommunityCollector.getMembersFromCommunity(CommunityCollector.java:50)
at com.ibm.nl.wwdw.server.importer.ConnectionsImporter.StartImport(ConnectionsImporter.java:53)
at com.ibm.nl.wwdw.server.importer.MyJob.execute(MyJob.java:17)
at org.quartz.core.JobRunShell.run(JobRunShell.java:202)
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:573)
2-jun-2014 17:38:56 com.ibm.nl.wwdw.server.importer.ConnectionsImporter StartImport 严重:BaseProjectLocal为空
调用适配器的Java代码
public static JSONObject doCall(String adapter, String path, String paramArray) {
Logging.logger.warning(adapter+"/"+path+"?"+paramArray);
DataAccessService service = WorklightBundles.getInstance().getDataAccessService();//This line gives the error report
ProcedureQName procedureQName = new ProcedureQName(adapter, path);
InvocationResult result = service.invokeProcedure(procedureQName, paramArray);
Logging.logger.warning(result.toJSON().toString());
return result.toJSON();
}
}
答案 0 :(得分:0)
问题可能是线程没有身份验证上下文。虽然可以手动创建身份验证上下文,但由于需要使用内部API(这意味着它是不受支持的路径,...),因此很难完成。
这样的事情:
authService = (AuthenticationServiceBean);
getBeanFactory().getBean(AuthenticationService.BEAN_ID);
authContext = authService.createAuthenticationContext(realm, username, password);
AuthenticationContext.setThreadContext(authContext);
建议在Worklight的外部运行导入程序,并远程调用适配器(通过HTTP)。
但请注意,适配器不应受其他领域的保护。