Session案例:简易的购物车
三个jsp和两个Servlet组成:在WebContent下边建立一个shoppingcart文件夹,将三个jsp文件放在里面:
1.建立一个step1.jsp文件,出现一个表格,是一个复选框,可以选择要购买的书籍,完毕后,点击Submit,跳转到Servlet类 ProcessStep1Servlet里面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h2>step1: 选择要购买的书籍!</h2> <form action="<%= request.getContextPath() %>/processStep1Servlet" method="post"> <table border="1" cellpadding="10" cellspacing="0">
<tr>
<th>书名</th>
<th>点击购买</th>
</tr> <tr>
<td>Oracle</td>
<td><input type="checkbox" name="book" value="Oracle"/></td>
</tr> <tr>
<td>java</td>
<td><input type="checkbox" name="book" value="java"/></td>
</tr> <tr>
<td>C++</td>
<td><input type="checkbox" name="book" value="C++"/></td>
</tr> <tr>
<td>mysql</td>
<td><input type="checkbox" name="book" value="mysql"/></td>
</tr> <tr>
<td>WEB</td>
<td><input type="checkbox" name="book" value="WEB"/></td>
</tr> <tr>
<td colspan="2"> <input type="submit" value="Submit"/></td>
</tr> </table> </form>
</body>
</html>
2.建立一个Servlet类 ProcessStep1Servlet,里面有doPost方法,可实现session方法(好处就是获取用户选择书名的id,保存到后边再使用),获取用户选择的书名,使绝对路径的方法重定向到step1.jsp页面; response.sendRedirect(request.getContextPath()+"/shoppingcart/step2.jsp");
public class ProcessStep1Servlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1. 获取选中的图书的信息
String [] books = request.getParameterValues("book");
//2. 把图书信息放入到 HttpSession 中
request.getSession().setAttribute("books", books);
//2. 重定向页面到 shoppingcart/step-2.jsp
System.out.println(request.getContextPath() + "/shoppingcart/step-2.jsp");
response.sendRedirect(request.getContextPath() + "/shoppingcart/step-2.jsp");
}
}
3.在step2.jsp页面,是用户输入个人信息页面,付款,发送货物需要的信息,然后跳转到Servlet类 processStep2Servlet 对用户的信息封装到customer类里面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h2>step2: 请输入寄送地址和信用卡</h2> <form action="<%= request.getContextPath() %>/processStep2Servlet" method="post">
<table border="1" cellpadding="10" cellspacing="0">
<tr>
<td colspan="2">寄送信息:</td>
</tr> <tr>
<td>姓名:</td>
<td><input type="text" name="name"/></td>
</tr> <tr>
<td>地址:</td>
<td><input type="text" name="address"/></td>
</tr> <tr>
<td>联系电话:</td>
<td><input type="text" name="phone"/></td>
</tr> <tr >
<td colspan="2">信用卡信息:</td>
</tr> <tr>
<td>信用卡种类</td>
<td>
<input type="radio" name="cardType" value="nong"/>nong
<input type="radio" name="cardType" value="gong"/>gong
</td> </tr> <tr>
<td>信用卡号:</td>
<td><input type="text" name="card"/></td>
</tr> <tr>
<td colspan="2"> <input type="submit" value="Submit"/></td>
</tr>
</table> </form>
</body>
</html>
4.建立一个Servlet类,里面有doPost方法,对用户的信息封装到customer类里面,session实例,保存用户的id信息,便于后边输出,然后重定向到confirm.jsp页面 ,跳转一面使用了绝对路径:response.sendRedirect(request.getContextPath()+"/shoppingcart/confirm.jsp");
public class ProcessStep2Servlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1. 获取请求参数: name, address, cardType, card
String name = request.getParameter("name");
String address = request.getParameter("address");
String cardType = request.getParameter("cardType");
String card = request.getParameter("card");
Customer customer = new Customer(name, address, cardType, card);
//2. 把请求信息存入到 HttpSession 中
HttpSession session = request.getSession();
session.setAttribute("customer", customer);
//3. 重定向页面到 confirm.jsp
response.sendRedirect(request.getContextPath() + "/shoppingcart/confirm.jsp");
}
}
5.confirm.jsp页面,使用了session实例,将前边的用户选择的书籍和用户输入的个人信息,输出到这个页面
<%@page import="com.lanqiao.javatest.Customer"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
Customer customer=(Customer)session.getAttribute("customer");
String [] books=(String [])session.getAttribute("books");
%> <h2>信息表单</h2>
<table>
<tr>
<td>顾客姓名:</td>
<td><%=customer.getName() %></td>
</tr> <tr>
<td>顾客地址:</td>
<td><%=customer.getAddress() %></td>
</tr> <tr>
<td>顾客联系电话:</td>
<td><%=customer.getPhone() %></td>
</tr> <tr>
<td>顾客卡类型:</td>
<td><%=customer.getCardType() %></td>
</tr> <tr>
<td>顾客的卡号:</td>
<td><%=customer.getCard() %></td>
</tr> <tr>
<td>您购买的书:</td>
<td>
<%
for(String book:books){
out.print(book);
out.print("\t\t");
}
%>
</td> </tr> </table>
</body>
</html>
6.lib下边的web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<servlet>
<description></description>
<display-name>ProcessStep1Servlet</display-name>
<servlet-name>ProcessStep1Servlet</servlet-name>
<servlet-class>com.lanqiao.javatest.ProcessStep1Servlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ProcessStep1Servlet</servlet-name>
<url-pattern>/processStep1Servlet</url-pattern>
</servlet-mapping>
<servlet>
<description></description>
<display-name>ProcessStep2Servlet</display-name>
<servlet-name>ProcessStep2Servlet</servlet-name>
<servlet-class>com.lanqiao.javatest.ProcessStep2Servlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ProcessStep2Servlet</servlet-name>
<url-pattern>/processStep2Servlet</url-pattern>
</servlet-mapping>
</web-app>
7.Customer封装类:
package com.lanqiao.javatest; public class Customer {
private String name;
private String address;
private String phone;
private String cardType;
private String card; public Customer() {
super();
} public Customer(String name, String address, String phone, String cardType, String card) {
super();
this.name = name;
this.address = address;
this.phone = phone;
this.cardType = cardType;
this.card = card;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getAddress() {
return address;
} public void setAddress(String address) {
this.address = address;
} public String getPhone() {
return phone;
} public void setPhone(String phone) {
this.phone = phone;
} public String getCardType() {
return cardType;
} public void setCardType(String cardType) {
this.cardType = cardType;
} public String getCard() {
return card;
} public void setCard(String card) {
this.card = card;
} @Override
public String toString() {
return "Customer [name=" + name + ", address=" + address + ", phone=" + phone + ", cardType=" + cardType
+ ", card=" + card + "]";
} }
Session案例:简易的购物车的更多相关文章
- 使用jQuery制作一个简易的购物车结算流程
因为今天下午时候在网上买了东西,在结算界面的时候突发奇想的也想自己动手做一个结算界面,当然了,只是一个最简易的结算界面,有商品数量的加减,有单价和小计,单个多个删除,全选和区县全选等等一些小功能,我在 ...
- js中的经典案例--简易万年历
js中的经典案例--简易万年历 html代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8& ...
- 【Tomcat】JSP使用Session、Cookie实现购物车
购物界面shop.jsp 初始页面 添加商品后,在session中设置属性,重定向回到shop.jsp,然后根据session的内容显示结果 Cookie设置setMaxAge可以延长session的 ...
- 零基础学习java------29---------网络日志数据session案例,runtime(导出jar程序)
一. 网络日志数据session案例 部分数据 数据中的字段分别为: 访客ip地址,访客访问时间,访客请求的url及协议,网站响应码,网站返回数据量,访客的referral url,访客的客户端操作系 ...
- [原创]java WEB学习笔记33:Session 案例 之 购物车
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- 基于session的简易购物车引发的问题
一.功能描述: 页面如下所示: 运行报错: java.io.FileNotFoundException: E:\apache-tomcat-8.0.37\work\Catalina\localhos ...
- express+session实现简易身份认证
本文摘录自<Nodejs学习笔记>,更多章节及更新,请访问 github主页地址.欢迎加群交流,群号 197339705. 文章概览 本文基于express.express-session ...
- Session案例
用户登入案例: 按一般的网站登入实例,用户在页面登入页输入账号.密码,验证通过后,在首页显示其"欢迎回来,xxx". 首先完成登入页login.html <!DOCTYPE ...
- Nodejs进阶:express+session实现简易身份认证
本文摘录自<Nodejs学习笔记>,更多章节及更新,请访问 github主页地址.欢迎加群交流,群号 197339705. 文档概览 本文基于express.express-session ...
随机推荐
- PAT 解题报告 1004. Counting Leaves (30)
1004. Counting Leaves (30) A family hierarchy is usually presented by a pedigree tree. Your job is t ...
- java collections读书笔记(8)collection框架总览(1)
- python自动化运维之路~DAY1
python自动化运维之路~DAY1 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.文件大小单位单位换算 我们一起看一下下面的图: 没错,都是数字,而且这些数字都是二进制的数字 ...
- codeforces.com/problemset/problem/213/C
虽然一开始就觉得从右下角左上角直接dp2次是不行的,后面还是这么写了WA了 两次最大的并不一定是最大的,这个虽然一眼就能看出,第一次可能会影响第二次让第二次太小. 这是原因. 5 4 32 1 18 ...
- Codeforce Round #221 Div2
每次的CF都是一把辛酸泪! 什么时候能打破这局面,昨天做着睡着了! 有时候有的题目也就差一线! 哎,! A:杠杆原理! B:算最后负的和! B:没弄出来当时就脑短路... C:事后写了个n*log(n ...
- Codeforces Round #284 (Div. 1)
A. Crazy Town 这一题只需要考虑是否经过所给的线,如果起点和终点都在其中一条线的一侧,那么很明显从起点走点终点是不需要穿过这条线的,否则则一定要经过这条线,并且步数+1.用叉积判断即可. ...
- 【py网页】sitecopy代码
001 #coding:utf-8 002 import re,os,shutil,sys 003 import urllib2,socket,cookielib 004 from threading ...
- 【python】标准库的大致认识
正如那句 Python 社区中很有名的话所说的:“battery included”,Python 的一大好处在于它有一套很有用的标准库(standard library).标准库是随着 Python ...
- 在ASP.NET非MVC环境中(WebForm中)构造MVC的URL参数
目前项目中有个需求,需要在WebForm中去构造MVC的URL信息,这里写了一个帮助类可以在ASP.NET非MVC环境中(WebForm中)构造MVC的URL信息,主要就是借助当前Http上下文去构造 ...
- React+Node.js+Express+mongoskin+MongoDB
首发:个人博客,更新&纠错&回复 采用React + Node.js + Express + mongoskin + MongoDB技术开发的一个示例,演示地址在这里,项目源码在这里. ...