`

34、servlet--会话技术/购物车demo/y验证码

    博客分类:
  • mvc
 
阅读更多
会话Session and Cookie
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;  
	}
  • 大小: 6.8 KB
  • 大小: 8.7 KB
分享到:
评论

相关推荐

    servlet的小demo

    这个"Servlet的小demo"应该是对Servlet基础概念、配置和实现的一个简单示例。让我们详细了解一下Servlet及其相关知识。 1. **Servlet概述**: Servlet是一个Java类,它扩展了Java平台的服务能力,特别是对于Web...

    springmvc写一个购物车demo

    通过这个“springmvc写一个购物车demo”,开发者不仅可以学习Spring MVC的基本用法,还能了解到如何在实际项目中整合数据库操作、会话管理、视图渲染等多个环节,对整个Web开发流程有更深入的理解。这个小型项目是一...

    实验5 会话及其会话技术.docx

    Servlet 会话技术详解 在 Web 应用程序中,会话是一种非常重要的概念,用于记录和跟踪用户的交互行为。Servlet 提供了两种类型的会话技术,即 Cookie 和 Session,下面我们将详细介绍这两种技术的实现原理和应用...

    javaWEB servlet版 图书商城demo

    JavaWeb Servlet版图书商城Demo是一个基于JavaWeb技术的在线图书销售平台示例,适用于那些已经对JavaWeb有基本了解的学习者。这个项目旨在提供一个实际的、可运行的应用程序,帮助开发者理解如何在Web环境中使用...

    购物车java项目源码

    在本项目中,“购物车java项目源码”是一个基于Java Web技术实现的电子商务系统的核心模块。这个项目展示了如何使用Java编程语言以及相关的Web框架来构建一个功能完备的购物车系统。下面将详细介绍该项目中涉及的...

    servlet版的购物车

    在Servlet中实现购物车,通常会涉及到以下几个关键技术点: 1. **HTTP协议与Servlet生命周期**:Servlet主要通过HTTP协议与客户端进行通信。当用户发起一个HTTP请求时,Servlet容器(如Tomcat)会创建或复用Servlet...

    java购物车案例

    本案例“java购物车”是基于Servlet技术实现的一个简单购物车示例,非常适合初学者学习和理解Web开发中的会话管理机制。以下是这个购物车案例中的核心知识点: 1. **Servlet基础**:Servlet是Java Web开发中的重要...

    jsp小demo-新手级别

    【标题】"jsp小demo-新手级别"是一个适合初学者的JavaServer Pages(JSP)实践项目,旨在帮助新接触JSP技术的开发者快速掌握基本功能的实现。 【描述】中提到的功能涵盖了Web应用程序开发中常见的用户交互和数据...

    ServletCookie DEMO

    总的来说,ServletCookie DEMO是一个实用的学习资源,它涵盖了Web开发中重要的用户会话管理技术。通过分析和实践这个DEMO,开发者可以更深入地理解Servlet和Cookie的工作原理,以及如何在Java Web应用中有效地利用...

    京东网购商城demo

    【京东网购商城demo】是一个适合初学者学习的项目,它主要展示了如何利用AJAX、Servlet以及JSP等Java技术来构建一个基本的在线购物平台。在这个项目中,用户可以完成登录、注册、注销等基本操作,同时也能浏览商品...

    spring web flow demo

    本教程分析了 Spring Web Flow 2.0 的技术要点,并且通过创建一个示例应用程序,展示了 Spring Web Flow 2.0 的基本知识。 开始之前 关于本教程 本教程通过一个简化的购物车应用,介绍了如何使用 Spring Web Flow ...

    最简单的servlet增删改查示例小项目

    本项目"最简单的servlet增删改查示例小项目"是一个非常适合初学者上手的实践案例,它通过Servlet技术实现了一个简单的购物车功能,包括了商品列表展示、添加到购物车、删除购物车商品、修改购物车商品数量以及查看...

    javaweb作业jsp内置对象作业:使用session完成简单购物车功能

    在JavaWeb开发中,JSP(JavaServer Pages)是一种用于创建动态网页的技术,而内置对象是JSP为我们提供的便利工具,无需显式实例化即可直接使用。本作业的主题是使用JSP内置对象`session`来实现一个简单的购物车功能...

    基于javaweb上机报告.doc

    综上所述,这些知识点涵盖了使用 Java Web 技术进行基本应用开发的主要方面,包括用户认证、会话管理以及数据持久化等关键环节。通过理解和掌握这些技术点,可以帮助开发者构建更加安全、高效的应用系统。

    jvm_session_demo:jvm 会话演示

    【标题】"jvm_session_demo:jvm 会话演示"主要关注的是Java虚拟机(JVM)在处理会话管理中的应用。会话是Web应用程序中一个关键的概念,它允许服务器跟踪用户的状态和行为,特别是在状态无状态的HTTP协议中。JVM在此...

    cookie_demo2.zip

    在IT领域,尤其是在Web开发中,会话管理和用户身份验证是至关重要的部分。"cookie_demo2.zip"这个压缩包文件似乎包含了一个关于Cookie使用的示例,特别是关注于Cookie的生命周期。接下来,我们将深入探讨Cookie、...

    [工具查询]淘特JSP探针_tot-jsp-check.zip

    5. **会话管理**:通过session对象,源码可能实现了用户会话的跟踪,例如保持登录状态、购物车数据等。 6. **电子商务功能**:可能包括商品展示、搜索、添加到购物车、订单处理、支付接口模拟等实际的电子商务场景。...

    简单的电商项目

    【标题】"简单的电商项目"揭示了这是一个针对电商领域的初级示例项目,主要基于Java的Servlet技术进行构建。Servlet是Java EE(企业版)中用于处理HTTP请求的核心组件,广泛应用于服务器端编程,尤其在构建Web应用时...

    基于JAVA的网上图书超市

    1. **Java Web开发基础**:项目基于Java Web技术栈,这包括了Servlet、JSP(JavaServer Pages)和JSTL(JavaServer Pages Standard Tag Library)。Servlet是Java编写服务器端应用程序的核心,用于处理HTTP请求;JSP...

    [博客空间]JSPWiki ALPHA release v2.3.92_jspwiki-2.3.92-alpha-src.zip

    通过这个项目,学生可以深入了解Java Web开发,尤其是JSP和Servlet技术在实际项目中的应用。JSPWiki作为一款协作工具,展示了如何使用Java技术来实现动态内容生成和用户交互,这对于初学者理解Web应用程序的架构和...

Global site tag (gtag.js) - Google Analytics