此案例运用到session技术,可作为小练习。
cookie&session详细介绍点击这里。
验证码有生成模板,可以直接使用,名为CheckImgServlet.java,需要有一个名为new_words.txt的文件放在WEB-INF下。我们关注的是如何进行校验问题。
贴出目录树:
要校验验证码,首先少不了的就是输入框,所以我们需要一个jsp文件。
login.jsp:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<div><%=request.getAttribute("loginInfo")==null?"":request.getAttribute("loginInfo")%></div>
<form class="form-horizontal" action="/WEB_TEST/login" method="post">
<label>验证码</label>
<input type="text" name="checkCode" placeholder="请输入验证码">
<img src="/WEB_TEST/checkImg" />
<input type="submit" width="100" value="登录" name="submit">
</form>
</body>
</html>
然后贴出我们校验的代码,LoginServlet.java:
package cn.itclass.login;
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 {
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// 编码设置
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=UTF-8");
// 获得输入的验证码
String checkCode_client = (String) request.getParameter("checkCode");
// 获得生成的验证码
String checkCode_session = (String) request.getSession().getAttribute("checkcode_session");
// 两者进行比对,是否一致
if (!checkCode_client.equals(checkCode_session)) {
request.setAttribute("loginInfo", "您的验证码不正确!!!");
request.getRequestDispatcher("/login.jsp").forward(request, response);
return;
}else {
//此处为校验成功,然后获取用户名密码啥啥啥的,进行一堆操作。就不写了
response.getWriter().write("登陆成功");
}
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}
验证码生成的代码我就不放出来了,也是抄的别人的,直接去我的github下载整个项目就好了,验证码生成的文件也有相关说明,写得清楚明白点击此处。
版权声明:本文为qq_31851531原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。