注解开发的handler方式:
使用RequestMappingHandlerMapping需要在Handler 中使用**@controller标识此类是一个控制器**,使用**@requestMapping指定Handler方法所对应的url,建议与方法名一致,方便开发维护**。
@Controller
public class Controller_Demo{
@RequestMapping("/queryItems")
public ModelAndView queryItems(){}
}
@RequestMapping
value的值是数组,可以将多个url映射到同一个方法
1. **一个方法对应一个或多个url,且建议方法名称与url一致**,在一个controller里面会有多个方法,那就有多个@RequestMapping,不同的url访问不同的方法
2. 窄化映射请求: 通过此方法对url进行分类管理,避免 url冲突。
1. 在class上定义根路径,访问时 根路径+方法的url
@RequestMapping("/items")
@Controller
public class Controller_Demo{
@RequestMapping("/queryItems")
public ModelAndView queryItems(){}
}
// 这个方法的访问地址为: /items/queryItems
3. 限制http请求的方法
1. 限定GET方法
@RequestMapping(method = RequestMethod.GET)
//如果通过Post访问则报错:HTTP Status 405 - Request method 'POST' not supported
2. 限制POST方法,同理
3. 同时限定:
@RequestMapping(method = {RequestMethod.GET,RequestMethod.POST})
controller的方法返回值:
1. 返回 ModelAndView:
1. 往ModelAndView中存值 : addObject(String name,Object obj)
2. 制定逻辑视图名: setViewName(String name)
3. 最终视图的址为:前缀+逻辑视图名+后缀,逻辑视图名需要在controller中返回ModelAndView指定,比如逻辑视图名为**hello**,则最终返回的jsp视图地址 “WEB-INF/jsp/**hello**.jsp”
2. 返回 字符串 : 字符串就是逻辑视图名
3. 返回 void : 那就是使用原始的方式request 转发,response 重定向
4. redirect重定向:相当于“response.sendRedirect()”
return "redirect:queryItem.action";
5. forward 转发 : 相当于request.getRequestDispatcher().forward(request,response)
return "forward:editItem.action"
参数绑定(方法中传入的形参)
1. 默认支持的类型:
- HttpServletRequest
- HttpServletResponse
- HttpSession
- Model
通过model向页面传递数据,如下:
//调用service查询商品信息
Items item = itemService.findItemById(id);
model.addAttribute("item", item);
页面通过${item.XXXX}获取item对象的属性值。
2. 简单类型(整型,布尔型,字符串,单双精度)
3. pojo
4. 集合类
5. @RequestParam
6. 自定义参数绑定