0

as in topic I'm creating applicationg combining all those technologoies.

My problem is that after whole hard configuration stuff i get error on my requestmapping and dunno why.

After deploy I get in my browser (http://localhost:8080/springer/)

WARN : org.springframework.web.servlet.PageNotFound - No mapping found for HTTP request with URI [/springer/] in DispatcherServlet with name 'appServlet'

Bello I'll paste my whole configuratiion. Dunno where to look the problem. Pls help

// EDIT

I've found small bug in my servlet-context.xml

instead having

<context:component-scan base-package="org.fixus.springer" />

I had wrong package here. BUT I got another error now

type Exception report

message

description The server encountered an internal error () that prevented it from fulfilling this request.

exception

org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.NullPointerException
   org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:681)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:574)
javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
root cause

java.lang.NullPointerException
org.springframework.faces.webflow.FacesContextHelper.releaseIfNecessary(FacesContextHelper.java:54)
org.springframework.faces.mvc.JsfView.renderMergedOutputModel(JsfView.java:88)
org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:250)
org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1047)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:817)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:719)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:669)
org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:574)
javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

// END OF EDIT

web.xml

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

<!-- The definition of the Root Spring Container shared by all Servlets and Filters -->
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>/WEB-INF/spring/root-context.xml</param-value>
</context-param>

<!-- Creates the Spring Container shared by all Servlets and Filters -->
<listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<listener>
    <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
</listener>
<servlet>
    <servlet-name>facesServlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<!--  -->

    <listener>
      <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
</listener>
<servlet>
     <servlet-name>facesServlet</servlet-name>
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>
<!--  -->

<!-- Processes application requests -->
<servlet>
    <servlet-name>appServlet</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/spring/appServlet/servlet-context.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>appServlet</servlet-name>
    <url-pattern>/</url-pattern>
</servlet-mapping>
<!--  -->
<servlet-mapping>
    <servlet-name>facesServlet</servlet-name>
<url-pattern>*.jspx</url-pattern>

servlet-context.xml

<?xml version="1.0" encoding="UTF-8"?>

   xsi:schemaLocation="
    http://www.springframework.org/schema/beans 
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context-3.0.xsd
    http://www.springframework.org/schema/tx 
    http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
    http://www.springframework.org/schema/aop 
    http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
    http://www.springframework.org/schema/mvc
    http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

 <context:component-scan base-package="org.fixus.springer" />

<!-- map all requests to /resources/** to the container default servlet (ie, don't let Spring handle them) -->

<bean id="defaultServletHttpRequestHandler" class="org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler" />

<bean id="simpleUrlHandlerMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
    <property name="urlMap">
    <map>
        <entry key="/resources/**" value-ref="defaultServletHttpRequestHandler" />
    </map>
    </property>
</bean>

<bean class="org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter" />

<mvc:annotation-driven/>
<bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver">
    <property name="cache" value="false" />
    <property name="viewClass" value="org.springframework.faces.mvc.JsfView" />
    <property name="prefix" value="/WEB-INF/views/" />
    <property name="suffix" value=".jspx" />
</bean>

HomeController.java

package org.fixus.springer;

import java.util.Locale;

import org.fixus.springer.model.User;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;

/**
 * Handles requests for the application home page.
 */
@Controller
public class HomeController {

private static final Logger logger = LoggerFactory.getLogger(HomeController.class);

/**
 * Simply selects the home view to render by returning its name.
 */
@RequestMapping(value = "/", method = RequestMethod.GET)
public void home(Locale locale, Model model) {
   logger.info("progres");
}
Fixus
  • 4,631
  • 10
  • 38
  • 67
  • I've also found out that when in my servlet-context.xml I'll put wrong suffix I get error that he can't find a file. Thats nothign strange cause suffix is wrong BUT i don't get exception witch I've put in edit in my post. Mayb this is some kind of hint for someone ? – Fixus Mar 23 '12 at 08:30
  • hint number 2: The action from my controller is read cause on consol I get the message from the logger. INFO : org.fixus.springer.HomeController - progres 2012-03-23 09:31:00 org.apache.catalina.core.StandardWrapperValve invoke SEVERE: Servlet.service() for servlet appServlet threw exception java.lang.NullPointerException at org.springframework.faces.webflow.FacesContextHelper.releaseIfNecessary(FacesContextHelper.java:54) – Fixus Mar 23 '12 at 08:31

0 Answers0