- 浏览: 91106 次
文章分类
最新评论
会话Session and Cookie
1、session:用户打开一个网站,只要不关闭浏览器(服务器中间没重启),称这样的操作为一次会话。
2、Cookie :记录历史访问、保存用户名密码.可被多个浏览器共享,一个浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
cookie是以明文存放,安全性较低;
创建cookie
cookie是明文保存的;
读取cookie
页面取cookie:
value="<%=cookie1%>"
删除cookie:ck.setMaxAge(0);
设置为负数,在浏览器关闭时删除,相当于会话级别。
session的运用:购物车
第一次访问自动创建;cookie需要手动创建回送给浏览器一个http响应头,把sessionID带回给浏览器以cookie的方式,在会话结束或30分钟时清除
再次访问服务器时,web服务器内存接到request时读取到sessionID,就能在内存中查到该id的信息。
setAttribute(java.lang.String name, java.lang.Object value)
一个浏览器对应一个session对象,而cookie是可以是多个浏览器共存,cookie是对象数组
session是存在服务器的内存里的,不是存在浏览器中
注意游览器设置,单进程浏览器:无论打开多个浏览器都使用同一个session;一般来说是多进程浏览器,一个浏览器独享一个session
session的生命周期
默认是30分钟,在tomcat/web.xml中设置的
也可通过session.setMaxInac...(int) 设置
HttpSession session = request.getSession;
设置属性:
session.setAttribute("user",user);
获取属性
User u = session.getAttribute("user");
清除session的某个属性
session.removeAtrribute("user");
当用户成功登陆后,将用户信息存放在session内,不用每次都连接数据库验证,当内存肿么没有该用户信息时,要求登陆验证;
验证码:使用到java的绘图技术
image.jsp
login.jsp
禁用cookie和禁用session
1、浏览器设置禁用cookie(原session失效,将重新创建session,每次请求都要创建session)
2、实现禁用cookie后继续使用原session:url重写
c标签的遍历list/map
1、session:用户打开一个网站,只要不关闭浏览器(服务器中间没重启),称这样的操作为一次会话。
2、Cookie :记录历史访问、保存用户名密码.可被多个浏览器共享,一个浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
cookie是以明文存放,安全性较低;
创建cookie
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //Cookie(java.lang.String name, java.lang.String value) Cookie ck = new Cookie("cookie1", "name"); ck.setMaxAge(600);//600s //发送个浏览器 response.addCookie(ck); }
cookie是明文保存的;
读取cookie
Cookie[] ck = request.getCookies(); for(int i =0;i<ck.length;i++) { if("cookie1".equals(ck[i].getName())) { System.out.println(ck[i].getValue()); } }
页面取cookie:
value="<%=cookie1%>"
删除cookie:ck.setMaxAge(0);
设置为负数,在浏览器关闭时删除,相当于会话级别。
session的运用:购物车
第一次访问自动创建;cookie需要手动创建回送给浏览器一个http响应头,把sessionID带回给浏览器以cookie的方式,在会话结束或30分钟时清除
再次访问服务器时,web服务器内存接到request时读取到sessionID,就能在内存中查到该id的信息。
setAttribute(java.lang.String name, java.lang.Object value)
一个浏览器对应一个session对象,而cookie是可以是多个浏览器共存,cookie是对象数组
session是存在服务器的内存里的,不是存在浏览器中
注意游览器设置,单进程浏览器:无论打开多个浏览器都使用同一个session;一般来说是多进程浏览器,一个浏览器独享一个session
session的生命周期
默认是30分钟,在tomcat/web.xml中设置的
也可通过session.setMaxInac...(int) 设置
HttpSession session = request.getSession;
设置属性:
session.setAttribute("user",user);
获取属性
User u = session.getAttribute("user");
清除session的某个属性
session.removeAtrribute("user");
当用户成功登陆后,将用户信息存放在session内,不用每次都连接数据库验证,当内存肿么没有该用户信息时,要求登陆验证;
验证码:使用到java的绘图技术
image.jsp
<%@ page contentType="image/jpeg" import="java.awt.*, java.awt.image.*,java.util.*,javax.imageio.*" %> <%! Color getRandColor(int fc,int bc) { Random random = new Random(); if(fc>255) fc=255; if(bc>255) bc=255; int r=fc+random.nextInt(bc-fc); int g=fc+random.nextInt(bc-fc); int b=fc+random.nextInt(bc-fc); return new Color(r,g,b); } %> <% //out.clear();//这句针对resin服务器,如果是tomacat可以不要这句 response.setHeader("Pragma","No-cache"); response.setHeader("Cache-Control","no-cache"); response.setDateHeader("Expires", 0); //设置长高 int width=60, height=20; BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics g = image.getGraphics(); Random random = new Random(); g.setColor(getRandColor(200,250)); g.fillRect(0, 0, width, height); g.setFont(new Font("Times New Roman",Font.PLAIN,18)); g.setColor(getRandColor(160,200)); for (int i=0;i<155;i++) { int x = random.nextInt(width); int y = random.nextInt(height); int xl = random.nextInt(12); int yl = random.nextInt(12); g.drawLine(x,y,x+xl,y+yl); } String sRand=""; //设置位数 for (int i=0;i<4;i++){ String rand=String.valueOf(random.nextInt(10)); sRand+=rand; g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110))); g.drawString(rand,13*i+6,16); } // 将认证码存入SESSION session.setAttribute("rand",sRand); g.dispose(); ImageIO.write(image, "JPEG", response.getOutputStream()); out.clear(); out = pageContext.pushBody(); %>
login.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>login.jsp</title> <script language="javascript"> function loadimage(){ //加个随即数字是为了使每次访问image.jsp的地址不一样,这样浏览器不会取本地缓存的数据。 document.getElementById("checkid").src = "<%=path%>/pages/image.jsp?"+Math.random(); } </script> </head> <body> <% String str = (String)request.getAttribute("info"); if(null != str) response.getWriter().print(str); %> <form action="<%=path%>/servlet/LoginCk" method="post" style="margin-left: 40% ;margin-top: 8%" > 用户id:<input type="text" name="id"><br> 密 码:<input type="password" name="pwd"><br> 验证码: <input type="text" name="checkid"><img border=0 id="checkid" src="<%=path%>/pages/image.jsp"/> <a href="javascript:loadimage();">看不清点我</font></a> <br> <input type="submit"> <input type="reset"> </form> </body> </html>
禁用cookie和禁用session
1、浏览器设置禁用cookie(原session失效,将重新创建session,每次请求都要创建session)
2、实现禁用cookie后继续使用原session:url重写
c标签的遍历list/map
<%-- <c:forEach items="${books}" var="vo"> ${vo}<br/> </c:forEach> --%> id----> 书 名---->购买数量<br/> <c:forEach items="${books}" var="vo"> ${vo.key}----> ${vo.value.name}---->${vo.value.num}<br/> </c:forEach> <br/>
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String id = request.getParameter("id").trim(); String name = request.getParameter("name").trim(); HttpSession session = request.getSession(); HashMap<String, Book> hm = (HashMap<String, Book>)session.getAttribute("books"); if(null == hm) { hm = new HashMap<String, Book>(); Book b = new Book(); b.setId(Integer.parseInt(id)); b.setName(name); b.setNum(1); session.setAttribute("books", hm); }else { //已经购买,数量+1 if(hm.containsKey(id)) { Book b = hm.get(id); b.setNum(b.getNum()+1); hm.put(id, b); } //第一次购买 else { Book b = new Book(); b.setId(Integer.parseInt(id)); b.setName(name); b.setNum(1); hm.put(id, b); } } /*ArrayList list = (ArrayList)session.getAttribute("books"); if(null == list) { list = new ArrayList(); } list.add(book);*/ session.setAttribute("books", hm); request.getRequestDispatcher("/pages/booklist.jsp").forward(request, response); return; }
发表评论
-
41、解决HttpServletResponse输出的中文乱码问题
2015-04-12 21:48 1215response返回有两种,一种是字节流outputs ... -
41、轮询
2015-04-12 08:50 0浏览器关闭使session失效 ... -
40、spring ajax/easyui 中文乱码的解决
2015-04-04 14:52 692使用spingmvc,在JS里面通过ajax发送请求,并 ... -
39、.net
2015-03-28 23:12 543熟悉java编程,自然学习c#就会比较容易,有几个点需要说明下 ... -
38、servlet-- JSTL+EL(c标签、${})
2015-03-23 15:57 780参看:http://www.cnblogs.com/xdp-g ... -
37、servlet--jsp
2015-03-23 15:07 493不管是JSP还是Servlet,虽然都可以用于开发动 ... -
36、servlet--防止表单重复提交
2015-03-23 14:33 7101、在网络延迟会或服务器反应过慢的情况下让用户有时间点击多次s ... -
35、servlet--servletContext
2015-03-22 13:41 475servletContext接口是Servlet中最大的一个接 ... -
33、servlet--转发/web开发指导思想
2015-03-21 12:31 445转发: req.getRequestDispatcher(&q ... -
32、servlet --重定向/下载/缓存/中文乱码
2015-03-20 23:21 1055重定向1、sendRedirect rep.sendRedir ... -
31、servlet--开发方式
2015-03-20 21:55 634servlet:利用java技术开发动态网页的技术,是学习ja ... -
30、servlet---tomcat原理
2015-03-20 18:20 675Servlet出现得早,servlet很强大,但是se ... -
29、servlet--jsp执行过程
2015-03-20 15:08 446J2EE的13种核心技术:JDBC、JNDI、EJBs、 ... -
29、springmvc+spring+mybatis+oracle12的demo
2015-03-15 20:29 0每次搭建都要重头搭建,累~~ 注意:用12c的jdbc 在安 ... -
27、Tomcat多次加载项目问题
2015-03-12 15:30 563错误配置方式: <Host name="lo ... -
26、数据分页(jsp+servlet)
2015-03-12 15:19 472随着数据库中存储的数据的增多,满足用户查询条件的数据也 ... -
llll.文档设计
2015-03-11 13:31 0设计文档与代码实现到 ... -
24、webservice_短信接口
2015-03-11 10:48 801http://blog.csdn.net/sxdtzhaoxi ... -
25、RMI_demo1
2015-03-11 10:48 426Java RMI 指的是远程方法调用 (Remote Meth ... -
23、svn
2015-03-11 10:48 422<参看>http://blog.csdn.net/ ...
相关推荐
这个"Servlet的小demo"应该是对Servlet基础概念、配置和实现的一个简单示例。让我们详细了解一下Servlet及其相关知识。 1. **Servlet概述**: Servlet是一个Java类,它扩展了Java平台的服务能力,特别是对于Web...
通过这个“springmvc写一个购物车demo”,开发者不仅可以学习Spring MVC的基本用法,还能了解到如何在实际项目中整合数据库操作、会话管理、视图渲染等多个环节,对整个Web开发流程有更深入的理解。这个小型项目是一...
Servlet 会话技术详解 在 Web 应用程序中,会话是一种非常重要的概念,用于记录和跟踪用户的交互行为。Servlet 提供了两种类型的会话技术,即 Cookie 和 Session,下面我们将详细介绍这两种技术的实现原理和应用...
JavaWeb Servlet版图书商城Demo是一个基于JavaWeb技术的在线图书销售平台示例,适用于那些已经对JavaWeb有基本了解的学习者。这个项目旨在提供一个实际的、可运行的应用程序,帮助开发者理解如何在Web环境中使用...
在本项目中,“购物车java项目源码”是一个基于Java Web技术实现的电子商务系统的核心模块。这个项目展示了如何使用Java编程语言以及相关的Web框架来构建一个功能完备的购物车系统。下面将详细介绍该项目中涉及的...
在Servlet中实现购物车,通常会涉及到以下几个关键技术点: 1. **HTTP协议与Servlet生命周期**:Servlet主要通过HTTP协议与客户端进行通信。当用户发起一个HTTP请求时,Servlet容器(如Tomcat)会创建或复用Servlet...
本案例“java购物车”是基于Servlet技术实现的一个简单购物车示例,非常适合初学者学习和理解Web开发中的会话管理机制。以下是这个购物车案例中的核心知识点: 1. **Servlet基础**:Servlet是Java Web开发中的重要...
【标题】"jsp小demo-新手级别"是一个适合初学者的JavaServer Pages(JSP)实践项目,旨在帮助新接触JSP技术的开发者快速掌握基本功能的实现。 【描述】中提到的功能涵盖了Web应用程序开发中常见的用户交互和数据...
总的来说,ServletCookie DEMO是一个实用的学习资源,它涵盖了Web开发中重要的用户会话管理技术。通过分析和实践这个DEMO,开发者可以更深入地理解Servlet和Cookie的工作原理,以及如何在Java Web应用中有效地利用...
【京东网购商城demo】是一个适合初学者学习的项目,它主要展示了如何利用AJAX、Servlet以及JSP等Java技术来构建一个基本的在线购物平台。在这个项目中,用户可以完成登录、注册、注销等基本操作,同时也能浏览商品...
本教程分析了 Spring Web Flow 2.0 的技术要点,并且通过创建一个示例应用程序,展示了 Spring Web Flow 2.0 的基本知识。 开始之前 关于本教程 本教程通过一个简化的购物车应用,介绍了如何使用 Spring Web Flow ...
本项目"最简单的servlet增删改查示例小项目"是一个非常适合初学者上手的实践案例,它通过Servlet技术实现了一个简单的购物车功能,包括了商品列表展示、添加到购物车、删除购物车商品、修改购物车商品数量以及查看...
在JavaWeb开发中,JSP(JavaServer Pages)是一种用于创建动态网页的技术,而内置对象是JSP为我们提供的便利工具,无需显式实例化即可直接使用。本作业的主题是使用JSP内置对象`session`来实现一个简单的购物车功能...
综上所述,这些知识点涵盖了使用 Java Web 技术进行基本应用开发的主要方面,包括用户认证、会话管理以及数据持久化等关键环节。通过理解和掌握这些技术点,可以帮助开发者构建更加安全、高效的应用系统。
【标题】"jvm_session_demo:jvm 会话演示"主要关注的是Java虚拟机(JVM)在处理会话管理中的应用。会话是Web应用程序中一个关键的概念,它允许服务器跟踪用户的状态和行为,特别是在状态无状态的HTTP协议中。JVM在此...
在IT领域,尤其是在Web开发中,会话管理和用户身份验证是至关重要的部分。"cookie_demo2.zip"这个压缩包文件似乎包含了一个关于Cookie使用的示例,特别是关注于Cookie的生命周期。接下来,我们将深入探讨Cookie、...
5. **会话管理**:通过session对象,源码可能实现了用户会话的跟踪,例如保持登录状态、购物车数据等。 6. **电子商务功能**:可能包括商品展示、搜索、添加到购物车、订单处理、支付接口模拟等实际的电子商务场景。...
【标题】"简单的电商项目"揭示了这是一个针对电商领域的初级示例项目,主要基于Java的Servlet技术进行构建。Servlet是Java EE(企业版)中用于处理HTTP请求的核心组件,广泛应用于服务器端编程,尤其在构建Web应用时...
1. **Java Web开发基础**:项目基于Java Web技术栈,这包括了Servlet、JSP(JavaServer Pages)和JSTL(JavaServer Pages Standard Tag Library)。Servlet是Java编写服务器端应用程序的核心,用于处理HTTP请求;JSP...
通过这个项目,学生可以深入了解Java Web开发,尤其是JSP和Servlet技术在实际项目中的应用。JSPWiki作为一款协作工具,展示了如何使用Java技术来实现动态内容生成和用户交互,这对于初学者理解Web应用程序的架构和...