07-验证码登录
LoginServlet.java ============》
package com.gyf.web.servlet.lesson07; import java.io.IOException; 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 { @Override protected void doPost(HttpServletRequest requeset, HttpServletResponse response) throws ServletException, IOException { response.setHeader("content-type", "text/html;charset=utf-8"); //1.获取请求参数 String username = requeset.getParameter("username"); String password = requeset.getParameter("password"); String client_code = requeset.getParameter("code"); //2.获取服务端的code String server_code = (String) requeset.getSession().getAttribute("code"); if(server_code == null){ response.getWriter().write("请刷新上一个页面"); return; } //3.验证码对比 if(!server_code.equalsIgnoreCase(client_code)){ response.getWriter().write("验证码不对"); }else{ if("gyf".equals(username) && "123".equals(password)){ response.getWriter().write("登录成功"); }else{ response.getWriter().write("登录失败"); } } //4.把验证码从服务器删除 //requeset.getSession().removeAttribute("code"); requeset.getSession().invalidate();//让session的所有数据都删除 System.out.println(requeset.getSession().getAttribute("code")); } }
ValidateCodeServlet.java ==========》
package com.gyf.web.servlet.lesson07; import java.io.IOException; 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 javax.servlet.http.HttpSession; import cn.dsna.util.images.ValidateCode; /** * 验证码的Servlet */ @WebServlet("/ValidateCodeServlet") public class ValidateCodeServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //1.生成验证 ValidateCode vc = new ValidateCode(100, 30, 4, 6); System.out.println("生成的验证码:" + vc.getCode()); //如果客户端传来sessionid,但是服务端面没有对应id的session对象,这个方法没有返回值 //If create is false and the request has no valid HttpSession, this method returns null. /** * request.getSession(false); * 文档是,请求中没有一个合法的sessionid,这个方法就返回null * 情况:浏览器传了sessionid,但是服务器已经没有这个sessionid对应的session对象,但是不是返回一个session对象 * 浏览器没传sessionid,服务器返回null * 演示结果: */ HttpSession session = request.getSession(); System.out.println(session); /* //2.把验证码存在session session.setAttribute("code", vc.getCode()); //3.取session的ID System.out.println("SessionID:" + session.getId()); //设置session的存活时间 //request.getSession().setMaxInactiveInterval(30); */ vc.write(response.getOutputStream()); } }
分类:
Servlet实战应用
, java Session概述
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?