Spring learning day 3(spring mvc)

1.spring mvc业务处理流程:http请求到达->dispathcer servlet与处理器映射器决定使用哪个控制器->dispatcher serlvet通过处理器适配器调用处理器方法->调用容器类的处理器方法来处理业务(该方法会返回模型数据返回给视图)->dispatcher servlet选择视图->将模型数据传递给视图在浏览器中显示。

2.定义servlet文件:在web.xml文件中定义servlet

	
		smart
		
			org.springframework.web.servlet.DispatcherServlet
		
		3
		

	
		smart
		*.html
	

定义了servlet的name为smart,servlet-mapping在这里相当于定义了一个网关,所有以html结尾的url请求都被送到这里。servlet初始化阶段需要获取spring容器上下文,在这里是webapplicationcontext,即servletname-servlet.xml定义的文件,因此可以根据约定在web-inf目录下定义一个$(servlet-name)-servlet.xml的文件,这是默认的命名约定,并且存放与web-inf目录下,当然也可以自定义存放路径,通过在配置文件中添加参数指明:



    org.springframework.web.context.ContextLoaderListener

org.saderListenerpringframework.web.context.ContextLoaderListener的作用是在web容器启动的时候自动装载applicationcontext.xml文件的配置信息。

3.controller注解:可以使用此注解来修饰一个类,将其声明为一个控制器,在方法之上使用@RequestMapping注解来修饰一个方法。这样就可以拦截对应的请求执行相应的RequestMapping方法,如下所示:

@Controller
public class HelloReaderController {

	@RequestMapping(value="/hello")
	public ModelAndView sayhello() {
		ModelAndView mv=new ModelAndView();
		mv.addObject("message","Hello Reader");
		mv.setViewName("helloReader");
		return mv;
	}
} 

其中value指定了访问路径名:比如在url中输入/hello就能执行相应的sayhello方法。在sayhello方法中声明了一个模型视图容器类,在其中放入了一个对象,并且设置了返回的视图名称。视图名称即是helloReader,视图经过解析,由在servletname-servlet.xml中定义的视图解析器解析,通常给视图添加上前缀和后缀构成视图的路径,比如WEB-INF/pages/helloReader.jsp.

4.:能激活在xml中注册过的bean,而能够激活xml中注册过的bean,而且还能注册并激活指定包下通过注解注册的bean,注解@conponmentScan能和达到同样的效果。

5.@Configuration修饰一个类,这个类可以作为webapplicationcontext启动时候的配置类,修饰的类中可以由注解@Bean声明一个bean。在web.xml中的标签中定义:

Spring learning day 3(spring mvc)_第1张图片

6.表单标签:在一个页面如果想使用表单标签库,需要在页面进行配置。

<%@taglib uri="http://www.springframework.org/tags/form" prefix="big" %>

7.注解controller:此注解和@service、@Responsitory等注解一样都是继承自component类,@controller主要负责将一个类作为mvc框架的一个控制器。从而将web请求映射到@RequestMapping注解的方法上。

8.注解@RequestMapping:可以接受http servlet请求响应对象,http session对象。

9.@pathVariable:用于修饰一个方法参数。


这样路径名中的userid的值就是参数string userid的值。

你可能感兴趣的:(spring)