Отключить обработку расширения JSP - PullRequest
1 голос
/ 16 ноября 2008

У меня есть веб-приложение JavaEE 1.4, работающее на WebSphere Application Server 6.0. В web.xml есть сервлет, настроенный на перехват всех запросов сервера:

<servlet-mapping>
    <servlet-name>name</servlet-name>
    <url-pattern>/*</url-pattern>
</servlet-mapping>

Это прекрасно работает, пока я не попытаюсь запросить что-то, заканчивающееся *.jsp. В этом случае сервер пытается найти JSP с этим именем и завершается с ошибкой:

java.io.FileNotFoundException: JSPG0036E: Failed to find resource /cfvct/search_criteria.jsp
    at com.ibm.ws.jsp.webcontainerext.JSPExtensionProcessor.findWrapper(JSPExtensionProcessor.java:279)
    at com.ibm.ws.jsp.webcontainerext.JSPExtensionProcessor.handleRequest(JSPExtensionProcessor.java:261)
    at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:3226)
    at com.ibm.ws.webcontainer.webapp.WebGroup.handleRequest(WebGroup.java:253)
    at com.ibm.ws.webcontainer.VirtualHost.handleRequest(VirtualHost.java:229)
    at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:1970)
    at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:120)
    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:434)
    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewInformation(HttpInboundLink.java:373)
    at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.ready(HttpInboundLink.java:253)
    at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.sendToDiscriminaters(NewConnectionInitialReadCallback.java:207)
    at com.ibm.ws.tcp.channel.impl.NewConnectionInitialReadCallback.complete(NewConnectionInitialReadCallback.java:109)
    at com.ibm.ws.tcp.channel.impl.WorkQueueManager.requestComplete(WorkQueueManager.java:566)
    at com.ibm.ws.tcp.channel.impl.WorkQueueManager.attemptIO(WorkQueueManager.java:619)
    at com.ibm.ws.tcp.channel.impl.WorkQueueManager.workerRun(WorkQueueManager.java:952)
    at com.ibm.ws.tcp.channel.impl.WorkQueueManager$Worker.run(WorkQueueManager.java:1039)
    at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1475)

Мне нужно обработать этот запрос сервлетом, но, похоже, сервер использует некоторые JSPExtensionProcessor для обработки всех путей, заканчивающихся .jsp. Есть ли способ изменить это поведение?

1 Ответ

2 голосов
/ 16 ноября 2008

Да, вам нужно сопоставить ваш сервлет с * .jsp, чтобы перенаправить поддержку * .jsp на ваш сервлет.

<servlet-mapping>
        <servlet-name>name</servlet-name>
        <url-pattern>*.jsp</url-pattern>
</servlet-mapping>

Обычно плохой идеей является прямой доступ к jsps. Размещение их в WEB-INF в каком-либо каталоге, а затем сопоставление соответствующего URL-адреса (.do, .action и т. Д.) Сервлету, который затем перенаправляет его на этот JSP-сервер, является лучшей практикой.

Таким образом, вместо того, чтобы вводить thisUrl.jsp, пользователь будет вводить thisUrl.do или thisUrl.action, и сервлет получит перенаправление на thisUrl.jsp.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...