怎么让用户名错误提示不在一开始就显示

怎么让用户名错误提示不在一开始就显示

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<%@ page language="java" contentType="text/html;charset=utf-8" pageEncoding="utf-8" %>
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>登录</title>
        <link rel="stylesheet" href="css/login.css">
    </head>
    <body>
        <div class="login">
            <div class="header">
                <h1>
                    <a href="/login.do">登录</a>${msg}
                </h1>
                <button></button>
            </div>
            <form action="${pageContext.request.contextPath}/LoginServlet" method="post">
                <div class="name">
                    <input type="text" id="name" name="username">
                    <p></p>
                </div>
                <div class="pwd">
                    <input type="password" id="pwd" name="password">
                    <p></p>
                </div>
                <div class="code">
                    <input type="text" id="code" name="verifyCode" style="width: 150px">
                    &nbsp;&nbsp;&nbsp;&nbsp;
                    <img src="code.jpg" style="width: 150px;height: 42px;vertical-align: middle;">
                    <p></p>
                </div>
                <div class="btn-red">
                    <input type="submit" value="登录" id="login-btn">
                </div>
            </form>
        </div>
    </body>
</html>
 
package com.book.web.servlet;
 
import java.io.IOException;
import java.util.List;
 
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
 
import com.book.web.domain.User;
import com.book.web.service.UserServiceImpl;
 
 
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
 
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //接收数据:
        String username=request.getParameter("username");
        String password=request.getParameter("password");
        //封装数据:
        User user=new User(username,password);
        //处理数据:
        UserServiceImpl userServiceImpl=new UserServiceImpl();
        //获得用户列表的集合:
        List<User> userList=(List)getServletContext().getAttribute("userList");
        User existUser=userServiceImpl.login(userList,user);
        //显示结果:
        if(existUser==null) {
            //登录失败
            request.setAttribute("msg""用户名或密码错误!");
            request.getRequestDispatcher("/login.jsp").forward(request, response);
        }else {
            //登录成功
            request.getSession().setAttribute("existUser", existUser);
            response.sendRedirect(request.getContextPath()+"/bookList.jsp");
        }
    }
 
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }
 
}
 
package com.book.web.listener;
 
import java.util.ArrayList;
import java.util.List;
 
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import javax.servlet.annotation.WebListener;
import com.book.web.domain.User;
 
 
@WebListener
public class InitListener implements ServletContextListener {
 
    
    public void contextDestroyed(ServletContextEvent sce)  { 
          
    }
 
     
    public void contextInitialized(ServletContextEvent sce)  { 
         //创建一个用于保存用户信息的集合
        List<User> userList=new ArrayList();
        userList.add(new User("admin1","123456"));
        userList.add(new User("admin2","123123"));
        userList.add(new User("admin3","111111"));
        //将List集合存入ServletContext域中
        sce.getServletContext().setAttribute("userList", userList);
    }
     
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package com.book.web.domain;
 
public class User {
    private String username;//用户名
    private String password;//密码
    public User() {
         
    }
    public User(String username, String password) {
        super();
        this.username = username;
        this.password = password;
    }
 
    public String getUsername() {
        return username;
    }
 
    public void setUsername(String username) {
        this.username = username;
    }
 
    public String getPassword() {
        return password;
    }
 
    public void setPassword(String password) {
        this.password = password;
    }
 
    @Override
    public String toString() {
        return "User [username=" + username + ", password=" + password + "]";
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
package com.book.web.service;
 
import java.util.List;
 
import com.book.web.domain.User;
 
public class UserServiceImpl {
    public User login(List<User> userList,User user) {
        for(User existUser:userList) {
            if(existUser.getUsername().equals(user.getUsername())&&existUser.getPassword().equals(user.getPassword())) {
                return existUser;
            }
        }
        return null;
    }
}


打开登录页面时,还没提交表单就已显示登录错误的提示,请问怎么样才能不在一开始就出现呢

正在回答

登陆购买课程后可参与讨论,去登陆

3回答

同学你好,这里老师的意思是,同学可以添加一个判断后,再执行alert-->比如,在还没有比较过用户名和密码时,msg为空,那对应我们就可以添加一个判断

http://img1.sycdn.imooc.com//climg/5d774aed0001ff3006280170.jpg

对应就会在msg为null时,不输出alert的值,这里老师只是想让同学自己开动脑筋,想一下这个判断要怎么写。

如果我的回答解决了你的疑惑,请采纳。祝:学习愉快~

  • 慕UI5285863 提问者 #1
    谢谢老师,解决了,之前我有加判断但null外面没有加引号
    2019-09-10 15:19:11
好帮手慕小班 2019-09-10 11:20:23

同学你好,1、复制运行贴出代码,直接进入login.jsp页面,运行效果如下;

http://img1.sycdn.imooc.com//climg/5d7712f900013c8006080384.jpg

直接通过login.jsp这个地址进入登录页面,是没有密码错误的提示,因为在LoginServlet中,将msg放在request中,而在jsp页面中直接获取${msg},所以通过LoginServlet进入login.jsp的页面中都是有错误提示的。

2、将msg的信息将在js中通过alert输出,例如:

http://img1.sycdn.imooc.com//climg/5d77160a00019aee05790132.jpg

这就是一个简单的msg的alert输出

http://img1.sycdn.imooc.com//climg/5d7716440001551f04450126.jpg

但是同学需要注意添加判断,当用户名密码不对时,添加这个alert的输出哟。

如果我的回答解决了你的疑惑,请采纳。祝:学习愉快~

  • 提问者 慕UI5285863 #1
    但是按老师这么写还是不行,还是会先弹出这个,而且显示是null
    2019-09-10 13:23:35
提问者 慕UI5285863 2019-09-09 22:47:10

还有个问题就是怎么写才能把提示信息msg的信息通过alert弹出呢

问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师
插入代码