博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jsp写的简单购书网站
阅读量:6511 次
发布时间:2019-06-24

本文共 9254 字,大约阅读时间需要 30 分钟。

hot3.png

监听器:

package com.cjq.servlet;import javax.servlet.http.HttpSessionEvent;import javax.servlet.http.HttpSessionListener;/** * Application Lifecycle Listener implementation class SessionListener * */public class SessionListener implements HttpSessionListener {		protected static int count = 0;		/**     * @see HttpSessionListener#sessionCreated(HttpSessionEvent)     */    public void sessionCreated(HttpSessionEvent arg0) {    	System.out.println(count);    	count++;    }	/**     * @see HttpSessionListener#sessionDestroyed(HttpSessionEvent)     */    public void sessionDestroyed(HttpSessionEvent arg0) {    	System.out.println(count);    	if(count>0) count--;    }        public static int getCount(){    	return count;    }	}
 
web.xml配置如下:
 
NetWorDemo
UI/login.html
com.cjq.servlet.SessionListener

 
Book.java:
 
package com.cjq.book;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import sun.jdbc.odbc.JdbcOdbcDriver;public class Book {	String sDBDriver = "sun.jdbc.odbc.JdbcOdbcDriver";	String sConnStr = "jdbc:odbc:book";	Connection conn = null;	ResultSet rs = null;	public Book(){		try{			Class.forName(sDBDriver);		}catch(ClassNotFoundException e){			e.printStackTrace();		}	}		public ResultSet executeQuery(String sql){		rs = null;		try{			conn = DriverManager.getConnection(sConnStr);			Statement stmt = conn.createStatement();			stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);			rs = stmt.executeQuery(sql);		}catch(SQLException ex){			ex.printStackTrace();		}		return rs;	}}
 
login.html:
 
Insert title here
登录名:
密码:
 
login_confirm.jsp:
 
<%@page import="java.sql.ResultSet"%><%@ page language="java" contentType="text/html; charset=GBK"    pageEncoding="GBK"%>
Insert title here
<% String name = request.getParameter("login"); name = new String(name.getBytes("UTF-8")); String pwd = request.getParameter("password"); pwd = new String(pwd.getBytes("UTF-8")); String sql = "select * from customer where logname='"+name+"' and password='"+pwd+"'"; ResultSet rs = users.executeQuery(sql); if(rs.next()){ rs.close(); session.putValue("username", name); %>
<% }else{ rs.close(); %>
<% }%>
 
browse.jsp:
 
<%@page import="com.cjq.servlet.SessionListener"%><%@page import="java.sql.ResultSet"%><%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><%	if(session.getAttribute("username")==null){		response.sendRedirect("login.html");	}	%>	
<% int pageSize = 8; int showPage = 1; int rowCount = 0; int pageCount = 0; ResultSet rs = mybook.executeQuery("select * from book"); rs.last(); rowCount = rs.getRow(); rs.beforeFirst(); pageCount = ((rowCount%pageSize)==0?(rowCount/pageSize):(rowCount/pageSize)+1); %>
Insert title here

在线人数:<%= SessionListener.getCount() %>


<% String toPage = request.getParameter("toPage"); if(toPage!=null){ showPage = Integer.parseInt(toPage); if(showPage>pageCount){ showPage=pageCount; }else if(showPage<=0){ showPage=1; } } rs.absolute((showPage-1)*pageSize+1);%>

当前在第<%= showPage %>页,共<%= pageCount %>

<% for(int i=(showPage-1)*pageSize+1;i<=rowCount;i++){ %>
<% rs.next(); if(i==pageSize){ break; } } rs.close(); %>
书名 作者 价格(元) 购书
<%=rs.getString("name") %> <%=rs.getString("author") %> <%=rs.getString("price") %> ">选购此书
<% if(showPage!=1){ %>
<% } if(showPage!=pageCount){ %>
<% } %>
到第一页 到上一页 到下一页 到最后一页
 
cart.jsp:
 
<%@page import="java.sql.ResultSet"%><%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><%	if(session.getAttribute("username")==null){		response.sendRedirect("login.html");	}%>
<% String book_id=request.getParameter("book_id"); String sql = "select id from orders where book_id="+book_id+" and user_name='"+session.getAttribute("username")+"'"; ResultSet rs = cart.executeQuery(sql); int rowscount=0; try{ while(rs.next()){ rowscount++; } }catch(Exception e){ out.println(e.getMessage()); } if(rowscount==0){ String sqlBook1 = "select * from book where id="+book_id; ResultSet rsBook1 = cart.executeQuery(sqlBook1); while(rsBook1.next()){ String sqlCart="insert into orders (user_name,book_id,book_number,goods_price)"+ "values('"+session.getAttribute("username")+"','"+book_id+"','1',"+rsBook1.getDouble("price")+")"; cart.executeQuery(sqlCart); } }else{ String sqlBook2="select * from book where id="+book_id; ResultSet rsBook2=cart.executeQuery(sqlBook2); while(rsBook2.next()){ String sqlAdd="update orders set book_number=book_number+1,goods_price="+rsBook2.getDouble("price")+" where book_id="+book_id+" and user_name='"+session.getAttribute("username")+"'"; cart.executeQuery(sqlAdd); } } response.sendRedirect("shopcart.jsp");%>
 

shopcart.jsp:

<%@page import="java.sql.ResultSet"%><%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%>
<% if(session.getAttribute("username")==null){ response.sendRedirect("login.html"); }%>
Insert title here
购书清单

您已选购以下书籍:

<% double g_price,total_price; g_price=0; total_price=0; String sqlList="select * from orders where user_name='"+session.getAttribute("username")+"'"; ResultSet rsList = workM.executeQuery(sqlList); rsList.beforeFirst(); try{ while(rsList.next()){ int b_num = rsList.getInt("book_number"); %>
<% String sqlBook="select * from book where id="+rsList.getInt("book_id"); ResultSet rsBook = workM.executeQuery(sqlBook); while(rsBook.next()){ %>
<% g_price=g_price+(double)price*b_num; } %>
<% } }catch(Exception e){ out.println(e); } %>
购买数量
书名
单价(元)
总价格(元)
<%=b_num %>
<%=rsBook.getString("name") %>
<% double price = rsBook.getDouble("price"); %>
¥<%=price %>
¥<%=(float)price*b_num %>
货物价格
¥<%=(float)g_price %>
运输费用
¥5.00
总费用
¥<%=(float)g_price+5 %>
继续购书

 

submit_order.jsp:

<%@page import="java.sql.ResultSet"%><%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%>
<% if(session.getAttribute("username")==null){ response.sendRedirect("login.html"); }%><% String tel = request.getParameter("address"); tel = new String(tel.getBytes("UTF-8")); String address = request.getParameter("tel"); address = new String(address.getBytes("UTF-8")); String sqlinsert = "update order set user__address='"+address+"',user_tel='"+tel+"' where user_name='"+session.getAttribute("username")+"'"; workM.executeQuery(sqlinsert);%>
Insert title here
订单确认
订单信息
姓名: <%=session.getAttribute("username") %>
住址: <%=address %>
电话: <%=tel %>

您选购了以下书籍:

<% double g_price=0,total_price=0; String sqlList = "select * from orders where user_name='"+session.getAttribute("username")+"'"; ResultSet rsList = workM.executeQuery(sqlList); try{ while(rsList.next()){ int b_num = rsList.getInt("book_number"); %>
<% String sqlBook="select * from book where id="+rsList.getInt("book_id"); ResultSet rsBook=workM.executeQuery(sqlBook); while(rsBook.next()){ %>
<% g_price=price+(double)price*b_num; } %>
<% } }catch(Exception e){ } %>
购买数量
书名
单价(元)
总价格(元)
<%=b_num %>
<%=rsBook.getString("name") %>
<% double price = rsBook.getDouble("price"); %>
¥<%=price %>
¥<%=(double)price*b_num %>
货物价格
¥<%=(float)g_price %>
运输费用
¥5.00
总费用
¥<%=(float)g_price+5 %>

转载于:https://my.oschina.net/u/2552902/blog/543930

你可能感兴趣的文章
最短路-Bellman-Ford算法
查看>>
Object 类有哪些方法
查看>>
oracle 将一个表复制到另外一个表里 .
查看>>
libcurl以get方式请求服务器端文件
查看>>
OpenJudge 2786 Pell数列
查看>>
mysql 游标循环,嵌套游标循环
查看>>
swoft| 源码解读系列一: 好难! swoft demo 都跑不起来怎么破? docker 了解一下呗~
查看>>
win7 蛋疼的时间格式转化
查看>>
C++中二维数组的动态创建与处理
查看>>
SPOJ 10628 COT - Count on a tree(在树上建立主席树)(LCA)
查看>>
SpringInAction--Bean参数的自动注入
查看>>
素数筛
查看>>
centos /linux 修改目录或文件权限
查看>>
leetcode--
查看>>
访问者模式
查看>>
异步函数
查看>>
Openstack的vnc界面定制
查看>>
软考 2018年下半年卷 错题知识点记录
查看>>
仿网易邮箱5.0版UI
查看>>
winsow xp不能安装软件, 提示"中断" 是因为设置了 软件限制策略
查看>>