WSO2 API管理器/services/...抛出NullPointerException [英] WSO2 API Manager /services/... throw a NullPointerException
问题描述
我在Windows 2012 R2服务器上运行了WSO2 API管理器,并且所有仪表板URL(例如https://localhost:9443/store
,https://localhost:9443/carbon
,https://localhost:9443/publisher
)都可以正常工作.但是,当我配置并部署(在carbon.super租户中)示例WeatherAPI Web服务并尝试通过/services/...
URL即:
https://localhost:9443/services/weather/1.0.0/*?q=Amsterdam
我返回以下错误页面:
> HTTP Status 500 -
>
>
> type Exception report
>
> message
>
> description The server encountered an internal error that prevented it
> from fulfilling this request.
>
> exception org.apache.axis2.AxisFault
> org.apache.axis2.AxisFault.makeFault(AxisFault.java:430)
> org.wso2.carbon.core.transports.CarbonServlet.doGet(CarbonServlet.java:155)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:735)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.eclipse.equinox.http.servlet.internal.ServletRegistration.service(ServletRegistration.java:61)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.processAlias(ProxyServlet.java:128)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.service(ProxyServlet.java:68)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.wso2.carbon.tomcat.ext.servlet.DelegationServlet.service(DelegationServlet.java:68)
> org.wso2.carbon.tomcat.ext.filter.CharacterSetFilter.doFilter(CharacterSetFilter.java:61)
>
>
>
> root cause java.lang.NullPointerException
> org.apache.synapse.rest.RESTUtils.getFullRequestPath(RESTUtils.java:80)
> org.apache.synapse.rest.API.canProcess(API.java:179)
> org.apache.synapse.rest.RESTRequestHandler.dispatchToAPI(RESTRequestHandler.java:79)
> org.apache.synapse.rest.RESTRequestHandler.process(RESTRequestHandler.java:64)
> org.apache.synapse.core.axis2.Axis2SynapseEnvironment.injectMessage(Axis2SynapseEnvironment.java:220)
> org.apache.synapse.core.axis2.SynapseMessageReceiver.receive(SynapseMessageReceiver.java:83)
> org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:180)
> org.apache.axis2.transport.http.util.RESTUtil.invokeAxisEngine(RESTUtil.java:144)
> org.apache.axis2.transport.http.util.RESTUtil.processURLRequest(RESTUtil.java:139)
> org.apache.axis2.transport.http.AxisServlet$RestRequestProcessor.processURLRequest(AxisServlet.java:837)
> org.wso2.carbon.core.transports.CarbonServlet.handleRestRequest(CarbonServlet.java:303)
> org.wso2.carbon.core.transports.CarbonServlet.doGet(CarbonServlet.java:152)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:735)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.eclipse.equinox.http.servlet.internal.ServletRegistration.service(ServletRegistration.java:61)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.processAlias(ProxyServlet.java:128)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.service(ProxyServlet.java:68)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.wso2.carbon.tomcat.ext.servlet.DelegationServlet.service(DelegationServlet.java:68)
> org.wso2.carbon.tomcat.ext.filter.CharacterSetFilter.doFilter(CharacterSetFilter.java:61)
当我在租户中创建自己的Web服务并进行部署时,会出现相同的错误.因此,我可能配置错误,但不知道在哪里看.
/services/...
下面的所有路径似乎都返回此错误页面.我检查了[WSO2]/repository/logs
目录中的日志文件,但是它们没有显示任何错误.
您正试图从servlet端口9443访问服务.请尝试使用 8280端口.但是,APIM中的API端点看起来并不像您提到的那样.查看 WSO2官方文档中给出的示例 >
I have the WSO2 API Manager running on a Windows 2012 R2 server and all dashboard URL's like https://localhost:9443/store
,https://localhost:9443/carbon
,https://localhost:9443/publisher
work fine. But when I configure and deploy (in the carbon.super tenant) the example WeatherAPI web service and try to reach it via the /services/...
URL i.e.:
https://localhost:9443/services/weather/1.0.0/*?q=Amsterdam
I get the following error page returned:
> HTTP Status 500 -
>
>
> type Exception report
>
> message
>
> description The server encountered an internal error that prevented it
> from fulfilling this request.
>
> exception org.apache.axis2.AxisFault
> org.apache.axis2.AxisFault.makeFault(AxisFault.java:430)
> org.wso2.carbon.core.transports.CarbonServlet.doGet(CarbonServlet.java:155)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:735)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.eclipse.equinox.http.servlet.internal.ServletRegistration.service(ServletRegistration.java:61)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.processAlias(ProxyServlet.java:128)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.service(ProxyServlet.java:68)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.wso2.carbon.tomcat.ext.servlet.DelegationServlet.service(DelegationServlet.java:68)
> org.wso2.carbon.tomcat.ext.filter.CharacterSetFilter.doFilter(CharacterSetFilter.java:61)
>
>
>
> root cause java.lang.NullPointerException
> org.apache.synapse.rest.RESTUtils.getFullRequestPath(RESTUtils.java:80)
> org.apache.synapse.rest.API.canProcess(API.java:179)
> org.apache.synapse.rest.RESTRequestHandler.dispatchToAPI(RESTRequestHandler.java:79)
> org.apache.synapse.rest.RESTRequestHandler.process(RESTRequestHandler.java:64)
> org.apache.synapse.core.axis2.Axis2SynapseEnvironment.injectMessage(Axis2SynapseEnvironment.java:220)
> org.apache.synapse.core.axis2.SynapseMessageReceiver.receive(SynapseMessageReceiver.java:83)
> org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:180)
> org.apache.axis2.transport.http.util.RESTUtil.invokeAxisEngine(RESTUtil.java:144)
> org.apache.axis2.transport.http.util.RESTUtil.processURLRequest(RESTUtil.java:139)
> org.apache.axis2.transport.http.AxisServlet$RestRequestProcessor.processURLRequest(AxisServlet.java:837)
> org.wso2.carbon.core.transports.CarbonServlet.handleRestRequest(CarbonServlet.java:303)
> org.wso2.carbon.core.transports.CarbonServlet.doGet(CarbonServlet.java:152)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:735)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.eclipse.equinox.http.servlet.internal.ServletRegistration.service(ServletRegistration.java:61)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.processAlias(ProxyServlet.java:128)
> org.eclipse.equinox.http.servlet.internal.ProxyServlet.service(ProxyServlet.java:68)
> javax.servlet.http.HttpServlet.service(HttpServlet.java:848)
> org.wso2.carbon.tomcat.ext.servlet.DelegationServlet.service(DelegationServlet.java:68)
> org.wso2.carbon.tomcat.ext.filter.CharacterSetFilter.doFilter(CharacterSetFilter.java:61)
When I create my own web service in a tenant and deploy it, I get the same error. So I probably misconfigured something, but don't know where to look.
All paths below /services/...
seem to return this error page. I checked the log files in the [WSO2]/repository/logs
directory, but they don't show any errors.
You are trying to access the services from the servlet port 9443. Try with the 8280 port . However, the endpoint of the API in APIM does not look like as you mention. Check the example given in the official WSO2 documentation
这篇关于WSO2 API管理器/services/...抛出NullPointerException的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!