【问题标题】:How to run my JSF 1.1 application on WAS 6.0如何在 WAS 6.0 上运行我的 JSF 1.1 应用程序
【发布时间】:2009-05-25 22:50:49
【问题描述】:

当我部署使用 JSF1.1 运行时环境的应用程序时,我无法访问部署在 Websphere Application Server 6.0 上的网站。

起初它加载了一些错误,告诉我我的 commandLink 缺少 bodyContent,这是可选的,但我认为编辑了我的页面并显示了页面。

当我尝试按下任何按钮或进行任何事件处理时,它只是没有反应。

然后我将我的 web 模块类加载器模式设置为:Parent Last,然后我发现了一个异常:错误 500:SRVE0207E:servlet 抛出未捕获的初始化异常

详细的错误是

[5/23/06 11:57:23:761 CEST] 0000007d ServletWrappe A SRVE0242I: [component-showcase_war] 

[/component-showcase] [/index.jsp]: Initialization successful. 
[5/23/06 11:57:23:766 CEST] 0000007d ServletWrappe E SRVE0100E: Did not realize init() exception thrown by servlet Persistent Faces Servlet: java.lang.NullPointerException 
at com.icesoft.faces.webapp.xmlhttp.PersistentFacesCommonlet.init(Unknown Source) 
at com.icesoft.faces.webapp.xmlhttp.PersistentFacesServlet.init(Unknown Source) 
at com.ibm.ws.webcontainer.servlet.ServletWrapper.init(ServletWrapper.java:274) 
at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java(Compiled Code)) 
at com.ibm.ws.webcontainer.webapp.WebAppRequestDispatcher.forward(WebAppRequestDispatcher.java(Compiled Code)) 
at org.apache.jasper.runtime.PageContextImpl.forward(PageContextImpl.java:510) 
at com.ibm._jsp._index._jspService(_index.java:66) 
at com.ibm.ws.jsp.runtime.HttpJspBase.service(HttpJspBase.java(Compiled Code)) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java(Compiled Code)) 
at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java(Compiled Code)) 
at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java(Compiled Code)) 
at com.ibm.wsspi.webcontainer.servlet.GenericServletWrapper.handleRequest(GenericServletWrapper.java(Inlined Compiled Code)) 
at com.ibm.ws.jsp.webcontainerext.JSPExtensionServletWrapper.handleRequest(JSPExtensionServletWrapper.java(Compiled Code)) 
at com.ibm.ws.jsp.webcontainerext.JSPExtensionProcessor.handleRequest(JSPExtensionProcessor.java:241) 
at com.ibm.ws.webcontainer.webapp.WebAppRequestDispatcher.forward(WebAppRequestDispatcher.java(Compiled Code)) 
at com.ibm.ws.webcontainer.extension.DefaultExtensionProcessor.handleRequest(DefaultExtensionProcessor.java(Compiled Code)) 
at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:2933) 
at com.ibm.ws.webcontainer.webapp.WebGroup.handleRequest(WebGroup.java:221) 
at com.ibm.ws.webcontainer.VirtualHost.handleRequest(VirtualHost.java:210) 
at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java(Compiled Code)) 
at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java(Compiled Code)) 
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java(Compiled Code)) 
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewInformation(HttpInboundLink.java(Compiled Code)) 
at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.ready(HttpInboundLink.java:288) 
at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.sendToDiscriminaters(NewConnectionInitialReadCallback.java:201) 
at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.complete(NewConnectionInitialReadCallback.java:103) 
at com.ibm.ws.tcp.channel.impl.WorkQueueManager.requestComplete(WorkQueueManager.java(Compiled Code)) 
at com.ibm.ws.tcp.channel.impl.WorkQueueManager.attemptIO(WorkQueueManager.java(Compiled Code)) 
at com.ibm.ws.tcp.channel.impl.WorkQueueManager.workerRun(WorkQueueManager.java(Compiled Code)) 
at com.ibm.ws.tcp.channel.impl.WorkQueueManager$Worker.run(WorkQueueManager.java(Compiled Code)) 
at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java(Compiled Code)) 

您认为是什么问题,我在这里缺少什么,我一直在搜索,有人说要删除默认的 WAS jsf-api.jar 文件,但它没有帮助!

【问题讨论】:

    标签: java jsf jakarta-ee websphere


    【解决方案1】:

    我认为 WAS 有另一个名为 ws-jsf.jar 的 JSF jar。也删除它并尝试

    【讨论】:

    • 谢谢,确实做到了。除此之外,它应该设置为作为应用程序运行,而不是作为模块运行,并删除 common-loggin1.1 并将其替换为 common-loggin-adapters1.1
    【解决方案2】:
     at com.icesoft.faces.webapp.xmlhttp.PersistentFacesServlet.init(Unknown Source) 
    

    此 servlet 未能初始化。去icesoft.com 了解它的作用以及失败的原因可能是一个想法,而不仅仅是从您的应用服务器中删除文件。

    如果您提供有关您正在使用的技术堆栈的更多详细信息(包括您使用应用程序部署的 JSF 实现),则可能更容易诊断问题。

    我将我的 web 模块类加载器模式设置为:Parent Last

    这是正确的做法。通过这样做,您的应用程序将使用它自己的 JSF 实现,而不是容器中的旧版本。我没有删除任何文件。

    这里是我部署到 WAS 6.0 的简单 JSF 1.1 应用程序的结构。我使用的是 MyFaces 库版本 1.1.6。

    test.jsp
    WEB-INF/faces-config.xml
    WEB-INF/web.xml
    WEB-INF/lib/commons-beanutils-1.7.0.jar
    WEB-INF/lib/commons-el-1.0.jar
    WEB-INF/lib/jstl-1.1.0.jar
    WEB-INF/lib/commons-collections-3.1.jar
    WEB-INF/lib/commons-lang-2.1.jar
    WEB-INF/lib/myfaces-api-1.1.6.jar
    WEB-INF/lib/commons-digester-1.8.jar
    WEB-INF/lib/commons-logging-1.1.1.jar
    WEB-INF/lib/myfaces-impl-1.1.6.jar
    

    faces-config.xml 文档类型:

    <!DOCTYPE faces-config PUBLIC
      "-//Sun Microsystems, Inc.//DTD JavaServer Faces Config 1.1//EN"
      "http://java.sun.com/dtd/web-facesconfig_1_1.dtd">
    

    web.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app id="WebApp_ID" version="2.4"
        xmlns="http://java.sun.com/xml/ns/j2ee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
        <display-name>jsf11</display-name>
        <context-param>
            <param-name>javax.faces.STATE_SAVING_METHOD</param-name>
            <param-value>server</param-value>
        </context-param>
        <servlet>
            <servlet-name>Faces Servlet</servlet-name>
            <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
            <load-on-startup>-1</load-on-startup>
        </servlet>
        <servlet-mapping>
            <servlet-name>Faces Servlet</servlet-name>
            <url-pattern>/faces/*</url-pattern>
        </servlet-mapping>
        <servlet-mapping>
            <servlet-name>Faces Servlet</servlet-name>
            <url-pattern>*.faces</url-pattern>
        </servlet-mapping>
    </web-app>
    

    【讨论】:

    • 虽然类加载器是Parent Last,但Websphere JSF实现的“ws-jsf.jar”仍然有效运行,删除该文件后问题解决。我将在接下来的几天提供成功的步骤
    • 我不怀疑这解决了您的问题,如果没有其他人使用该服务器可能会很好,但这不是我满意的解决方案 - 它会阻止其他应用程序运行使用提供的实现。如果您正确配置类加载,JSF 引导过程应该忽略容器实现,我想知道第 3 方库中 NPE 的根本原因。指向为何删除 JAR 有效的详细信息的链接。
    猜你喜欢
    • 1970-01-01
    • 2021-08-21
    • 2012-10-15
    • 2016-04-29
    • 1970-01-01
    • 2013-07-02
    • 1970-01-01
    • 2011-12-07
    • 1970-01-01
    相关资源
    最近更新 更多