spring四---- (mvc的常用注解)

本文详细介绍了Spring MVC中的一些常用注解,包括@RequestMapping用于提取表单数据,ModelAndView处理数据和视图,@ModelAttribute用于对象查询,以及@SessionAttributes将对象加入session域。此外,还讲解了如何配置和使用拦截器进行登录验证。
摘要由CSDN通过智能技术生成

1 – @RequestMapping

表单数据的提取 :
此处是 jsp中的表单代码 ,需要在后端代码中获取输入的 name参数

 <form action="/map">

      name<input type="text" name ="name"><br/>

      <input  type="submit">
  </form>

此处为后端的代码 ,通过 注解 (requestparam(“str”)获取 前端数据 —str 为 前端表单中的 name 属性 )

    @RequestMapping(value = "map")
    public String loginmap(@RequestParam("name") String name ,ModelMap m){
        System.out.println(name);
       m.put("name",name);

        return "success";

    }

2-- ModelAndView

如果在后端需要同时处理 数据 与 视图(model view)时 就可以是用 modelandview

控制器的 类型要是 ModelAndView 。
处理视图信息–ModelAndView mv =new ModelAndView("success"); 此处的 success 就是 要跳转的 页面信息。
当然 这个 页面信息 也会在视图解析中 增加定义的前后缀

    <!--  视图解析器 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <!--增加前缀-->
         <property name="prefix" value="/view/"/>
        <!--增加后缀-->
        <property name="suffix"  value=".jsp"/>

    </bean>

处理数据 (model)
使用 addObject 方法即可

  mv.addObject("sss" ,student);

类似modelandview 的方法 还有 使用 map modelmap 等
但是 返回的是 String 代表 页面的信息 ,使用 map.put 将数据放入request 域中

3–@ModelAttribute

此属性不会单独使用 一般是用于 一个修改功能中
修改 的过程 分为两步 1. 获取 对象 2. 对该对象修改
本注释 就是用于 第一步 获取对象的

具体使用

   @ModelAttribute
    public void querystu(Map<String,student> map, @RequestParam("name") String name){
       // 模拟查询
         student student =new student(name);
         System.out.print(student.getName()+"     ------  "+ student.getId()+"     ----------" + student.getAddress());
        map.put("stu",student);

    }

此处的代码 接受 了 前端的 name 属性的值 ,对其进行模拟查询 – student 然后将其 放入 map即可

第二步 修改

 @RequestMapping(value = "welcomeModelAndViewquerrystud")
    public ModelAndView loginnn(@ModelAttribute("stu") student student){
        System.out.print(student.getName()+"     ------  "+ student.getId()+"     ----------" + student.getAddress());
        ModelAndView mv =new ModelAndView("success");
        mv.addObject("sss" ,student);
        return mv;

    }

此处 通过 @ModelAttribute("stu") student student 获取 了第一步找中的stu的对象 赋值给 student
然后进行操作

在一个类中 ,只要有方法被 @ModelAttribute 修饰了, springmvc就会自动的先执行它 ,然后 再 根据 @RequestMapping 进行操作 。所以 该示例 中 一定会先得到 一个 student对象

4–@SessionAttributes

将 对象 加入到 session 域中 — 对于登录验证 一般 与 拦截器一起 作用

@SessionAttributes("username")
   @RequestMapping(value = "userlogin.action")
    public ModelAndView userlogin(@RequestParam("name") String username ){

      //  session.setAttribute("username",username);
      //  System.out.println("username is "+ session.getAttribute("username"));
        ModelAndView mv =new ModelAndView( "success");
        System.out.println("username is "+username);
        mv.addObject("username",username);

     //   return  "success";
        return  mv;
    }

此处 就将 username 对象加入到了 session域中

5-- 拦截器

首先在xml中对其进行配置
使用 mvc:interceptors 标签

    <!--配置拦截器  -->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--所有路径都拦截-->
            <mvc:mapping path="/**"/>

            <bean class="Interceptor.myInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
    

拦截器的部分代码

 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception {
        //判断 是不是登录界面 login
        if(!request.getRequestURI().contains("/userlogin")){
            System.out.println( request.getRequestURI() );
            String name = (String )request.getSession().getAttribute("username");
            if(name== null){
                System.out.println(" 名字为空  ");
                //转发?到登录界面
                response.sendRedirect("/view/login.jsp");
                return  false;//不放行
            }
        }
        return true;
    }

当 获取到 当前的 uri 中不包含 /login 且 session中不包含 username 时 就会 拦截本次的请求 ,将其转发 到 登录界面

<form action="/userlogin.action">

    name<input type="text" name ="name"><br/>

    <input  type="submit">
</form>

登录界面 --后端处理 获取name ,将其 添加到 session中


    @RequestMapping(value = "userlogin.action")
    public ModelAndView userlogin(@RequestParam("name") String username ){
        ModelAndView mv =new ModelAndView( "success");
        System.out.println("username is "+username);
        mv.addObject("username",username);
        return  mv;
    }

此时 session域中的username 不为空 拦截会对其放行 ,进入 success界面
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值