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

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

<%@ 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);
    }
	
}
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 + "]";
	}
}
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下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

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