SSM总结:拦截器

过程:

1. 用户发出请求,传递url,例如:/product/list.shtml

2. 中央处理器(DispatcherServlet)拿到请求,然后将请求交给 映射器(RequestMappingHandlerMapping),映射器根据请求去扫描,直到找到@RequestMapping(value="/product/list.shtml")

public String list(){  }方法,然后将list方法返回给映射器(RequestMappingHandlerAdapter),映射器再交给中央处理器。

3. 中央处理器在拿到方法后,再通知适配器,去执行此方法,当方法执行完毕后再将 return的结果返回给中央处理器。

4. 中央处理器将结果交给视图解析器,视图解析器找到对应的视图进行渲染,返回给中央处理器,中央处理器再返回给用户界面。

对于拦截器,我们将它配置到映射器中。

在springmvc-front.xml中具体配置:

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

    <!-- 映射器 -->
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping">
        <!--注入拦截器-->
        <property name="interceptors">
            <list>
                <bean class="cn.hdu.li.core.web.SpringmvcInterceptor">//拦截器
                    <property name="adminId" value="1"/>
                </bean>
            </list>
        </property>
    </bean>
    <!-- 适配器 -->
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
SpringmvcInterceptor类的实现:

//SpringmvcInterceptor实现类要想注入spring,必须要有个接口,此时接口为:HandlerInterceptor
public class SpringmvcInterceptor implements HandlerInterceptor {

    @Autowired
    private SessionProvider sessionProvider;

    //   拦截"/buyer/"
    private static final String INTERCEPTOR_URL = "/buyer/";

    private Integer adminId;

    //方法前
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
           //设置flag给前台页面,来决定显示"退出、我的购物车",还是显示"登录、注册"
           //去session中拿buyer,如果拿到就显示 "退出,我的购物车",如果为null,则没有登录,显示 "登录、注册"
           //下面还要用到buyer
            Buyer buyer = (Buyer) sessionProvider.getAttribute(request, Constants.BUYER_SESSION);
            boolean flag = false;
            if(buyer != null) {
                flag = true;
            }
            request.setAttribute("isLogin", flag);

            //此处才是核心,判断某一url是否拦截
            String uri = request.getRequestURI();
            if(uri.startsWith(INTERCEPTOR_URL)) {
                //必须登录
                if(buyer == null) {
                    response.sendRedirect("/shopping/login.shtml?returnUrl=" + request.getParameter("returnUrl"));
                    return false;
                }
            }
        return true;  //true就继续走,false就不往下走,拦住
    }

    //方法后
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

    }

    //页面渲染后
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

    }
}



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SSM框架中,可以使用拦截器(Interceptor)来对请求进行拦截和处理。如果你想要放行jQuery请求,可以在拦截器的配置中进行相关设置。 首先,在你的拦截器类中,可以通过重`preHandle`方法来实现对请求的拦截处理。在该方法中,你可以通过获取请求的URL或其他相关信息来判断是否需要对该请求进行拦截。 如果你想要放行jQuery请求,可以在`preHandle`方法中进行判断,如果是jQuery请求,则返回`true`,表示放行;否则,可以进行其他处理或返回`false`,表示拦截该请求。 下面是一个简单的示例: ```java public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 获取请求URL String requestUrl = request.getRequestURI(); // 判断是否是jQuery请求 if (requestUrl.contains("/jquery")) { return true; // 放行jQuery请求 } else { // 进行其他处理或返回false拦截请求 // ... return false; } } // 其他方法省略... } ``` 在上述示例中,假设请求URL中包含`/jquery`字符串的请求被认为是jQuery请求,将会被放行。你可以根据实际情况进行修改和扩展。 最后,在Spring MVC的配置文件(如`dispatcher-servlet.xml`)中配置拦截器,示例如下: ```xml <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <!-- 拦截所有请求 --> <bean class="com.example.MyInterceptor"/> </mvc:interceptor> </mvc:interceptors> ``` 通过以上配置,拦截器将会对所有请求进行拦截并进行处理。 希望对你有所帮助!如果还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值