Java项目访问根目录始终不进拦截器

web项目中配置了拦截器,但是访问根目录(项目名)一直都不进拦截器,而是直接进web.xml里配置的欢迎界面

  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>

而我的index.jsp是放在WEB-INF下面的,所以就会报404错误,我的需求就是对没登录的进行拦截,然后跳转到登录页面

在网上找了好多方法:

第一种就是直接把登录页面配置到web.xml的默认界面

  <welcome-file-list>
    <welcome-file>/WEB-INF/pages/login.jsp</welcome-file>
  </welcome-file-list>

这样访问项目跟目录就会直接跳转到登录页面,但是这不是我想要的方法

第二种方法就是在WebRoot下新增一个index.jsp,然后在里面写重定向方法,重定向到登录页

具体index.jsp页面里的方法,可以写重定向也可以用

        <script>
            location.href='<%=request.getContextPath()%>/sys/global/to_login.xhtml'
        </script>

但是这也不是我想用的方法

我就是想不改变这些直接能进拦截器,后来经过同事提醒才想起来看web.xml配置的servlet-mapping

   <servlet>
    <servlet-name>spring</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>
            /WEB-INF/classes/spring-servlet.xml
      </param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>spring</servlet-name>
    <!-- <url-pattern>*.xhtml</url-pattern> -->
    <url-pattern>/</url-pattern>
  </servlet-mapping>

我配置的是只有以 xhtml 结尾的才进拦截器,所以无论我怎么访问跟目录都不会进拦截器,所以我改成了 / 就是所有请求都会拦截,但是我又发现一个问题,即使这样仍然报404,原因是我没有写访问根目录的方法,于是又写了一个Controller

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

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

import com.ws.sys.core.model.User;
import com.ws.sys.core.web.controller.BaseController;

@Controller
@RequestMapping("")
public class DefaultController  extends BaseController{
    
    /**
     * (任务管理系统)访问根目录
     * @param request
     * @return
     */
    @RequestMapping("/")
    public void to_login(HttpServletResponse response,HttpServletRequest request,HttpSession session){
        try {
            User user  = (User)session.getAttribute("userm");
            if(user != null){
                response.sendRedirect(request.getContextPath()+"/sys/global/to_index");
            }else{
                response.sendRedirect(request.getContextPath()+"/sys/global/to_login");
            }
        } catch (Exception e) {
            // TODO: handle exception
        }
        
    }
    
}

这样的话就可以直接进拦截器,我打断点调试发现并没有进我新增的这个Controller,但是不写又会报404,我想可能是需要有这个根路径的一个方法吧

这个问题纠结了一上午,还是因为MVC拦截器的机制忘了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值