springMVC基础知识整理

springMVC

什么是Spring MVC ?简单介绍下你对springMVC的理解?

Spring MVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过把Model,View,Controller分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰的几部分,简化开发,减少出错,方便组内开发人员之间的配合。

SpringMVC的流程?

  1. 用户发送请求至前端控制器DispatcherServlet;

  2. DispatcherServlet收到请求后,调用HandlerMapping处理器映射器,请求获取Handle;

  3. 处理器映射器根据请求url找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet;

  4. DispatcherServlet 调用 HandlerAdapter处理器适配器;

  5. HandlerAdapter 经过适配调用 具体处理器(Handle(controller和method的包装类),也叫后端控制器);

  6. Handler执行完成返回ModelAndView;

  7. HandlerAdapter将Handler执行结果ModelAndView返回给DispatcherServlet;

  8. DispatcherServlet将ModelAndView传给ViewResolver视图解析器进行解析;

  9. ViewResolver解析后返回具体View;

  10. DispatcherServlet对View进行渲染视图(即将模型数据填充至视图中)

  11. DispatcherServlet响应用户。

    img

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 所示。

API描述

ApiModel

@ApiModel 用在类上,表示对类进行说明,用于实体类中的参数接收说明。使用方式代码如下所示。

@ApiModel(value = “com.biancheng.auth.param.AddUserParam”, description = “新增用户参数”)
public class AddUserParam {
}

效果图如图 2 所示。

APIModel描述

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 所示。

ApiOperation描述
图 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:默认值。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值