springmvc知识总结

1、springMVC 工作原理
  • 客户端发送HTTP请求到dispatcherservlet (前置控制器)

  • dispatcherservlet 根据适配器的规则 Handlermapper 找到控制器 controller

  • diaparcherservlet 将请求提交到controller 进行处理

  • controller 调用service 进行业务处理返回modelandview 到前置控制器

  • 前置控制器根据viewresolver 前端适配器 把modelandview 和视图进行匹配

  • 视图返回到客户端

在这里插入图片描述

2、springmvc 工作模式

1、引入springjar 包 ,spring web 相关的两个包,使用注解引入aop 包

2、在web.xml 文件配置前置控制器

  <servlet>
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!-- 表示容器再启动时立即加载servlet -->
        <load-on-startup>1</load-on-startup>
    </servlet>

3、创建web 页面

4、创建对应的controller 处理类,继承controller接口

5、在web-inf 目录下创建 springmvc-servlet.xml 配置文件,配置映射关系

    <bean name="/login" class="controller.LoginController"/>   
    <!-- LoginController控制器类,映射到"/register" -->
    <bean name="/register" class="controller.RegisterController"/>
3、ViewResolver 视图解析器, 制定重定向Url 地址规则
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" >
    <!--前缀-->
    <property name="prefix" value="/WEB-INF/jsp/"/>
    <!--后缀-->
    <property name="suffix" value=".jsp"/>
</bean>

制定的规则是页面前缀是/WEB-INF/jsp/ ,后缀是.jsp

为安全起见jsp 页面放置在web-INF 目录下,request 请求是请求不到此目录下的内容,InternalResourceView 在服务器跳转的方式可以很好的解决这个问题

4、注解控制器对比配置文件控制器有点

1、配置文件控制器需要配置文件配置映射关系,注解不需要

2、注解控制器可以有多个处理方法,配置文件控制器只能有一个方法

方法级别注解

package controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/**
* “@Controller”表示 IndexController 的实例是一个控制器
*
* @Controller相当于@Controller(@Controller) 或@Controller(value="@Controller")
*/
@Controller
public class IndexController {
    @RequestMapping(value = "/index/login")
    public String login() {
        /**
         * login代表逻辑视图名称,需要根据Spring MVC配置
         * 文件中internalResourceViewResolver的前缀和后缀找到对应的物理视图
         */
        return "login";
    }

    @RequestMapping(value = "/index/register")
    public String register() {
        return "register";
    }
}

类级别注解的

	package controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/index")
public class IndexController {
    @RequestMapping("/login")
    public String login() {
        return "login";
    }

    @RequestMapping("/register")
    public String register() {
        return "register";
    }
}
5、 获取参数几种方法

1、通过bean实体类get方法获取,要求是属性名跟页面参数名一致

2、通过处理方法的形参获取参数,要求是形参与请求参数名称完成相同,适用于get post方法

3、通过HttpServletRequest 类获取请求参数

public String register(HttpServletRequest request,Model model) {
    String uname = request.getParameter("uname");
    String upass = request.getParameter("upass");
    if ("zhangsan".equals(uname)
            && "123456".equals(upass)) {
        logger.info("成功");
        return "login"; // 注册成功,跳转到 login.jsp

4、通过@PathVariable注解获取参数

    public String register(@PathVariable String uname,@PathVariable String upass,Model model) {
        if ("zhangsan".equals(uname)
                && "123456".equals(upass)) {
            logger.info("成功");
            return "login"; // 注册成功,跳转到 login.jsp

5、通过@RequestParam 注解获取参数,当请求参数跟形参名称不一致时会报404 ,处理方法形参不会

public String register(@RequestParam String uname,
    @RequestParam String upass, Model model) {
    if ("zhangsan".equals(uname) && "123456".equals(upass)) {
        logger.info("成功");
        return "login"; // 注册成功,跳转到 login.jsp

6、通过@ModelAttribute 注解获取,多个请求参数封装到实体类中,自动暴露数据,视图展示使用,通过实体类不行

public String register(@ModelAttribute("user") UserForm user) {
    if ("zhangsan".equals(uname) && "123456".equals(upass)) {
        logger.info("成功");
        return "login"; // 注册成功,跳转到 login.jsp
6、重定向与转发
    @RequestMapping("/login")
    public String login() {
        //转发到一个请求方法(同一个控制器类可以省略/index/)
        return "forward:/index/isLogin";
    }
    @RequestMapping("/isLogin")
    public String isLogin() {
        //重定向到一个请求方法
        return "redirect:/index/isRegister";
    }

7、@Autowired和@Service 注解

Autowired 注解是对象注入到属性中,此对象必须使用service 注解声明

8、json 数据交互

使用@Requestbody 注解获取请求参数绑定到方法的形参中

使用 Responsebody 注解 直接返回到 return 对象中

    @ResponseBody
    public Person testJson(@RequestBody Person user) {
        // 打印接收的JSON格式数据
        System.out.println("pname=" + user.getPname() + ",password="
                + user.getPassword() + ",page" + user.getPage());
        ;
        // 返回JSON格式的响应
        return user;
    }
9、拦截器两种实现方式

1、 实现HandlerInterceptor接口 翻译:拦截器

2、实现 WebRequestInterceptor 接口

HandlerInterceptor 三个方法不同时段拦截

  • preHandle 方法:该方法在控制器的处理请求方法前执行,其返回值表示是否中断后续操作,返回 true 表示继续向下执行,返回 false 表示中断后续操作。

  • postHandle 方法:该方法在控制器的处理请求方法调用之后、解析视图之前执行,可以通过此方法对请求域中的模型和视图做进一步的修改。

  • afterCompletion 方法:该方法在控制器的处理请求方法执行完成后执行,即视图渲染结束后执行,可以通过此方法实现一些资源清理、记录日志信息等工作。、

    配置文件

    <mvc:interceptor>
        <!-- 配置拦截器作用的路径 -->
        <mvc:mapping path="/gotoTest" />
        <!-- 定义在<mvc: interceptor>元素中,表示匹配指定路径的请求才进行拦截 -->
        <bean class="interceptor.Interceptor2" />
    </mvc:interceptor>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值