热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java记住用户名和密码_JAVA高级基础开发Cookie实现记住用户名和密码

前端JSP页面:实现保存用户名和密码Cookie用户名Stringuser;登录密码Stringpass;复选框是否选中Stringchecked;获取的是请求里的所有

前端JSP页面: 实现保存用户名和密码

COOKIE

// 用户名

String user = "";

// 登录密码

String pass = "";

// 复选框是否选中

String checked = "";

// 获取的是请求里的所有COOKIE组成的数组

COOKIE[] COOKIEs = request.getCOOKIEs();

// 如果COOKIEs数组不为空对其进行遍历

if (COOKIEs != null && COOKIEs.length > 0) {

// 循环遍历COOKIE

for (int i = 0; i

// 获取COOKIE对象

COOKIE COOKIE = COOKIEs[i];

// 将创建的COOKIE名与获取的COOKIE数组中已经存在的COOKIE名进行比较

if ("name".equals(COOKIE.getName())) {

// "name"是在另一个jsp文件中创建的COOKIE名

// 获取名字叫做"name"的COOKIE的值

user = URLDecoder.decode(COOKIE.getValue(), "utf-8");

// 将“记住用户名”设置为勾选

checked = "checked";

}

// 将创建的COOKIE名与获取的COOKIE数组中已经存在的COOKIE名进行比较

if ("password".equals(COOKIE.getName())) {

// "password"是在另一个jsp文件中创建的COOKIE名

// 获取名字叫做"password"的COOKIE的值

pass = COOKIE.getValue();

}

}

}

%>

用户登录

指的是将获取的COOKIE值放进输入框内--%>

用户名:

密码:

记住用户名和密码

后端Servlet验证:

import javax.servlet.ServletException;

import javax.servlet.annotation.WebServlet;

import javax.servlet.http.COOKIE;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.IOException;

import java.io.PrintWriter;

@WebServlet("/Login3")

public class Login3 extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

doPost(req, resp);

}

@Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

//设置请求的编码

req.setCharacterEncoding("utf-8");

//获取请求中的参数

String name=req.getParameter("name");

String password=req.getParameter("password");

String remember=req.getParameter("remember");

//设置响应的文本信息

resp.setContentType("text/html;charset=UTF-8");

PrintWriter out=resp.getWriter();

//判断用户名和密码是否正确

if(name.equals("Admin")&&password.equals("000000")){

// 新建名为name的COOKIE

COOKIE nameCOOKIE = new COOKIE("name",name);

// 新建名为password的COOKIE

COOKIE passwordCOOKIE = new COOKIE("password", password);

// 判断复选框是否被选中,如果选中则返回on

if (remember.equals("on")) {

// 设置保存COOKIE的时间长度,

nameCOOKIE.setMaxAge(60*60*24*7); //7天

passwordCOOKIE.setMaxAge(60*60*24*7);

} else {

// 设置将不保存COOKIE

nameCOOKIE.setMaxAge(0);

passwordCOOKIE.setMaxAge(0);

}

// 输出到客户端

resp.addCOOKIE(nameCOOKIE);

resp.addCOOKIE(passwordCOOKIE);

// 登录成功后跳转到success.jsp

req.getRequestDispatcher("success.jsp").forward(req, resp);

}else if (!name.equals("Admin") && password.equals("000000")) {// 如果用户名不正确,密码正确

// 保存错误提示数据

req.setAttribute("error", "用户名不正确");

// 登录失败后将跳转到error.jsp

req.getRequestDispatcher("error.jsp").forward(req, resp);

} else if (name.equals("Admin") && !password.equals("000000")) {// 如果用户名正确,密码不正确

// 保存错误提示数据

req.setAttribute("error", "密码不正确");

// 登录失败后将跳转到error.jsp

req.getRequestDispatcher("error.jsp").forward(req, resp);

} else {// 如果用户名和密码都不正确

// 保存错误提示数据

req.setAttribute("error", "用户名和密码都不正确");

// 登录失败后将跳转到error.jsp

req.getRequestDispatcher("error.jsp").forward(req, resp);

}

}

}



推荐阅读
  • 网站访问全流程解析
    本文详细介绍了从用户在浏览器中输入一个域名(如www.yy.com)到页面完全展示的整个过程,包括DNS解析、TCP连接、请求响应等多个步骤。 ... [详细]
  • 在本文中,我们将为 HelloWorld 项目添加视图组件,以确保控制器返回的视图路径能够正确映射到指定页面。这一步骤将为后续的测试和开发奠定基础。首先,我们将介绍如何配置视图解析器,以便 SpringMVC 能够识别并渲染相应的视图文件。 ... [详细]
  • 浅析python实现布隆过滤器及Redis中的缓存穿透原理_python
    本文带你了解了位图的实现,布隆过滤器的原理及Python中的使用,以及布隆过滤器如何应对Redis中的缓存穿透,相信你对布隆过滤 ... [详细]
  • javascript分页类支持页码格式
    前端时间因为项目需要,要对一个产品下所有的附属图片进行分页显示,没考虑ajax一张张请求,所以干脆一次性全部把图片out,然 ... [详细]
  • 如何将TS文件转换为M3U8直播流:HLS与M3U8格式详解
    在视频传输领域,MP4虽然常见,但在直播场景中直接使用MP4格式存在诸多问题。例如,MP4文件的头部信息(如ftyp、moov)较大,导致初始加载时间较长,影响用户体验。相比之下,HLS(HTTP Live Streaming)协议及其M3U8格式更具优势。HLS通过将视频切分成多个小片段,并生成一个M3U8播放列表文件,实现低延迟和高稳定性。本文详细介绍了如何将TS文件转换为M3U8直播流,包括技术原理和具体操作步骤,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 在 Axublog 1.1.0 版本的 `c_login.php` 文件中发现了一个严重的 SQL 注入漏洞。该漏洞允许攻击者通过操纵登录请求中的参数,注入恶意 SQL 代码,从而可能获取敏感信息或对数据库进行未授权操作。建议用户尽快更新到最新版本并采取相应的安全措施以防止潜在的风险。 ... [详细]
  • 本文详细介绍了如何在 Linux 系统上安装 JDK 1.8、MySQL 和 Redis,并提供了相应的环境配置和验证步骤。 ... [详细]
  • 属性类 `Properties` 是 `Hashtable` 类的子类,用于存储键值对形式的数据。该类在 Java 中广泛应用于配置文件的读取与写入,支持字符串类型的键和值。通过 `Properties` 类,开发者可以方便地进行配置信息的管理,确保应用程序的灵活性和可维护性。此外,`Properties` 类还提供了加载和保存属性文件的方法,使其在实际开发中具有较高的实用价值。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 2012年9月12日优酷土豆校园招聘笔试题目解析与备考指南
    2012年9月12日,优酷土豆校园招聘笔试题目解析与备考指南。在选择题部分,有一道题目涉及中国人的血型分布情况,具体为A型30%、B型20%、O型40%、AB型10%。若需确保在随机选取的样本中,至少有一人为B型血的概率不低于90%,则需要选取的最少人数是多少?该问题不仅考察了概率统计的基本知识,还要求考生具备一定的逻辑推理能力。 ... [详细]
  • Sanic 是一个类似于 Flask 的 Python 3.5 Web 服务器,以其出色的写入速度而著称。与 Flask 不同,Sanic 支持异步请求处理,这使得它在处理高并发请求时表现更加出色。通过利用 Python 的异步特性,Sanic 能够显著提高应用程序的性能和响应能力,适用于构建高性能的异步 Web 应用。 ... [详细]
  • 在PHP的设计中,预定义了9个超级全局变量、8个魔术变量和13个魔术函数,这些变量和函数无需声明即可在脚本的任意位置使用。这些特性在PHP开发中极为常见,能够显著提升开发效率和代码的灵活性。相比之下,Java并没有类似的内置机制,但通过其他方式如上下文对象和反射机制,也可以实现类似的功能。本文将详细探讨这两种语言中这些特殊变量和函数的使用方法及其应用场景。 ... [详细]
  • 本文介绍了一种利用PHP cURL库高效提取Sohu邮箱联系人列表的方法。通过设置错误报告级别、定义Cookie文件路径等关键步骤,确保了代码的稳定性和可靠性。经过实际测试,该方法在2012年3月24日被验证为有效,能够快速准确地获取联系人信息。此外,文章还提供了详细的代码示例和注意事项,帮助开发者更好地理解和应用这一技术。 ... [详细]
  • 本文深入探讨了ASP.NET中ViewState、Cookie和Session三种状态管理技术的区别与应用场景。ViewState主要用于保存页面控件的状态信息,确保在多次往返服务器过程中数据的一致性;Cookie则存储在客户端,适用于保存少量用户偏好设置等非敏感信息;而Session则在服务器端存储数据,适合处理需要跨页面保持的数据。文章详细分析了这三种技术的工作原理及其优缺点,并提供了实际应用中的最佳实践建议。 ... [详细]
author-avatar
mobiledu2502861133
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有