springMVC
什么是Spring MVC ?简单介绍下你对springMVC的理解?
Spring MVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过把Model,View,Controller分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰的几部分,简化开发,减少出错,方便组内开发人员之间的配合。
SpringMVC的流程?
-
用户发送请求至前端控制器DispatcherServlet;
-
DispatcherServlet收到请求后,调用HandlerMapping处理器映射器,请求获取Handle;
-
处理器映射器根据请求url找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet;
-
DispatcherServlet 调用 HandlerAdapter处理器适配器;
-
HandlerAdapter 经过适配调用 具体处理器(Handle(controller和method的包装类),也叫后端控制器);
-
Handler执行完成返回ModelAndView;
-
HandlerAdapter将Handler执行结果ModelAndView返回给DispatcherServlet;
-
DispatcherServlet将ModelAndView传给ViewResolver视图解析器进行解析;
-
ViewResolver解析后返回具体View;
-
DispatcherServlet对View进行渲染视图(即将模型数据填充至视图中)
-
DispatcherServlet响应用户。
springMVC基于什么拦截的???
HandlerInterceptor (汉德勒 因特三普特)
SpringMVC怎么样设定重定向和转发的?
(1)转发:在返回值前面加"forward:",譬如"forward:user.do?name=method4"
(2)重定向:在返回值前面加"redirect:",譬如"redirect:http://www.baidu.com"
SpringMvc的控制器是不是单例模式,如果是,有什么问题,怎么解决?
答:是单例模式,所以在多线程访问的时候有线程安全问题,不要用同步,会影响性能的,解决方案是在控制器里面不能写字段。
SpringMVC常用的注解有哪些?
@RequestMapping:用于处理请求 url 映射的注解,可用于类或方法上。用于类上,则表示类中的所有响应请求的方法都是以该地址作为父路径。
@RequestBody:注解实现接收http请求的json数据,将json转换为java对象。
@ResponseBody:注解实现将conreoller方法返回对象转化为json对象响应给客户。
//实例
@Controller
@RestContrller //返回json 相当于 controller + @ResponseBody
public class ServletController {
/**
* 只要在控制器方法上加入request,response,session类型的参数,springmvc框架会把这些对象准备好作为方法参数传入
* 建议不要直接在方法参数上使用 Servlet 的(request,response,session)对象
* @param request
* @param response
* @param session
* @return
*/
@RequestMapping("/s1")
public String s1(HttpServletRequest request, HttpServletResponse response, HttpSession session){
System.out.println("获取实际请求路径:"+request.getRequestURI());
System.out.println("获取客户端的ip:"+request.getRequestURI());
System.out.println("response的对象:"+response);
response.addCookie(new Cookie("user","chen"));
System.out.println("session的对象:"+session);
return "hello";
}
@RequestParam(value=”参数名”,required=”考虑,m/fmalse”,defaultValue=””)
@Controller
@RequestMapping("hello")
public class HelloController2 {
/**
* 接收普通请求参数
* http://localhost:8080/hello/show16?name=linuxsir
* url参数中的name必须要和@RequestParam("name")一致
* @return
*/
@RequestMapping("show16")
public ModelAndView test16(@RequestParam("name")String name){
ModelAndView mv = new ModelAndView();
mv.setViewName("hello2");
mv.addObject("msg", "接收普通的请求参数:" + name);
return mv;
}
/**
* 接收普通请求参数
* http://localhost:8080/hello/show17
* url中没有name参数不会报错、有就显示出来
* @return
*/
@RequestMapping("show17")
public ModelAndView test17(@RequestParam(value="name",required=false)String name){
ModelAndView mv = new ModelAndView();
mv.setViewName("hello2");
mv.addObject("msg", "接收普通请求参数:" + name);
return mv;
}
/**
* 接收普通请求参数
* http://localhost:8080/hello/show18?name=998 显示为998
* http://localhost:8080/hello/show18?name 显示为hello
* @return
*/
@RequestMapping("show18")
public ModelAndView test18(@RequestParam(value="name",required=true,defaultValue="hello")String name){
ModelAndView mv = new ModelAndView();
mv.setViewName("hello2");
mv.addObject("msg", "接收普通请求参数:" + name);
return mv;
}
}
@PathVariable (“id”)
//@PathVariable可以用来映射URL中的占位符到目标方法的参数中
@RequestMapping("/testPathVariable/{id}", method = RequestMethod.GET)
public String testPathVariable(@PathVariable("id") Integer id)
{
System.out.println("testPathVariable:"+id);
return SUCCESS;
}
@RequestHeader即可将请求头中的属性值绑定到处理方法的入参中
@RequestMapping("/testRequestHeader")
public String testRequestHeader(@RequestHeader(value="Accept-Language") String al){
System.out.println("SpringMVCTest.testRequestHeader():"+al);
return SUCCESS;
}
SpingMvc中的控制器的注解一般用那个,有没有别的注解可以替代?**
答:一般用@Controller注解,也可以使用@RestController,@RestController注解相当于@ResponseBody + @Controller,表示是表现层,除此之外,一般不用别的注解代替。
如果在拦截请求中,我想拦截get方式提交的方法,怎么配置?
答:可以在@RequestMapping注解里面加上method=RequestMethod.GET。
怎样在方法里面得到Request,或者Session?怎么声明?
答:直接在方法的形参中声明request,SpringMvc就自动把request对象传入。
谈谈mvc设计思想?(原理)
springmvc如何接受json形式的参数?
Swagger
Api
@Api 用在类上,说明该类的作用。可以标记一个 Controller 类作为 Swagger 文档资源,使用方式代码如下所示。
@Api(tags={"用户接口"})@RestControllerpublic class UserController {}
效果图如图 1 所示。
ApiModel
@ApiModel 用在类上,表示对类进行说明,用于实体类中的参数接收说明。使用方式代码如下所示。
@ApiModel(value = “com.biancheng.auth.param.AddUserParam”, description = “新增用户参数”)
public class AddUserParam {
}
效果图如图 2 所示。
ApiParam
@ApiParam 用于 Controller 中方法的参数说明。使用方式代码如下所示。
纯文本复制
@PostMapping("/user")public UserDto addUser(@ApiParam(value = "新增用户参数", required = true) @RequestBody AddUserParam param) { System.err.println(param.getName()); return new UserDto();}
ApiOperation
@ApiOperation 用在 Controller 里的方法上,说明方法的作用,每一个接口的定义。使用方式代码如下所示。
@ApiOperation(value=“新增用户”, notes=“详细描述”)
public UserDto addUser(@ApiParam(value = “新增用户参数”, required = true) @RequestBody AddUserParam param) {
}
效果图如图 3 所示。
图 3 ApiOperation 描述
- value:接口名称
- notes:详细说明
ApiImplicitParam 和 ApiImplicitParams
用于方法上,为单独的请求参数进行说明。使用方式代码如下所示。
@ApiImplicitParams({ @ApiImplicitParam(name = "id", value = "用户ID", dataType = "string", paramType = "query", required = true, defaultValue = "1") })@ApiResponses({ @ApiResponse(code = 200, message = "OK", response = UserDto.class) })@GetMapping("/user")public UserDto getUser(@RequestParam("id") String id) { return new UserDto();}
- name:参数名,对应方法中单独的参数名称。
- value:参数中文说明。
- required:是否必填。
- paramType:参数类型,取值为 path、query、body、header、form。
- dataType:参数数据类型。
@GetMapping("/user")public UserDto getUser(@RequestParam(“id”) String id) { return new UserDto();}
- name:参数名,对应方法中单独的参数名称。
- value:参数中文说明。
- required:是否必填。
- paramType:参数类型,取值为 path、query、body、header、form。
- dataType:参数数据类型。
- defaultValue:默认值。