@Controller这个注解会将这个类识别为控制器,并且将其作为组件扫描的候选者,所以Spring会发现它并且自动创建一个Bean实例到Spring上下文中;
在类上使用@RequestMapping("/design"),在该类中的方法上使用@GetMapping(),相当于对类的注解进行了细化;
@GetMapping=RequestMapping(method=RequestMethod.GET) 前一个是spring4.3后引入的;
注解  | 描述  | 
@RequestMapping  | 通用的请求处理  | 
@GetMapping  | 处理HTTP GET的请求  | 
@PostMapping  | 处理HTTP POST的请求  | 
@PutMapping  | 处理HTTP PUT的请求  | 
@DeleteMapping  | 处理HTTP DELETE的请求  | 
@PatchMapping  | 处理HTTP PATCH的请求  | 
@Controller和@RestController的区别
@RestController注解相当于@ResponseBody + @Controller合在一起的作用。
1) 如果只是使用@RestController注解Controller,则Controller中的方法无法返回jsp页面,或者html,配置的视图解析器 InternalResourceViewResolver不起作用,返回的内容就是Return 里的内容。
2) 如果需要返回到指定页面,则需要用 @Controller配合视图解析器InternalResourceViewResolver才行。
     如果需要返回JSON,XML或自定义mediaType内容到页面,则需要在对应的方法上加上@ResponseBody注解。
例如:
1.使用@Controller 注解,在对应的方法上,视图解析器可以解析return 的jsp,html页面,并且跳转到相应页面
若返回json等内容到页面,则需要加@ResponseBody注解
2.@RestController注解,相当于@Controller+@ResponseBody两个注解的结合,返回json数据不需要在方法前面加@ResponseBody注解了,但使用@RestController这个注解,就不能返回jsp,html页面,视图解析器无法解析jsp,html页面










