Jetty 9.0 Абсолютный uri: http://java.sun.com/jsp/jstl/core не может быть разрешен

я использую

  • Встроенный Jetty 9.
  • Мавен
  • Ява 1.7
  • JSTL

Когда я запускаю свое приложение в Eclipse и просматриваю свою веб-страницу, содержащую теги JSTL, все работает нормально. Когда я связываю его в исполняемый файл jar и запускаю из командной строки cmd, я получаю

org.apache.jasper.JasperException: /jsp/pcReport.jsp(4,62) PWC6188: Абсолютный uri: http://java.sun.com/jsp/jstl/core не может быть разрешен ни в web.xml, ни в файлах jar, развернутых с этим приложением.

Мои зависимости

    <dependency>
        <groupId>javax.servlet</groupId>
        <artifactId>jstl</artifactId>
        <version>1.2</version>
    </dependency>

    <dependency>
        <groupId>org.eclipse.jetty</groupId>
        <artifactId>jetty-webapp</artifactId>
        <version>9.0.6.v20130930</version>
    </dependency>
    <dependency>
        <groupId>org.mortbay.jetty</groupId>
        <artifactId>jsp-2.1-glassfish</artifactId>
        <version>2.1.v20100127</version>
    </dependency>

Мои плагины

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.4</version>
            <configuration>
                <archive>
                    <manifest>
                        <mainClass>com.pricemon.server.Main</mainClass>
                        <classpathPrefix>webapp/WEB-INF/lib/</classpathPrefix>
                        <addClasspath>true</addClasspath>
                    </manifest>
                    <manifestEntries>
                        <Class-Path>etc/</Class-Path>
                    </manifestEntries>
                </archive>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>2.4</version>
            <configuration>
                <descriptors>
                    <descriptor>assembly.xml</descriptor>
                </descriptors>
            </configuration>
            <executions>
                <execution>
                    <id>make-assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>

веб.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app 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-app_2_5.xsd"
    version="2.5">

    <servlet>
        <servlet-name>spring</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>spring</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

</web-app>

У меня есть jar JSTL в WEB-INF/lib, который находится в моем пути к классам манифеста.

Я просто не могу понять, почему это работает при запуске под eclipse, но не работает при запуске из исполняемого файла jar. Я также пытался вручную добавить в путь к классам при запуске безрезультатно.

java -classpath ./jstl-1.2.jar -jar app.jar

Я пропустил что-то очевидное!?


person RossMcC    schedule 18.10.2013    source источник
comment
возможный дубликат http://stackoverflow.com/questions/4928271/jstl-1-2-the-absolute-uri-http-java-sun-com-jstl-core-cannot-be-resolved   -  person Joe    schedule 18.10.2013
comment
Надеюсь, вы просмотрели эту ссылку, wiki.eclipse.org/Jetty/Howto/Configure_JSP   -  person dipu    schedule 02.01.2014


Ответы (3)


Я столкнулся с той же проблемой, но не нашел ответа в последнее время. Мне пришлось отлаживать код Glassfish, чтобы решить эту проблему. Я надеюсь, что следующее объяснение может помочь другим.

Что касается зависимостей, для работы с JSP с помощью Glassfish вам понадобится:

<dependency>
    <groupId>org.eclipse.jetty</groupId>
    <artifactId>jetty-jsp</artifactId>
    <version>9.2.3.v20140905</version>
</dependency>

<dependency>
    <groupId>org.eclipse.jetty.toolchain</groupId>
    <artifactId>jetty-jsp-jdt</artifactId>
    <version>2.3.3</version>
</dependency>

Причина, по которой ваш встроенный Jetty не может загрузить ядро, даже если у вас есть jar JSLT 1.2 (вероятно, javax.servlet.jsp.jstl.jar от Glassfish), заключается в TldScanner класс в том числе в стеклянных банках для JSP. Чтобы было ясно, этот класс имеет некоторые статические элементы, такие как:

197    static {
198        systemUrisJsf.add("http://java.sun.com/jsf/core");
199        systemUrisJsf.add("http://java.sun.com/jsf/html");
200        systemUris.add("http://java.sun.com/jsp/jstl/core");
201    }

И он не будет загружать TLD в JAR из-за блока в

515    private void mapTldLocation(String resourcePath, TldInfo tldInfo,
516                                boolean isLocal) {
517
518        String uri = tldInfo.getUri();
519        if (uri == null) {
520            return;
521        }
522
523        if ((isLocal
524                // Local tld files override the tlds in the jar files,
525                // unless it is in a system jar (except when using myfaces)
526                && mappings.get(uri) == null
527                && !systemUris.contains(uri)
528                && (!systemUrisJsf.contains(uri) || useMyFaces)
529            ) ||
530            (!isLocal
531                // Jars are scanned bottom up, so jars in WEB-INF override
532                // thos in the system (except when using myfaces)
533                && (mappings.get(uri) == null
534                    || systemUris.contains(uri)
535                    || (systemUrisJsf.contains(uri) && !useMyFaces)
536                   )
537            )
538           ) {
            ...

Невозможно загрузить ваш TLD, если URL-адрес "http://java.sun.com/jsp/jstl/core" и хранится в локальном банке. Чтобы сделать его НЕ ЛОКАЛЬНЫМ, приложение должно быть загружено загрузчиком классов, родительский элемент которого содержит jar-файл JSTL. Короче говоря, вам нужно изменить код для инициализации WebAppContext примерно так:

  ...
  WebAppContext webapp = new WebAppContext();

  // classURLs may contains URL to WEB-INF/classes or WEB-INF/lib/additional_jar of you web app
  URLClassLoader classLoader = new URLClassLoader(classURLs.toArray(new URL[classURLs.size()]),
        Thread.currentThread().getContextClassLoader());
    webapp.setClassLoader(classLoader);
  ...
  ContextHandlerCollection contextCollection = new ContextHandlerCollection();
  contextCollection.addHandler(webapp);
  ...
  Server server = new Server(threadPool);
  server.setHandler(contextCollection);
  server.start();
  ...

Если это не поможет, я хотел бы узнать, как вы встраиваете Jetty в свое приложение.

person Nam Pham    schedule 10.10.2014

У вас есть конфликтующий/дублирующийся артефакт для JSTL.

Упростите свои зависимости.

<dependencies>
  <!-- Meta Dependency - adds JSP support to the same version of Jetty -->
  <dependency>
    <groupId>org.eclipse.jetty</groupId>
    <artifactId>jetty-jsp</artifactId>
    <version>9.0.6.v20130930</version>
  </dependency>
  <!-- NOT NEEDED
  <dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>jstl</artifactId>
    <version>1.2</version>
  </dependency> -->
  <dependency>
    <groupId>org.eclipse.jetty</groupId>
    <artifactId>jetty-webapp</artifactId>
    <version>9.0.6.v20130930</version>
  </dependency>
  <!-- NOT NEEDED
  <dependency>
    <groupId>org.mortbay.jetty</groupId>
    <artifactId>jsp-2.1-glassfish</artifactId>
    <version>2.1.v20100127</version>
 </dependency> -->
</dependency>

Как видите, мы не используем артефакт JSTL, а org.mortbay.jetty предоставил уровень поддержки jsp.
Jetty предоставила мета-зависимость для извлечения артефактов для поддержки JSP в той же версии Jetty, что и ваша пристань. артефакт веб-приложения.

person Joakim Erdfelt    schedule 18.10.2013
comment
Попробовал это, и он очистил зависимости, теперь он не работает и в eclipse, и я получаю там ту же ошибку :( - person RossMcC; 19.10.2013
comment
jetty-jsp Недоступно для 9.4.3.v20170317 - person Sergei Rodionov; 16.04.2021
comment
@SergeiRodionov используйте apache-jsp для Jetty 9.4.x (также обновление, 9.4.40 уже вышла) - person Joakim Erdfelt; 16.04.2021
comment
Да, спасибо за подсказку. Я обновил приложение до 9.4.35.v20201120, но в какой-то момент попробую 9.4.40. Решил не использовать taglib, учитывая все проблемы. Это было самое простое исправление, учитывая, что я использовал только c:url. - person Sergei Rodionov; 16.04.2021

Вы должны использовать:

    <dependency>
        <groupId>org.eclipse.jetty</groupId>
        <artifactId>apache-jstl</artifactId>
        <version>${jetty-version}</version>
    </dependency>

Вместо:

 <dependency>
    <groupId>javax.servlet</groupId>
    <artifactId>jstl</artifactId>
    <version>1.2</version>
</dependency>

Я также сталкиваюсь с той же проблемой, но она была взорвана после того, как я внес это изменение.

person biendltb    schedule 24.04.2016