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

网站用户存在状态的session用法及例子

问题?首先我们知道,在我们登录网站的时候,点击一个又一个链接,但是用户显示依然存在,这是为什么呢,

问题?首先我们知道,在我们登录网站的时候,点击一个又一个链接,但是用户显示依然存在,这是为什么呢,网站又是如何识别的呢?那怎么来做这个效果呢?接下来用一个例子及原理为大家说明。

原理:session的用法,当我们登陆验证成功后就在session中写一个标记,等点击链接的时候就会一直识别是否有这个标记。


HttpSession概述及原理探讨
得到HttpSession对象:
HttpServletRequest.getSession():根据特殊COOKIE(JSESSIONID=HttpSession对象的id,由服务器生成,唯一的)的取值,在服务器的内存中根据id查找这个HttpSession对象,找到了,取出来继续服务;没有找到,创建一个新的HttpSession对象。

第一步:建立jsp或者html页面

<%&#64; page language&#61;"java" import&#61;"java.util.*" pageEncoding&#61;"UTF-8"%>
<%
String path &#61; request.getContextPath();
String basePath &#61; request.getScheme()&#43;"://"&#43;request.getServerName()&#43;":"&#43;request.getServerPort()&#43;path&#43;"/";
%>
">
用 户 名&#xff1a;
密 码&#xff1a;
看不清


第二步&#xff1a;xml文件


day08IndexServletcom.dp.javaweb.login.IndexServletLandingServletcom.dp.javaweb.login.LandingServletLoginoutServletcom.dp.javaweb.login.LoginoutServletImageServletcom.dp.javaweb.login.ImageServletIndexServlet/servlet/IndexServletLandingServlet/servlet/LandingServletLoginoutServlet/servlet/LoginoutServletImageServlet/servlet/ImageServletLogin.jsp




第三步&#xff1a;画图验证码class类

package com.dp.javaweb.login;import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;public class ImageServlet extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException { //通知浏览器不要缓存response.setHeader("Expires", "-1");response.setHeader("Cache-Control", "no-cache");response.setHeader("Pragma", "-1");int height&#61;25;int width&#61;120;//得到一个内存图像BufferedImageBufferedImage img&#61;new BufferedImage(width, height, BufferedImage.TYPE_ INT_RGB);//得到一个画笔Graphics g&#61;img.getGraphics();//画边框drawRect绘制指定矩形的边框。g.drawRect(0, 0, width, height);//填充颜色g.setColor(Color.RED);g.fillRect(1, 1, width-2, height-2);//画干扰线g.setColor(Color.BLACK);Random r&#61;new Random();for(int i&#61;0;i<20;i&#43;&#43;)g.drawLine(r.nextInt(width), r.nextInt(height), r.nextInt(width), r.nextInt(height));//生成随机数字g.setColor(Color.BLUE);g.setFont(new Font("微软雅黑", Font.BOLD|Font.ITALIC, 20));//BOLD加粗&#xff0c;ITALIC斜体int d&#61;15;StringBuffer sb&#61;new StringBuffer();//可变字符串的利用for(int j&#61;0;j<4;j&#43;&#43;){String code&#61;r.nextInt(10)&#43;"";sb.append(code);g.drawString(code&#43;"", d, 20);d&#43;&#61;20;}//将验证码输入到session中&#xff0c;用来验证request.getSession().setAttribute("code", sb.toString());//输出打web页面ImageIO.write(img, "jpg", response.getOutputStream());}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);}}


第四步&#xff1a;处理用户密码验证码类(这里就开始利用session的作用&#xff0c;因为痛密码用户一样也在验证码出也写了一个session)

package com.dp.javaweb.login;import java.io.IOException;
import java.io.PrintWriter;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;/*** 处理用户密码**/
public class LandingServlet extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {request.setCharacterEncoding("UTF-8");response.setContentType("text/html;charset&#61;UTF-8");PrintWriter out&#61;response.getWriter();//验证用户和密码String username&#61;request.getParameter("username");String password&#61;request.getParameter("password");String code&#61;request.getParameter("code");//得到session中的session验证码String sessuoncode&#61;(String)request.getSession().getAttribute("code");//验证验证码if(!code.equals(sessuoncode)){out.write("登陆失败&#xff0c;错误的验证码&#xff01;&#xff01;重新登录");return;//不往下执行了}StringBuffer sb&#61;new StringBuffer(password);password&#61;sb.reverse().toString();//reverse()将此字符序列用其反转形式取代if(username.equals(password)){User user&#61;new User();user.setUsername(username);user.setPassword(password);//在把user对象放入session中&#xff0c;有了标记&#xff0c;这点儿很重要。request.getSession().setAttribute("user", user);out.write("登陆成功&#xff0c;2秒后自动返回到主页面&#xff01;&#xff01;");}else{out.write("登陆失败&#xff0c;2秒钟后自动返回到主页面&#xff01;&#xff01;");}response.setHeader("Refresh","2;URL&#61;/day08/servlet/IndexServlet");}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);}}


第五步&#xff1a;验证session是否存在&#xff0c;并处理登陆状态

package com.dp.javaweb.login;import java.io.IOException;
import java.io.PrintWriter;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;/*** 验证session中用户和密码**/
public class IndexServlet extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.setContentType("text/html;charset&#61;UTF-8");PrintWriter out&#61;response.getWriter();HttpSession session&#61;request.getSession();//创建session对象User user&#61;(User)session.getAttribute("user");//得到标记//session.setMaxInactiveInterval(2);//setMaxInactiveInterval表示2秒内不对session做出操作&#xff0c;自动删除session//一般情况下&#xff0c;不用设置这个函数,因为getMaxInactiveInterval()的session的默认失效为1800毫秒也就是半分钟//System.out.println(session.getMaxInactiveInterval());//打印默认session存在时间if(user&#61;&#61;null){out.write("请登陆");}else{out.write("欢迎您&#xff1a;"&#43;user.getUsername()&#43;"    注销");}out.write("


");out.write("主页&#xff1a;");}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);}}


第六步&#xff1a;注销功能的实现&#xff0c;这个功能主要是将写入session的标记去除掉或者将域中的标记联系中断

package com.dp.javaweb.login;import java.io.IOException;
import java.io.PrintWriter;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;//去掉session中的登陆标记&#xff0c;也就是用于注销
public class LoginoutServlet extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {response.setContentType("text/html;charset&#61;UTF-8");request.setCharacterEncoding("UTF-8");PrintWriter out&#61;response.getWriter();request.getSession().removeAttribute("user");//删除了域中绑定的对象
// request.getSession().invalidate();//这是直接销毁session&#xff0c;可任选一种out.write("注销成功&#xff0c;2秒后自动转入主页。");response.setHeader("Refresh", "2;URL&#61;/day08/servlet/IndexServlet");}public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {doGet(request, response);}}


第七步&#xff1a;封装用户密码的Bean类

package com.dp.javaweb.login;public class User {private String username;private String password;public String getUsername() {return username;}public void setUsername(String username) {this.username &#61; username;}public String getPassword() {return password;}public void setPassword(String password) {this.password &#61; password;}}


结果显示&#xff1a;

        

第一种情况&#xff1a;验证码错误

       

第二种情况&#xff1a;用户密码错误

       

第三种情况&#xff1a;登陆成功后

                    

最后的注销就不用我说了吧&#xff01;就是去掉session的标记。


注意&#xff1a;session.setMaxInactiveInterval(30 * 60);//单位秒&#xff0c;这是设置网页中session在缓存中的存在时间
   如果不设置的话&#xff0c;session,默认过期时间为30分钟也就是1800秒&#xff0c;

    session时间的另外一种设置方式&#xff0c;在另一边博客上写得有喔。


推荐阅读
  • 移动端常用单位——rem的使用方法和注意事项
    本文介绍了移动端常用的单位rem的使用方法和注意事项,包括px、%、em、vw、vh等其他常用单位的比较。同时还介绍了如何通过JS获取视口宽度并动态调整rem的值,以适应不同设备的屏幕大小。此外,还提到了rem目前在移动端的主流地位。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • FeatureRequestIsyourfeaturerequestrelatedtoaproblem?Please ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 本文总结了Java中日期格式化的常用方法,并给出了示例代码。通过使用SimpleDateFormat类和jstl fmt标签库,可以实现日期的格式化和显示。在页面中添加相应的标签库引用后,可以使用不同的日期格式化样式来显示当前年份和月份。该文提供了详细的代码示例和说明。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 本文介绍了使用Python解析C语言结构体的方法,包括定义基本类型和结构体类型的字典,并提供了一个示例代码,展示了如何解析C语言结构体。 ... [详细]
author-avatar
黄姐佛光普照_516
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有