怎么让用户名错误提示不在一开始就显示
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" > <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 ; } } |
打开登录页面时,还没提交表单就已显示登录错误的提示,请问怎么样才能不在一开始就出现呢
5
收起
正在回答
3回答
同学你好,这里老师的意思是,同学可以添加一个判断后,再执行alert-->比如,在还没有比较过用户名和密码时,msg为空,那对应我们就可以添加一个判断
对应就会在msg为null时,不输出alert的值,这里老师只是想让同学自己开动脑筋,想一下这个判断要怎么写。
如果我的回答解决了你的疑惑,请采纳。祝:学习愉快~
好帮手慕小班
2019-09-10 11:20:23
同学你好,1、复制运行贴出代码,直接进入login.jsp页面,运行效果如下;
直接通过login.jsp这个地址进入登录页面,是没有密码错误的提示,因为在LoginServlet中,将msg放在request中,而在jsp页面中直接获取${msg},所以通过LoginServlet进入login.jsp的页面中都是有错误提示的。
2、将msg的信息将在js中通过alert输出,例如:
这就是一个简单的msg的alert输出
但是同学需要注意添加判断,当用户名密码不对时,添加这个alert的输出哟。
如果我的回答解决了你的疑惑,请采纳。祝:学习愉快~
慕UI5285863
2019-09-09 22:47:10
还有个问题就是怎么写才能把提示信息msg的信息通过alert弹出呢
2. 从网页搭建入门JavaWeb
- 参与学习 人
- 提交作业 676 份
- 解答问题 9666 个
本阶段将从前端网页搭建入手,到Java Web基础,前后端结合助你完成Java Web小白的蜕变!
了解课程
恭喜解决一个难题,获得1积分~
来为老师/同学的回答评分吧