一些小细节的注解&&拦截器

一些小细节的注解&&拦截器

@PathVariable

作用:通过@PathVariable可以接收url中传入的参数
jsp页面代码:

<!--后面/${item.id}为传入的参数-->
<td><a href="${pageContext.request.contextPath }/items/itemEdit/${item.id}">修改</a></td>

controller中代码:
注意:@RequestMapping(“/itemEdit/{id}”)中接收参数使用大括号中加上变量名称, @PathVariable中的变量名称要和RequestMapping中的变量名称相同

/*通过@PathVariable可以接收url中传入的参数
*@RequestMapping("/itemEdit/{id}")中接收参数使用大括号中加上变量名称, @PathVariable中的变量名称要和*RequestMapping中的变量名称相同
*/
@RequestMapping("/itemEdit/{id}")
public String itemEdit(@PathVariable("id") Integer id, HttpServletRequest reuqest, 
    Model model) throws Exception{
    //String idStr = reuqest.getParameter("id");
    Items items = itmesService.findItemsById(id);
    //Model模型:模型中放入了返回给页面的数据
    //model底层其实就是用的request域来传递数据,但是对request域进行了扩展.
    model.addAttribute("item", items);
    //如果springMvc方法返回一个简单的string字符串,那么springMvc就会认为这个字符串就是页面的名称
    return "editItem";
}

拦截器

首先配置springMVC.xml(springMVC核心配置文件)

<!-- 配置拦截器 -->
<mvc:interceptors>
    <!-- 多个拦截器的执行顺序等于springMvc.xml中的配置顺序 -->
    <mvc:interceptor> 
        <!-- 拦截请求的路径    要拦截所有必需配置成/** -->
        <mvc:mapping path="/**"/>
            <!-- 指定拦截器的位置 -->
        <bean class="cn.itheima.interceptor.Interceptor1"></bean>
    </mvc:interceptor>

    <mvc:interceptor>
        <!-- 拦截请求的路径    要拦截所有必需配置成/** -->
        <mvc:mapping path="/**"/>
        <!-- 指定拦截器的位置 -->
        <bean class="cn.itheima.interceptor.LoginInterceptor"></bean>
    </mvc:interceptor>
</mvc:interceptors>

拦截器类的实现:
注意:拦截器类实现了HandlerInterceptor接口,实现了其中的三个方法(preHandle,postHandle,afterCompletion),要注意他们的执行顺序及使用场景,具体看代码中的注释。

public class Interceptor1 implements HandlerInterceptor {
    //执行时机:controller已经执行,modelAndview已经返回
    //使用场景: 记录操作日志,记录登录用户的ip,时间等.
    @Override
    public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
            throws Exception {
        System.out.println("======Interceptor1=======afterCompletion========");
    }
    //执行时机:Controller方法已经执行,ModelAndView没有返回
    //使用场景: 可以在此方法中设置全局的数据处理业务
    @Override
    public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
            throws Exception {
        System.out.println("======Interceptor1=======postHandle========");

    }
    //返回布尔值:如果返回true放行,返回false则被拦截住
    //执行时机:controller方法没有被执行,ModelAndView没有被返回
    //使用场景: 权限验证
    @Override
    public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2) throws Exception {
        System.out.println("======Interceptor1=======preHandle========");
        return true;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值