登录页面核心代码

<div id="login">
		<h2>用户登陆</h2>
		<form method="post" action="LoginServlet" onsubmit="return check()">
			<dl>
				<dt>用户名:</dt>
				<dd><input class="input-text" type="text" id="username" name="username" onblur="isUsernameNull()"/><span id="usernull"></span></dd>
				<dt>密 码:</dt>
				<dd><input class="input-text" type="password" id="password" name="password" onblur="isPasswordNull()"/><span  id="pwdnull"></span></dd>
				<dt> </dt>
				<dd class="button"><input class="input-btn" type="submit" name="submit" value="" />
				<input class="input-reg" type="button" name="register"
				value="" onclick="window.location='register.jsp';" /></dd>
			</dl>
		</form>
	</div>

LoginServlet的参考代码:

public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		String username = request.getParameter("username");
		String password = request.getParameter("password");

		UserinfoDao ud = new UserinfoDaoImpl();

		Userinfo userinfo = ud.findByNameAndPwd(username, password);
		//如果登陆成功,则去bookListServlet
		if(userinfo!=null){
			request.getSession().setAttribute("userinfo", userinfo);
			response.sendRedirect("BooklistServlet");
		}
		else{
			response.sendRedirect("login.jsp");
		}

	}

BooklistServlet的参考代码:

protected void doPost(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		String page = req.getParameter("page");
		if(page==null){
			page="1";//第一次传过来就是默认首页
		}
		int pageindex = Integer.parseInt(page);//否则,可能是第2页等
		BookDao bd = new BookDaoImpl();
		List<Book> books = bd.findBookByPage(pageindex, 3);//3:每页多少数据
		int count = bd.count();
		PageControler pc = new PageControler();
		int total = pc.getTotalPages(count, 3);//总页数
		//通过request设置属性,+forward转向;

		req.setAttribute("pageindex", pageindex);
//		HttpSession session=req.getSession();
//		session.setAttribute("books",books); 也可以,可以直接跳转;
		req.setAttribute("books",books);
		req.setAttribute("total",total);

		req.getRequestDispatcher("index.jsp").forward(req,resp);
	}

购物车页面显示代码段参考:

<div id="content" class="wrap">
	<div class="list bookList">
		<form method="post" name="shoping" action="CartServlet" onsubmit="return checkCart();">
			<table>
				<tr>
					<th class="checker">@</th>
					<th>书名</th>
					<th class="info">简介</th>
					<th class="price">价格</th>
					<th class="store">库存</th>
					<th class="view">图片预览</th>
				</tr>
					<c:forEach items="${books}" var="book"><!--book.id的值可以存放value -->
					<tr>
						<td><input type="checkbox" name="bookId" value="${book.id}" /></td>
						<td class="title">${book.bookname}</td>
						<td class="info">${book.info}</td>
						<td>¥${book.price}</td>
						<td>${book.stock}</td>
						<td class="thumb"><img src="images/book/${book.image}" /></td>
					</tr>
					</c:forEach>

			</table>

			<div class="page-spliter">
				<a href="BooklistServlet?page=1">首页</a>

				<c:if test="${pageindex>1}">
					<a href="BooklistServlet?page=${pageindex-1}">上一页</a>
				</c:if>

				<c:if test="${pageindex<total}">
					<a href="BooklistServlet?page=${pageindex+1}">下一页</a>
				</c:if>

				<a href="BooklistServlet?page=${total}">尾页</a>
			</div>

			<div class="button">
			<input class="input-btn" type="submit"
			 name="submit" value="" /></div>
		</form>
	</div>
</div>

jsp电子商务 购物车实现之二 登录和分页篇的更多相关文章

  1. jsp电子商务购物车之四 数据库存储篇

    为了方便用户下次登录,仍然可以看到自己的购物车内容,所以,需要在数据库存储相应的购物车项目,本处增加购物车项表;uid和bid是复合主键. package com.cart.entity; //购物车 ...

  2. jsp电子商务购物车之五 数据库存储篇2

    业务逻辑图,简单版要写各个Servlet //ChangeCartCountServlet 使用ajax实现数量,增加或减少; package com.cart.web; import java.io ...

  3. jsp电子商务 购物车实现之三 购物车

    CartServlet参考代码 : public void doPost(HttpServletRequest req, HttpServletResponse resp) throws Servle ...

  4. jsp电子商务 购物车实现之一 设计篇

    购物车的功能实现. 查询的资料,找到三种方法: 1.用cookie实现购物车: 2.用session实现购物车: 3.用cookie和数据库(购物车信息持久化)实现购物车: ============= ...

  5. 学习jsp篇:jsp简单实例之二登录

    编程环境:IDEA,Tomcat,JavaEE 一.实例二登录 1.在自己建的工程下的web目录下建一个文件夹为login,在login中编写登录代码(其实就是和实例一同一个项目) 2.先建登录页面j ...

  6. Java正则速成秘籍(二)之心法篇

    导读 正则表达式是什么?有什么用? 正则表达式(Regular Expression)是一种文本规则,可以用来校验.查找.替换与规则匹配的文本. 又爱又恨的正则 正则表达式是一个强大的文本匹配工具,但 ...

  7. 【three.js详解之二】渲染器篇

    [three.js详解之二]渲染器篇   本篇文章将详细讲解three.js中渲染器(renderer)的设置方法. three.js文档中渲染器的分支如下: Renderers CanvasRend ...

  8. 界面编程模仿篇(QQ登录界面逼真篇)

    写了好多天的爬虫,偷空前前后后用了两天的时间(排除吃饭睡觉)写完了这个QQ登录界面,看起来还凑和着吧,如果是的大神的,莫见笑,纯属业余作品,废话先不多说,截图如下,其中第二幅图片中的红色方框部份有待完 ...

  9. Spring Boot 揭秘与实战(二) 数据缓存篇 - Redis Cache

    文章目录 1. Redis Cache 集成 2. 源代码 本文,讲解 Spring Boot 如何集成 Redis Cache,实现缓存. 在阅读「Spring Boot 揭秘与实战(二) 数据缓存 ...

随机推荐

  1. 吐血分享:QQ群霸屏技术教程2017(活跃篇)

    热门词的群排名,在前期优化准备充分的情况下,活跃度不失为必杀技. 在<吐血分享:QQ群霸屏技术(初级篇)>中,我们提及到热门词的群排名,有了前面的基础,我们就可以进入深度优化,实现绝对的霸 ...

  2. vi-vim常用命令

    vi-vim常用命令 1 简介 在UNIX系统中,创建和修改配置文件.shell脚本.初始化文件.编写程序都离不开VI. 1      vi[1]属于两个主要的UNIX规范:POSIX和单一UNIX规 ...

  3. Python函数中的参数

    形参:形式参数 实参:实际参数 1.普通参数:严格按照顺序将实参赋值给形参. 2.默认参数:必须放置在参数列表的最后. 3.指定参数:将实参赋值给制定参数. 4.动态参数: *:默认将传入的参数,全部 ...

  4. python 装饰器 (多个装饰器装饰一个函数---装饰器前套一个函数)

    #带参数的装饰器 #500个函数 # import time # FLAGE = False # def timmer_out(flag): # def timmer(func): # def inn ...

  5. rails小技巧之分组查询统计并去重

    分组查询并统计 SpecialGroup.group(:special_type).count select special_type,count(*) from special_groups gro ...

  6. CUBLAS基础实验

    一.概述 最近在试图进行cuda并行编程,目标是编写一段矩阵计算代码,将计算结果存储进入GPU的缓冲区当中,并在达到某些要求后强制刷新缓冲区,取得计算结果. 但是考虑时间紧任务重的状况和实际的性能要求 ...

  7. PHP.39-扩展-锁机制解决并发-MySQL锁、PHP文件锁

    锁机制适用于高并发场景:高并发订单.秒杀…… apache压力测试 Mysql锁详解 语法 加锁:LOCK TABLE 表名1 READ|WRITE, 表名2 READ|WRITE ......... ...

  8. WPF 构建无外观(Lookless)控件

    原文:WPF 构建无外观(Lookless)控件 构建一个用户可以使用Template属性设置外观的WPF控件需要以下几步 1.继承自System.Windows.Controls.Control 2 ...

  9. Tapestry 权威讲解-备份

    http://blog.csdn.net/mindhawk/article/details/5021371#introduction

  10. linux shell中读写操作mysql数据库

    本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...