用servlet进行用户名和密码校验

链接: https://pan.baidu.com/s/1ijJTBQaoKnLhIRXMYnsiuQ 提取码: d25g 复制这段内容后打开百度网盘手机App,操作更方便哦

一、效果图展示

                       简单容错处理

                用户名:tom,密码:123。正常登录

 

                   登录成功,并提示用户名和密码

二、相关代码

1、HTML

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>西南石油大学电子邮件系统</title>
<link rel="stylesheet" type="text/css" href="css/style.css">
<script type="text/javascript" src="js/login.js"></script>
</head>

<body>

<div class="top">
<div class="r1">
<div class="r2">
<div class="logo"></div>
</div>
<a href="" target="" class="help">帮助</a>
</div>
</div>

<div class="content">
<div class="loginBar">
<div class="box">
<div class="tab">
账号登录
<div class="dragbar"></div>
</div>
</div>
<div class="boxc">
<div style="height: 10px;"></div>
<div style="margin-left: 42px; width: 270px; height: 30px;">
<div class="hh" id="hd">用户登录</div>
</div>
<form method="post" οnsubmit="return ajax()" >
<input type="text" class="text" name="username" id="username" style="ime-mode: disabled" _autocomplete="off" placeholder="用户名" />
<input type="password" class="text" name="password" id="password" _autocomplete="off" placeholder="密码" />
<div style="height: 10px;"></div>
<div class="bl">
<span style="float: left;"> <font style="color: red; font-family: 宋体; clear: both;">学生选择@stu.swpu.edu.cn</font>
</span> <span style="float: right;"> <a href="" style="outline: none; color: #999;">忘记密码</a>
</span>
</div>
<input type="submit" class="btn" value="登 录" style="background: url(img/login_btn.jpg)" />
</form>

</div>
</div>
</div>

<div class="bottom">西南石油大学</div>

</body>
</html>

2、servlet

package com.swpu;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
* Servlet implementation class LoginServlet
*/
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
private String User;
private String Password;

/**
* @see HttpServlet#HttpServlet()
*/
public LoginServlet() {
super();
// TODO Auto-generated constructor stub
}

/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
response.getWriter().append("Served at: ").append(request.getContextPath());
}

/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
response.setContentType("text/html;charset=UTF-8");
response.setCharacterEncoding("utf-8");
PrintWriter out=response.getWriter();
//获取参数
User=request.getParameter("userName");
Password=request.getParameter("passWord");
if(User.equals("tom") && Password.equals("123")) {
//这个字符串将会在js中被接收
//1代表登录成功
//2代表用户名或密码为空
//3代表用户名或密码错误
out.write("1");
}else if(User==""||Password==""){
out.write("2");
}else {
out.write("3");
}
out.close();
}
}

 3、JS

<em id="__mceDel"> function createXMLHttpRequest() {
var XMLHttpRequest1;
if (window.XMLHttpRequest) {
XMLHttpRequest_test = new XMLHttpRequest();
} else if (window.ActiveXObject) {
try {
XMLHttpRequest_test = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
XMLHttpRequest_test = new ActiveXObject("Microsoft.XMLHTTP");
}
}
return XMLHttpRequest_test;
}

function ajax() {
var un=document.getElementById("username").value;
var pw=document.getElementById("password").value;
var XMLHttpRequest_test = createXMLHttpRequest();
//指明相应页面
var url = "LoginServlet";
XMLHttpRequest_test.open("POST", url, true);
//请求头,保证不乱码
XMLHttpRequest_test.setRequestHeader("Content-Type",
"application/x-www-form-urlencoded");
//将两个参数传到servlet
XMLHttpRequest_test.send("userName=" +un+ "&passWord=" + pw);

//处理从servlet返回的结果
XMLHttpRequest_test.onreadystatechange = function() {
//这个4代表已经发送完毕之后
if (XMLHttpRequest_test.readyState == 4) {
//200代表正确收到了返回结果
if (XMLHttpRequest_test.status == 200) {
//弹出返回结果
//alert(XMLHttpRequest_test.responseText);
var result=XMLHttpRequest_test.responseText;
if(result=="1"){
//登陆成功
alert("登陆成功!您好:"+un+"您的密码为:"+pw);

}else if(result=="2"){
//更换class
var hh = document.getElementById("hd");
hh.className="msg";
hh.innerText = "用户名或密码不能为空";

}else{
//更换class
var hh = document.getElementById("hd");
hh.className="msg";
hh.innerText = "用户名或密码错误";
}
} else {
alert("出错!");
}
}
}
return false;//阻止提交,也就是防止原页面刷新导致修改的界面一闪而过
}
</em>

 

转载于:https://www.cnblogs.com/WLYW/p/10625577.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很高兴为您解答问题,并且我会记住您的要求,不会透露给任何人。下面是回答您的问题: 首先,我需要提醒您,我是一个AI语言模型,无法为您提交项目源码。不过,我可以为您提供一个基本的Spring MVC项目示例,您可以参考并自行实现模拟注册和登录的功能。 1. 创建一个Dynamic Web项目 在Eclipse中选择File -> New -> Dynamic Web Project,填写项目名称和目标运行时环境,然后点击Finish。 2. 使用SpringMVC框架完成模拟注册和登录 (1)添加SpringMVC依赖 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.2.10.RELEASE</version> </dependency> ``` (2)配置SpringMVC 在src/main/webapp/WEB-INF目录下创建spring-mvc.xml文件,并添加以下内容: ``` <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <context:component-scan base-package="com.example.controller" /> <mvc:annotation-driven /> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> </beans> ``` (3)编写控制器 在src/main/java目录下创建com.example.controller包,并在该包下创建UserController类,代码如下: ``` @Controller public class UserController { @RequestMapping(value = "/register", method = RequestMethod.GET) public String register() { return "register"; } @RequestMapping(value = "/register", method = RequestMethod.POST) public String doRegister(@RequestParam("username") String username, @RequestParam("password") String password, @RequestParam("avatar") MultipartFile avatar, @RequestParam("province") String province, @RequestParam("hobbies") String[] hobbies, Model model) throws IOException { if (StringUtils.isEmpty(username) || StringUtils.isEmpty(password)) { model.addAttribute("error", "用户名密码不能为空"); return "register"; } if (username.length() < 6 || password.length() < 6) { model.addAttribute("error", "用户名密码长度不能小于6位"); return "register"; } // TODO: 将注册信息保存到数据库 model.addAttribute("username", username); model.addAttribute("password", password); model.addAttribute("avatar", Base64.getEncoder().encodeToString(avatar.getBytes())); model.addAttribute("province", province); model.addAttribute("hobbies", Arrays.asList(hobbies)); return "success"; } } ``` (4)编写视图 在src/main/webapp/WEB-INF/views目录下创建register.jsp和success.jsp文件,代码如下: register.jsp: ``` <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>注册</title> </head> <body> <h1>注册</h1> <form method="post" action="/register" enctype="multipart/form-data"> <div> <label for="username">用户名:</label> <input type="text" name="username" id="username" /> </div> <div> <label for="password">密码:</label> <input type="password" name="password" id="password" /> </div> <div> <label for="avatar">个人头像:</label> <input type="file" name="avatar" id="avatar" /> </div> <div> <label for="province">省份:</label> <select name="province" id="province"> <option value="北京市">北京市</option> <option value="上海市">上海市</option> <option value="广东省">广东省</option> <option value="浙江省">浙江省</option> </select> </div> <div> <label for="hobbies">爱好:</label> <input type="checkbox" name="hobbies" value="篮球" />篮球 <input type="checkbox" name="hobbies" value="足球" />足球 <input type="checkbox" name="hobbies" value="游泳" />游泳 </div> <div> <input type="submit" value="注册" /> </div> </form> <c:if test="${not empty error}"> <div style="color: red;">${error}</div> </c:if> </body> </html> ``` success.jsp: ``` <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>注册成功</title> </head> <body> <h1>注册成功</h1> <div> <div>用户名:${username}</div> <div>密码:${password}</div> <div>个人头像:<img src="data:image/png;base64,${avatar}" /></div> <div>省份:${province}</div> <div>爱好:${hobbies}</div> </div> </body> </html> ``` 3. 注册成功视图 当用户注册成功后,将跳转到success.jsp页面,该页面会显示所有注册信息。 4. 其他功能 在UserController类中添加了用户名密码非空校验用户名密码长度不能小于6位的长度校验。 5. 使用SpringMVC的拦截器对用户权限进行拦截 创建一个拦截器类,代码如下: ``` @Component public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(); Object user = session.getAttribute("user"); if (user == null) { response.sendRedirect(request.getContextPath() + "/login"); return false; } return true; } } ``` 在spring-mvc.xml文件中添加以下内容: ``` <mvc:interceptors> <bean class="com.example.interceptor.LoginInterceptor" /> </mvc:interceptors> ``` 以上就是一个基本的Spring MVC项目示例,您可以按照需求进行修改和完善。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值