无法调用 CXFInstall.getLocation() 因为 cxfInstall 为空

问题描述

我正在尝试使用最新的 Eclipse IDE (jee-2021-03) 和 apache-cxf-3.4.2 从 WSDL 文件开始生成 Web 服务客户端。

我收到此错误:

IWAB0014E Unexpected exception occurred.
  Cannot invoke "org.eclipse.jst.ws.internal.cxf.core.model.CXFInstall.getLocation()" because "cxfInstall" is null
      java.lang.NullPointerException: Cannot invoke "org.eclipse.jst.ws.internal.cxf.core.model.CXFInstall.getLocation()" because "cxfInstall" is null
      at org.eclipse.jst.ws.internal.cxf.core.utils.LaunchUtils.launch(LaunchUtils.java:114)
      at org.eclipse.jst.ws.internal.cxf.consumption.core.commands.WSDL2JavaClientCommand.execute(WSDL2JavaClientCommand.java:73)
      at org.eclipse.wst.command.internal.env.core.fragment.CommandFragmentEngine.runCommand(CommandFragmentEngine.java:421)
      at org.eclipse.wst.command.internal.env.core.fragment.CommandFragmentEngine.visitTop(CommandFragmentEngine.java:361)
      at org.eclipse.wst.command.internal.env.core.fragment.CommandFragmentEngine.moveForwardToNextStop(CommandFragmentEngine.java:214)
      at org.eclipse.wst.command.internal.env.ui.widgets.SimpleCommandEngineManager$6.run(SimpleCommandEngineManager.java:296)
      at org.eclipse.jface.operation.ModalContext.runInCurrentThread(ModalContext.java:436)
      at org.eclipse.jface.operation.ModalContext.run(ModalContext.java:352)
      at org.eclipse.jface.wizard.WizardDialog.run(WizardDialog.java:1033)
      at org.eclipse.wst.command.internal.env.ui.widgets.SimpleCommandEngineManager.runForwardToNextStop(SimpleCommandEngineManager.java:266)
      at org.eclipse.wst.command.internal.env.ui.widgets.WizardPageManager.runForwardToNextStop(WizardPageManager.java:93)
      at org.eclipse.wst.command.internal.env.ui.widgets.WizardPageManager.performFinish(WizardPageManager.java:264)
      at org.eclipse.wst.command.internal.env.ui.widgets.DynamicWizard.performFinish(DynamicWizard.java:384)
      at org.eclipse.jface.wizard.WizardDialog.finishPressed(WizardDialog.java:832)
      at org.eclipse.jface.wizard.WizardDialog.buttonPressed(WizardDialog.java:472)
      at org.eclipse.jface.dialogs.Dialog.lambda$0(Dialog.java:619)
      at org.eclipse.swt.events.SelectionListener$1.widgetSelected(SelectionListener.java:84)
      at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:252)
      at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:89)
      at org.eclipse.swt.widgets.Display.sendEvent(Display.java:4441)
      at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1512)
      at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1535)
      at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1520)
      at org.eclipse.swt.widgets.Widget.notifyListeners(Widget.java:1324)
      at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4227)
      at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3837)
      at org.eclipse.jface.window.Window.runEventLoop(Window.java:823)
      at org.eclipse.jface.window.Window.open(Window.java:799)
      at org.eclipse.wst.command.internal.env.ui.widgets.popup.DynamicPopupWizard.run(DynamicPopupWizard.java:132)
      at org.eclipse.ui.internal.PluginAction.runWithEvent(PluginAction.java:239)
      at org.eclipse.jface.action.ActionContributionItem.handleWidgetSelection(ActionContributionItem.java:580)
      at org.eclipse.jface.action.ActionContributionItem.lambda$4(ActionContributionItem.java:414)
      at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:89)
      at org.eclipse.swt.widgets.Display.sendEvent(Display.java:4441)
      at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1512)
      at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1535)
      at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1520)
      at org.eclipse.swt.widgets.Widget.notifyListeners(Widget.java:1324)
      at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:4227)
      at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3837)
      at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$5.run(PartRenderingEngine.java:1157)
      at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:338)
      at org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:1046)
      at org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:155)
      at org.eclipse.ui.internal.Workbench.lambda$3(Workbench.java:644)
      at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:338)
      at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:551)
      at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:156)
      at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:152)
      at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:203)
      at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134)
      at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104)
      at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:401)
      at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:255)
      at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
      at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:64)
      at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      at java.base/java.lang.reflect.Method.invoke(Method.java:564)
      at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:653)
      at org.eclipse.equinox.launcher.Main.basicRun(Main.java:590)
      at org.eclipse.equinox.launcher.Main.run(Main.java:1461)

我在 macOS Big Sur 11.3(使用 Apple Silicon M1)上使用 AdoptOpenJDK 8。 Apache CXF 刚刚下载并存储在本地文件夹中。 在 Eclipse 首选项中,在 Web 服务/CXF 2.x 首选项下,我可以正确地看到我的 CXF 运行时。 它不依赖于 WSDL 本身,因为我也无法使用任何其他 WSDL 运行 Web 客户端生成。

相同的 WSDL 已成功用于使用旧版 MacBook Pro 和 macOS Big Sur 11.2.1、Eclipse jee-2020-06、apache-cxf-3.3.7 和 Java SE 8 (1.8.0_181) 生成客户端。

我在 Google 上没有找到任何关于它的信息...

有人遇到过同样的问题吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...