文章目录
Controller配置
控制器Controller
参数传递(View to Controller)
@RequestParam
@RequestMapping
参数传递(Controller to View)
ModelAndView
Model
数据处理
Controller配置
使用SpringMVC,必须配置以下信息:
处理器映射器
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
处理器适配器
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
or
注解驱动(如果使用注解来实现Spring MVC,可以不用处理器映射器和处理器适配器)
<mvc:annotation-driven/>
视图解析器(必要)
<bean id="InternalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/"/> <property name="suffix" value=".jsp"/> </bean>
控制器Controller
控制器复杂提供访问应用程序的行为,通常通过接口定义或注解定义两种方法实现。 控制器负责解析用户的请求并将其转换为一个模型。在Spring MVC中一个控制器类可以包含多个方法。
在SpringMVC中,对于Controller的配置方式有很多种:
1.控制器实现方式:实现Controller接口
实现接口Controller定义控制器是较老的办法,缺点是:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;定义的方式比较麻烦。
参数传递(View to Controller)
2.使用注解@Controller定义控制器
@Controller注解类型用于声明Spring类的实例是一个控制器(在讲IOC时还提到了另外3个注解);
Spring可以使用扫描机制来找到应用程序中所有基于注解的控制器类,为了保证Spring能找到你的控制器,需要在配置文件中声明组件扫描。
<!-- 自动扫描指定的包,下面所有注解类交给IOC容器管理 --> <context:component-scan base-package="cn.kgc.kb03.servlet"/>
用注解实现:
@Controller //使用注解定义控制器,注解的类会自动添加到Spring上下文中 @RequestMapping("/login") //映射包 public class LoginServlet{ Logger log=Logger.getLogger(LoginServlet.class); @RequestMapping(value = "/loginServlet") //映射访问路径 public void login(@RequestParam(value = "name",required = false) String name, @RequestParam(value = "password",required = false) String password){ System.out.println("这儿是控制器"); System.out.println(name+","+password); } }
@RequestParam
Controller方法中参数前加@RequestParam进行直接入参,指定其对应的请求参数。
value 参数名
required 是否必需
defaultValue 默认参数名,不推荐使用
@RequestMapping
@RequestMapping注解用于映射url到控制器类或一个特定的处理程序方法,它负责将不同的请求映射到对应的控制器方法上。
1.只注解在方法上面
参考上面的代码,如果@RequestMapping直接注解在方法上面,那么访问路径为:
访问路径:http://localhost:8080/项目名//loginServlet
2.同时注解类与方法
访问路径:http://localhost:8080/项目名/login/loginServlet , 需要先指定类的路径再指定方法的路径。
// 注意这里的映射规则 @RequestMapping(value = "/turn",method = RequestMethod.POST,params = "userCode")
映射规则
通过请求URL进行映射
通过请求参数进行映射
若选择方法参数直接入参的话,方法入参名必须与请求中参数名保持一致
通过请求方法进行映射
GET
POST
参数传递(Controller to View)
ModelAndView
包含视图信息和模型数据信息
常用方法
添加模型数据
ModelAndView addObject(String attributeName, Object attributeValue)
ModelAndView addAllObjects(Map<String,?> modelMap)
设置视图
void setView(View view)
void setViewName(String viewName)
/** * 参数传递:controller to view-(ModelAndView) * @param userCode * @return */ @RequestMapping(value = "/turn",method = RequestMethod.POST,params = "userCode") public ModelAndView hello(@RequestParam String userCode){ ModelAndView mav=new ModelAndView(); log.info("登入成功:userCode"+userCode); mav.addObject("userCode",userCode); mav.setViewName("success"); return mav; }
结果跳转方式:
设置ModelAndView对象,根据View名称,和视图解析器,跳转到指定的页面;
页面 :{视图解析器的前缀} + viewName + {视图解析器的后缀}
Model
除了可以使用ModelAndView对象来返回模型数据之外,还可以使用Spring MVC提供的Model对象来完成模型数据的传递。
数据结构:Map类型
常用方法:添加模型数据
Model.addAttribute(String attributeName,Object attributeValue)
/** * 参数传递:controller to view-(Model) * @param username * @param model * @return */ @RequestMapping(value = "/commit",method = {RequestMethod.GET}) public String index(String username,Model model){ //Spring MVC会自动实例化一个Model对象用于向视图中传值 model.addAttribute("username", "username"); //返回视图位置 return "index"; }
数据处理
处理前端传递过来的数据
1.名字规范的数据
@RequestMapping("/hello") //请求参数名和处理参数名一样的情况下,我们直接接收到前端传递的数据; //Model主要作用:为了给前端传递我们封装好的参数; public String hello(String name, Model model){ System.out.println(name); model.addAttribute("aaa",name); return "user"; }
2.名字不规范的数据
//请求参数名和处理参数名不一样的情况下 //状况:用户传递的参数名和我们要处理的参数名不一致,需要使用一个注解@RequestParam("username")来进行匹配 @RequestMapping("/hello2") public String hello2(@RequestParam(value = "username",required = false) String name){ System.out.println(name); return "user"; }
3.传递对象
尽量规范的编程:提交表单的数据和对象的属性名一致
//如何传递一个对象 //要求:提交表单的数据和对象的属性名一致;参数直接使用对象即可;否则按照上面方式处理 //http://localhost:8080/mvc04/hello3?id=1&username=Theshy&password=123456; @RequestMapping("/hello3") public String hello3(User user,Model model){ System.out.println(user); model.addAttribute("user",user); return "user"; }