1.实现功能:
登陆成功后首页的登陆注册按钮消失,变成欢迎:xxx
2.思路:
登陆成功后,将user用户信息请求共享,请求转发到/home。在head.jsp中判断,如果有共享数据user,则显示欢迎xxx。如果没有共享数据,则还显示登陆注册。
3.代码:
header.jsp
<c:choose> <%--如果LoginServlet传过来的user值为空,证明没有登陆,执行c:when,否则执行c:otherwise--%> <c:when test="${ empty user}"> <li><a href="/shop/views/login.jsp">登录</a></li> <li><a href="/shop/views/register.jsp">注册</a></li> </c:when> <c:otherwise> <li>欢迎你:<a href="/shop/views/personal.jsp">${user.nickname}</a></li> </c:otherwise> </c:choose>
LoginServlet.java
@WebServlet("/login") public class LoginServlet extends HttpServlet { @Override protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { /*获取请求参数telephone,password*/ String telephone = req.getParameter("username"); String password = req.getParameter("password"); // System.out.println(telephone+"-----"+password); /*调用dao,验证是否匹配*/ ILoginDAO dao=new LoginDAOImpl(); Map<String ,Object> user = dao.isLogin(telephone,password); //System.out.println(login); if (user==null){ req.setAttribute("error","对不起,你输入的账号或者密码错误"); req.getRequestDispatcher("/views/login.jsp").forward(req,resp); }else{ /**如果不正确提示电话或者密码不正确*/ /**如果正确登陆成功,请求转发到product.jsp*/ // resp.sendRedirect("/shop/product"); /*为什么用session,从共享数据开始到关闭浏览器,共享数据都可以获取,不受请求转发和重定向的影响*/ HttpSession session = req.getSession();//获取session对象 session.setAttribute("user",user); resp.sendRedirect("/shop/home"); } } }