文章目录
- 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到控制器类或一个特定的处理程序方法,它负责将不同的请求映射到对应的控制器方法上。
- 只注解在方法上面
参考上面的代码,如果@RequestMapping
直接注解在方法上面,那么访问路径为:
访问路径:http://localhost:8080/项目名//loginServlet - 同时注解类与方法
访问路径: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";
}
数据处理
处理前端传递过来的数据
- 名字规范的数据
@RequestMapping("/hello")
//请求参数名和处理参数名一样的情况下,我们直接接收到前端传递的数据;
//Model主要作用:为了给前端传递我们封装好的参数;
public String hello(String name, Model model){
System.out.println(name);
model.addAttribute("aaa",name);
return "user";
}
- 名字不规范的数据
//请求参数名和处理参数名不一样的情况下
//状况:用户传递的参数名和我们要处理的参数名不一致,需要使用一个注解@RequestParam("username")来进行匹配
@RequestMapping("/hello2")
public String hello2(@RequestParam(value = "username",required = false) String name){
System.out.println(name);
return "user";
}
- 传递对象
尽量规范的编程:提交表单的数据和对象的属性名一致
//如何传递一个对象
//要求:提交表单的数据和对象的属性名一致;参数直接使用对象即可;否则按照上面方式处理
//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";
}