登录页面核心代码

<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. Spring-Boot ☞ ShapeFile文件读写工具类+接口调用

    一.项目目录结构树 二.项目启动 三.往指定的shp文件里写内容 (1) json数据[Post] { "name":"test", "path&qu ...

  2. python正则表达式+正则大量实例

    正则表达式 正则表达式内部函数详解http://www.runoob.com/python/python-reg-expressions.html 正则表达式是一个特殊的字符序列,它能帮助你方便的检查 ...

  3. python第一个程序-->hello world

    最近在网上看到一个小笑话,一个程序员的自我嘲讽:“我精通所以计算机语言的hello world!” 好了,废话不多说了,开始撸代码: 我本人用的是python3.6版本,各位可以通过官网下载自己喜欢的 ...

  4. Spark 实践

    1.1 避免使用 GroupByKey   让我们看一下使用两种不同的方式去计算单词的个数,第一种方式使用 reduceByKey, 另外一种方式使用 groupByKey: val words = ...

  5. springmvc springboot 跨域问题(CORS)

    官方文档:http://docs.spring.io/spring/docs/current/spring-framework-reference/html/cors.html springmvc s ...

  6. 1754-I Hate It 线段树(单点替换,区间最值)

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  7. What to do when Enterprise Manager is not able to connect to the database instance (ORA-28001)

    摘自:http://dbtricks.com/?p=34 If you are trying to connect to the Oracle enterprise Manger and you ge ...

  8. react children技巧总结

    在使用该技巧时,建议先看一下相关的知识,点我查看 假如使用该属性时,想把父组件的所有属性及部分方法传递给子组件,该怎么办呢?看代码 const Child = ({ doSomething, valu ...

  9. Yarn 命令详解

    常用命令 创建项目:yarn init 安装依赖包:yarn == yarn install 添加依赖包:yarn add 配置淘宝镜像:yarn config set registry " ...

  10. python基础训练营01

    一.基础讲解: 1.1 文件末尾的.py后缀,指出这个文件,是一个python文件,因此,系统将使用python解释器来运行该文件,确定文件中每一个单词的含义. 1.2 python编辑/运行方法: ...