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 揭秘与实战(二) 数据缓存 ...
随机推荐
- Spring-Boot ☞ ShapeFile文件读写工具类+接口调用
一.项目目录结构树 二.项目启动 三.往指定的shp文件里写内容 (1) json数据[Post] { "name":"test", "path&qu ...
- python正则表达式+正则大量实例
正则表达式 正则表达式内部函数详解http://www.runoob.com/python/python-reg-expressions.html 正则表达式是一个特殊的字符序列,它能帮助你方便的检查 ...
- python第一个程序-->hello world
最近在网上看到一个小笑话,一个程序员的自我嘲讽:“我精通所以计算机语言的hello world!” 好了,废话不多说了,开始撸代码: 我本人用的是python3.6版本,各位可以通过官网下载自己喜欢的 ...
- Spark 实践
1.1 避免使用 GroupByKey 让我们看一下使用两种不同的方式去计算单词的个数,第一种方式使用 reduceByKey, 另外一种方式使用 groupByKey: val words = ...
- springmvc springboot 跨域问题(CORS)
官方文档:http://docs.spring.io/spring/docs/current/spring-framework-reference/html/cors.html springmvc s ...
- 1754-I Hate It 线段树(单点替换,区间最值)
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- 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 ...
- react children技巧总结
在使用该技巧时,建议先看一下相关的知识,点我查看 假如使用该属性时,想把父组件的所有属性及部分方法传递给子组件,该怎么办呢?看代码 const Child = ({ doSomething, valu ...
- Yarn 命令详解
常用命令 创建项目:yarn init 安装依赖包:yarn == yarn install 添加依赖包:yarn add 配置淘宝镜像:yarn config set registry " ...
- python基础训练营01
一.基础讲解: 1.1 文件末尾的.py后缀,指出这个文件,是一个python文件,因此,系统将使用python解释器来运行该文件,确定文件中每一个单词的含义. 1.2 python编辑/运行方法: ...