jsp电子商务 购物车实现之二 登录和分页篇
登录页面核心代码
<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电子商务 购物车实现之二 登录和分页篇的更多相关文章
- jsp电子商务购物车之四 数据库存储篇
为了方便用户下次登录,仍然可以看到自己的购物车内容,所以,需要在数据库存储相应的购物车项目,本处增加购物车项表;uid和bid是复合主键. package com.cart.entity; //购物车 ...
- jsp电子商务购物车之五 数据库存储篇2
业务逻辑图,简单版要写各个Servlet //ChangeCartCountServlet 使用ajax实现数量,增加或减少; package com.cart.web; import java.io ...
- jsp电子商务 购物车实现之三 购物车
CartServlet参考代码 : public void doPost(HttpServletRequest req, HttpServletResponse resp) throws Servle ...
- jsp电子商务 购物车实现之一 设计篇
购物车的功能实现. 查询的资料,找到三种方法: 1.用cookie实现购物车: 2.用session实现购物车: 3.用cookie和数据库(购物车信息持久化)实现购物车: ============= ...
- 学习jsp篇:jsp简单实例之二登录
编程环境:IDEA,Tomcat,JavaEE 一.实例二登录 1.在自己建的工程下的web目录下建一个文件夹为login,在login中编写登录代码(其实就是和实例一同一个项目) 2.先建登录页面j ...
- Java正则速成秘籍(二)之心法篇
导读 正则表达式是什么?有什么用? 正则表达式(Regular Expression)是一种文本规则,可以用来校验.查找.替换与规则匹配的文本. 又爱又恨的正则 正则表达式是一个强大的文本匹配工具,但 ...
- 【three.js详解之二】渲染器篇
[three.js详解之二]渲染器篇 本篇文章将详细讲解three.js中渲染器(renderer)的设置方法. three.js文档中渲染器的分支如下: Renderers CanvasRend ...
- 界面编程模仿篇(QQ登录界面逼真篇)
写了好多天的爬虫,偷空前前后后用了两天的时间(排除吃饭睡觉)写完了这个QQ登录界面,看起来还凑和着吧,如果是的大神的,莫见笑,纯属业余作品,废话先不多说,截图如下,其中第二幅图片中的红色方框部份有待完 ...
- Spring Boot 揭秘与实战(二) 数据缓存篇 - Redis Cache
文章目录 1. Redis Cache 集成 2. 源代码 本文,讲解 Spring Boot 如何集成 Redis Cache,实现缓存. 在阅读「Spring Boot 揭秘与实战(二) 数据缓存 ...
随机推荐
- 吐血分享:QQ群霸屏技术教程2017(活跃篇)
热门词的群排名,在前期优化准备充分的情况下,活跃度不失为必杀技. 在<吐血分享:QQ群霸屏技术(初级篇)>中,我们提及到热门词的群排名,有了前面的基础,我们就可以进入深度优化,实现绝对的霸 ...
- vi-vim常用命令
vi-vim常用命令 1 简介 在UNIX系统中,创建和修改配置文件.shell脚本.初始化文件.编写程序都离不开VI. 1 vi[1]属于两个主要的UNIX规范:POSIX和单一UNIX规 ...
- Python函数中的参数
形参:形式参数 实参:实际参数 1.普通参数:严格按照顺序将实参赋值给形参. 2.默认参数:必须放置在参数列表的最后. 3.指定参数:将实参赋值给制定参数. 4.动态参数: *:默认将传入的参数,全部 ...
- python 装饰器 (多个装饰器装饰一个函数---装饰器前套一个函数)
#带参数的装饰器 #500个函数 # import time # FLAGE = False # def timmer_out(flag): # def timmer(func): # def inn ...
- rails小技巧之分组查询统计并去重
分组查询并统计 SpecialGroup.group(:special_type).count select special_type,count(*) from special_groups gro ...
- CUBLAS基础实验
一.概述 最近在试图进行cuda并行编程,目标是编写一段矩阵计算代码,将计算结果存储进入GPU的缓冲区当中,并在达到某些要求后强制刷新缓冲区,取得计算结果. 但是考虑时间紧任务重的状况和实际的性能要求 ...
- PHP.39-扩展-锁机制解决并发-MySQL锁、PHP文件锁
锁机制适用于高并发场景:高并发订单.秒杀…… apache压力测试 Mysql锁详解 语法 加锁:LOCK TABLE 表名1 READ|WRITE, 表名2 READ|WRITE ......... ...
- WPF 构建无外观(Lookless)控件
原文:WPF 构建无外观(Lookless)控件 构建一个用户可以使用Template属性设置外观的WPF控件需要以下几步 1.继承自System.Windows.Controls.Control 2 ...
- Tapestry 权威讲解-备份
http://blog.csdn.net/mindhawk/article/details/5021371#introduction
- linux shell中读写操作mysql数据库
本文介绍了如何在shell中读写mysql数据库.主要介绍了如何在shell 中连接mysql数据库,如何在shell中创建数据库,创建表,插入csv文件,读取mysql数据库,导出mysql数据库为 ...