how2j.cn


工具版本兼容问题
比如网站提供Hero查询服务,但是前提是用户要登录过才能使用。

如果用户登陆过了,访问listHero,就让用户正常访问,否则就跳转到登陆界面。

这是非常常见的场景,通过使用 session 来实现这个功能。

在处理登录的loginServlet 中使用将用户名保存在session中。

HeroListServlet 中查看session中是否为空。如果为空,就表示用户没有登陆过,就跳转到登陆页面

步骤 1 : 在LoginServlet 把验证成功的用户加入到 Session   
步骤 2 : 在HeroListServlet判断Session中是否有数据   

步骤 1 :

在LoginServlet 把验证成功的用户加入到 Session

如果用户输入正确的账号密码,就跳转到 listHero,并且把用户名以"userName"放进session

如果用户输入错误的账号密码,就跳转到 login.html,让用户重新登陆
import java.io.IOException; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String name = request.getParameter("name"); String password = request.getParameter("password"); if ("admin".equals(name) && "123".equals(password)) { request.getSession().setAttribute("userName", name); response.sendRedirect("listHero"); } else { response.sendRedirect("login.html"); } } }
步骤 2 :

在HeroListServlet判断Session中是否有数据

String userName = (String) request.getSession().getAttribute("userName");
if (null == userName) {
response.sendRedirect("login.html");
return;
}


从session中取出userName,如果是空,就表示用户没有登录,或者登录已经超过了30分钟。 客户端跳转到login.html,让用户重新登陆
package servlet; import java.io.IOException; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import bean.Hero; import dao.HeroDAO; public class HeroListServlet extends HttpServlet { protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String userName = (String) request.getSession().getAttribute("userName"); if (null == userName) { response.sendRedirect("login.html"); return; } int start = 0; int count = 5; try { start = Integer.parseInt(request.getParameter("start")); } catch (NumberFormatException e) { // 当浏览器没有传参数start时 } int next = start + count; int pre = start - count; int total = new HeroDAO().getTotal(); int last; if (0 == total % count) last = total - count; else last = total - total % count; pre = pre < 0 ? 0 : pre; next = next > last ? last : next; request.setAttribute("next", next); request.setAttribute("pre", pre); request.setAttribute("last", last); List<Hero> heros = new HeroDAO().list(start, count); request.setAttribute("heros", heros); request.getRequestDispatcher("listHero.jsp").forward(request, response); } }


HOW2J公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2017-11-08 private static final long serialVersionUID = 1L;这句话有什么意义吗?
迈向最强之路
private static final long serialVersionUID = 1L; 在 LoginServlet中service()方法中第一行就写了这么一行,在这里好像没用到啊,啥意思?




2 个答案

sunsetoftomorrow 答案时间:2017-12-30
Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的

how2j 答案时间:2017-11-09
这个是对象流的相关知识,请参考: http://how2j.cn/k/io/io-objectstream/351.html




答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到




2017-09-16 为什么我在html里面输入admin,123还是跳转到html页面?
yi_912



输入错误正确的账号密码都是跳转到login.html页面,怎么回事,站长大大
login.html代码:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
   <form action="LoginCheck" method="post">
   用户名:<input type="text" name="username" /><br>
   密码:<input type="text" name="password" />
   <br><input type="submit" value="登陆" />
   </form>
</body>
</html>

LoginServlet.java代码
import java.io.IOException;
 
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
public class LoginServlet extends HttpServlet {
 
    private static final long serialVersionUID = 1L;
 
    protected void service(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        String name = request.getParameter("name");
        String password = request.getParameter("password");
 
        if ("admin".equals(name) && "123456".equals(password)) {
            request.getSession().setAttribute("userName", name);
            response.sendRedirect("listHero");
        } else {
            response.sendRedirect("login.html");
        }
 
    }
}
web.xml代码
    <servlet>
        <servlet-name>LoginCheck</servlet-name>
        <servlet-class>LoginServlet</servlet-class>
    </servlet>
 
    <servlet-mapping>
        <servlet-name>LoginCheck</servlet-name>
        <url-pattern>/LoginCheck</url-pattern>
    </servlet-mapping>   
    
      <servlet>
        <servlet-name>HeroListServlet</servlet-name>
        <servlet-class>servlet.HeroListServlet</servlet-class>
    </servlet>
 
    <servlet-mapping>
        <servlet-name>HeroListServlet</servlet-name>
        <url-pattern>/listHero</url-pattern>
    </servlet-mapping>   

							


3 个答案

尚未佩妥剑 答案时间:2018-04-16
6666 就是uesrname的问题

LUCIEN06 答案时间:2017-12-21
LoginServlet.java中: String name = request.getParameter("name"); 要用username,因为login.html中表单你用的是username

人来人往 答案时间:2017-09-23
粗略的看来是你的账户名和密码为admin和123456




答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2017-08-04 老师好。请问这种方法判断用户是否登录是不是只能应对只有1个用户的情况?
2017-07-30 老师好,请问下session的问题。
2017-07-19 数据库中数据无法显示
2017-06-30 最后为什么要加return,我试了好像加不加都能转发,求解答
2017-03-06 登录已经超过了30分钟跳转问题
2016-10-14 HeroListServlet里面的逻辑看不懂
2016-05-13 希望有个验证权限的Filter




提问之前请登陆
关于 J2EE-MVC-用户是否登陆 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 620943819
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
在已经存在的几千个提问里,有相当大的比例,是因为使用了和站长不同版本的开发环境导致的,比如 jdk, eclpise, idea, mysql,tomcat 等等软件的版本不一致。
请使用和站长一样的版本,可以节约自己大量的学习时间。 站长把教学中用的软件版本整理了,都统一放在了这里, 方便大家下载: http://how2j.cn/k/helloworld/helloworld-version/1718.html

上传截图