SpringMVC学习笔记

1:SpringMVC注解

1.1@Controller

@Controller 定义了一个控制器类

  SpringMVC 中,控制器Controller 负责处理由DispatcherServlet 分发的请求,它把用户请求的数据经过业务处理层处理之后封装成一个Model ,然后再把该Model 返回给对应的View 进行展示

1.2@RequestMapping

 RequestMapping是一个用来处理请求地址映射的注解(将请求映射到对应的控制器方法中),可用于类或方法上。用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
 RequestMapping请求路径映射,如果标注在某个controller的类级别上,则表明访问此类路径下的方法都要加上其配置的路径;最常用是标注在方法上,表明哪个具体的方法来接受处理某次请求。

value:指定请求的实际url

(1)普通的具体值。如value="/customer"。
(2)含某变量的一类值。

@RequestMapping(value="/get/{phone")
@PathVariable提取value中的变量
1 public void getCode(@PathVariable("phone") String phone,ModelMap model)

@RequestMapping还可以指定请求的方式

@RequestMapping(value={"/{phone}/code"},method=RequestMethod.GET)

 1 @Controller
 2 @RequestMapping(value={"/customer"})
 3 public class CustomerControl {
 4     protected final Log log = LogFactory.getLog(getClass());
 5     @Autowired
 6     ICustomerService customerimpl;
 7     Gson gson =new Gson();
 8     @RequestMapping(value={"/login/add"})
 9     public void addConstomer(CrCustomer param,ModelMap model){
10         try {
11             CrCustomer cusinfo= customerimpl.insertApplication(param);
12             
13          model.put("data",gson.toJson(cusinfo));
14         } catch (ServiceException e) {
15             model.put(SystemParm.ERRORCODE,ExceptionUtil.wrapExcepeion(e).code);
16             model.put(SystemParm.ERRORMESAGE,ExceptionUtil.wrapExcepeion(e).message);
17         }
18     }

如上代码在控制类添加了@RequestMapping注解 ,如果要请求方法必须要加上此注解value

请求:http://192.168.2.180:9800/consumer_tc/customer/login/add.json

@Autowired

@Autowired是做bean的注入时使用

@Autowired
	CustomerDaoImpl customerDaoImpl;

  @Autowired为Spring提供的注解,需要导入包org.springframework.beans.factory.annotation.Autowired;

@Service

  用于service层的注解

@Repository

用于注解dao层,在daoImpl类上面注解。

-----------------------------------------------------------------------以下内容为转载--------------------------------------------------------------------------

@RequestMapping 标记的处理器方法支持的方法参数和返回类型

1. 支持的方法参数类型

         (1 )HttpServlet 对象,主要包括HttpServletRequest 、HttpServletResponse 和HttpSession 对象。 这些参数Spring 在调用处理器方法的时候会自动给它们赋值,所以当在处理器方法中需要使用到这些对象的时候,可以直接在方法上给定一个方法参数的申明,然后在方法体里面直接用就可以了。但是有一点需要注意的是在使用HttpSession 对象的时候,如果此时HttpSession 对象还没有建立起来的话就会有问题。

   (2 )Spring 自己的WebRequest 对象。 使用该对象可以访问到存放在HttpServletRequest 和HttpSession 中的属性值。

   (3 )InputStream 、OutputStream 、Reader 和Writer 。 InputStream 和Reader 是针对HttpServletRequest 而言的,可以从里面取数据;OutputStream 和Writer 是针对HttpServletResponse 而言的,可以往里面写数据。

   (4 )使用@PathVariable 、@RequestParam 、@CookieValue 和@RequestHeader 标记的参数。

   (5 )使用@ModelAttribute 标记的参数。

   (6 )java.util.Map 、Spring 封装的Model 和ModelMap 。 这些都可以用来封装模型数据,用来给视图做展示。

   (7 )实体类。 可以用来接收上传的参数。

   (8 )Spring 封装的MultipartFile 。 用来接收上传文件的。

   (9 )Spring 封装的Errors 和BindingResult 对象。 这两个对象参数必须紧接在需要验证的实体对象参数之后,它里面包含了实体对象的验证结果。

2. 支持的返回类型

   (1 )一个包含模型和视图的ModelAndView 对象。

   (2 )一个模型对象,这主要包括Spring 封装好的Model 和ModelMap ,以及java.util.Map ,当没有视图返回的时候视图名称将由RequestToViewNameTranslator 来决定。

   (3 )一个View 对象。这个时候如果在渲染视图的过程中模型的话就可以给处理器方法定义一个模型参数,然后在方法体里面往模型中添加值。

   (4 )一个String 字符串。这往往代表的是一个视图名称。这个时候如果需要在渲染视图的过程中需要模型的话就可以给处理器方法一个模型参数,然后在方法体里面往模型中添加值就可以了。

   (5 )返回值是void 。这种情况一般是我们直接把返回结果写到HttpServletResponse 中了,如果没有写的话,那么Spring 将会利用RequestToViewNameTranslator 来返回一个对应的视图名称。如果视图中需要模型的话,处理方法与返回字符串的情况相同。

   (6 )如果处理器方法被注解@ResponseBody 标记的话,那么处理器方法的任何返回类型都会通过HttpMessageConverters 转换之后写到HttpServletResponse 中,而不会像上面的那些情况一样当做视图或者模型来处理。

   (7 )除以上几种情况之外的其他任何返回类型都会被当做模型中的一个属性来处理,而返回的视图还是由RequestToViewNameTranslator 来决定,添加到模型中的属性名称可以在该方法上用@ModelAttribute(“attributeName”) 来定义,否则将使用返回类型的类名称的首字母小写形式来表示。使用@ModelAttribute 标记的方法会在@RequestMapping 标记的方法执行之前执行。

 

posted @ 2017-04-14 17:17  Jkzzz  阅读(316)  评论(0编辑  收藏  举报