限制登录后才可以访问

思想:

 

1.主页

<body>

    <%--是否已经登录 --%>

    <c:choose>

        <c:when test="${empty sessionScope.user}">

            <c:if test="${not empty error}">

                ${error}

                <c:remove var="error" scope="session"/>   错误信息显示完,刷新时不再显示

            </c:if>

            <br/>

            <form name="xx" method="post"action="<c:url value='/LoginServlet'/>">

                Name:<input name="name"><br/>

                <input type="submit">

            </form>

        </c:when>

        <c:otherwise>

            你好:${user}<br/>

            <a href="<c:url value='/jsps/a.jsp'/>">AAA</a><br/>

            <a href="<c:url value='/jsps/c.jsp'/>">CCC</a><br/>

        </c:otherwise>

    </c:choose>


2.LoginServlet

public class LoginServlet extendsHttpServlet {

      

       public voiddoPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

              request.setCharacterEncoding("UTF-8");

              String name =request.getParameter("name");

              if(name!=null&& !name.trim().equals("")){

                     request.getSession().setAttribute("user",name);

              }else{

                     request.getSession().setAttribute("error", "your pwd and name error..");

              }

              response.sendRedirect(request.getContextPath()+"/index.jsp");

       }

}

3.过滤器,查看session中是否有值

public void doFilter(ServletRequest request, ServletResponseresponse,

           FilterChain chain) throws IOException, ServletException{

       // 验证在session中是否存在数据

       HttpServletRequest req = (HttpServletRequest) request;

       if (req.getSession().getAttribute("user") == null) {

           req.getSession().setAttribute("error", "请你先登录...");

           HttpServletResponse resp = (HttpServletResponse) response;

           resp.sendRedirect(req.getContextPath() + "/index.jsp");

       } else {

           chain.doFilter(request, response);

       }

    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值