加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

jsp如何达成短期内免除重复输账号密码

发布时间:2023-06-08 11:20:10 所属栏目:语言 来源:
导读:这篇文章给大家介绍了“jsp如何实现短期内免除重复输账号密码”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。本文实例为大

这篇文章给大家介绍了“jsp如何实现短期内免除重复输账号密码”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。

本文实例为大家分享了jsp实现简单用户7天内免登录的具体代码,供大家参考,具体内容如下:

(1)登陆页面: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>

<form action="LoginServlet" method="post">

用户名:<input type="text" name="username" value="${cookie.cook_name.value }"/><br/>

<input type="checkbox" name="chkCookie" value="7"/>记住我,7天内免登录<br/>

<input type="submit" value="登录"/><br/>

<a href="sessionUser.jsp" rel="external nofollow" >验证session</a>

<a href="cookieUser.jsp" rel="external nofollow" >验证cookie</a>

</form>

</body>

</html>

(2)跳转页面:cookieUser.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>

<%

//从浏览器获取cookie

Cookie[] cookies = request.getCookies();

String uname = null;

//判断语句条件小技巧

if(null != cookies){

for(Cookie cookie:cookies){

//遍历本地浏览器中的所有cookie

if(cookie.getName().equals("cook_name")){

//把cookie中的用户名取出

uname = cookie.getValue();

}

//out.print("<p>name: " + cookie.getName()+"</p>");

//out.print("<p>value: " + cookie.getValue()+"</p>");

}

}

//判断cookie有没有失效

if(null != uname){

out.print("<p>用户名:"+uname +"</p>");

}

else{

response.sendRedirect("login.jsp");

}

%>

</body>

</html>

(3)Servlet文件:LoginServlet类

package com.servlet;

import java.io.IOException;

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 javax.servlet.http.HttpSession;

/**

* Servlet implementation class LoginServlet

*/

@WebServlet("/LoginServlet")

public class LoginServlet extends HttpServlet {

private static final long serialVersionUID = 1L;

/**

* @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

//获取用户登录名

String username = request.getParameter("username");

//获取7天内是否免登录

String day7 = request.getParameter("chkCookie");

int cookie_day = 1;

if(null != day7 && day7.equals("")){

cookie_day = Integer.valueOf(day7);

}

//创建cookie

Cookie cookie = new Cookie("cook_name",username);

//设置Cookie有限期

//cookie.setMaxAge(6);//有效期6秒

cookie.setMaxAge(3600 * 24 * cookie_day);//设置7天免登录

//写入cookie到浏览器

response.addCookie(cookie);

response.sendRedirect("cookieUser.jsp");

}

/**

* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)

*/

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

// TODO Auto-generated method stub

doGet(request, response);

}

}

以上就是关于“jsp如何实现短期内免除重复输账号密码”的介绍了,感谢各位的阅读,希望这篇文章能帮助大家解决问题。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!