LoginSignup
2

More than 5 years have passed since last update.

JSF jarを作ってtomcatで動かそうとするとClassNotFoundException

Last updated at Posted at 2015-12-17

JSF jarを作ってtomcatで動かそうとするとClassNotFoundException

JSF jarを作ってtomcatで動かそうとするとClassNotFoundExceptionが出て動かない場合の対処法

環境

os : redhat
java : Java(TM) SE Runtime Environment (build 1.7.0_72-b14)
jsf:2.2.6
tomcat:7.0.56

現象

JSFアプリケーションのjarを作ってtomcatにデプロイして動かそうと思った時、何故か上手く動かないeclipse上だと動いているのにっ!
 結構長い事ハマった事があります。調べていくと

  • tomcatは起動する
  • tomcat関連のログにはエラーは出ていない
  • アプリで出しているログにClassNotFoundExceptionがでてちゃんと動かない

StackTraceは以下の内容が出ています。

java.lang.ClassNotFoundException: javax.servlet.jsp.jstl.core.Config
        at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1720)
        at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1571)
        at com.sun.faces.application.view.JspViewHandlingStrategy.executePageToBuildView(JspViewHandlingStrategy.java:344)
        at com.sun.faces.application.view.JspViewHandlingStrategy.buildView(JspViewHandlingStrategy.java:153)
        at com.sun.faces.lifecycle.RenderResponsePhase.execute(RenderResponsePhase.java:99)
        at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
        at com.sun.faces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:219)
        at javax.faces.webapp.FacesServlet.service(FacesServlet.java:647)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
        at org.primefaces.webapp.filter.FileUploadFilter.doFilter(FileUploadFilter.java:98)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
        at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
        at xx.xx.xxxx.xxxxx.common.util.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:166)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:503)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
        at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:950)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:421)
        at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1070)
        at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:611)
        at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
        at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
        at java.lang.Thread.run(Thread.java:745)

原因

Google先生に色んな質問をすると、色々教えてくれるのですが全部外人さんの記事ばかり…英語苦手なんです読めないんです。
がしょうがないので何とか読んで色々試してみても一向に改善しませんでした。

でも
そんな時、あるナイスガイがこんな事をいっていました。「META-INFに空の faces-config.xmlを置いてjarにすれば治るYo」
※サイトのURL忘れちゃった、Googleで調べても見つけられなかったから割愛します。
※ faces-config.xml ・・・JSF周りの各種設定を書くxml

どうやら、JSFアプリケーションでjarを作る際は、実際に設定を書く faces-config.xmlとは別に(META-INFに本体あれば動くのかも・・・でも試してない)
空の faces-config.xmlを作成してMETA-INFに置かないといけないらしい

対応方法

さっそく↓↓の感じの faces-config.xmlを作ります。(改行コードはlfのみ)

<?xml version="1.0" encoding="UTF-8"?>
<faces-config xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facesconfig_2_1.xsd"
    version="2.1">
</faces-config>

jarのMETA-INFにいれる

jarファイルを解凍して、META-INFにさっき作ったfaces-config.xmlをコピーして、またjarにします。

うごいたーーーー!

あとがき

多分、本当は別の適切な対処方法があるのかもしれない。と思いつつも調査はこれでギブアップ
何とか動いてくれています。

後、面倒臭かったのがeclipseで開発しているのですが、開発中からMETA-INFに空のfaces-config.xmlを置いちゃうと
eclipse上でJSFが動きません、だからjarを作る時に毎回やっていました。(面倒臭い)

mavenで自動デプロイしてくれた人に感謝しつつ

あと、jar内に日本語ファイルがあると、また別のエラーで動かなくなります。お気を付け

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2