易买网项目完工,把一些新知识记录下来,以便以后查阅,也方便他人借阅。介绍使用cookies查询商品详情。

第一步:建立商品实体类。

第二步:连接Oracle数据库。

第三步:使用三层架构。

效果图如下:

当我看中新疆牛肉干,商品点击时,进入查看商品详情页。

商品详情页:

核心代码如下:

 <%
//创建商品业务逻辑对象
productBiz prodctbiz = new productBizImpl(); List<easybuy_product> productlist = prodctbiz.findproductList();
request.setAttribute("productlist",product);
%>
//EL表达式
核心架包
<%@taglib uri="http://java.sun.com/jsp/jstl/core"  prefix="c"%>
//EL表达式:
<c:forEach var="news" items="${requestScope.productlist}" > <li class="ck">
<dl>
<dt><a href="addcookie?id=${news.ep_id}"><img src="${news.ep_file_name}" /></a></dt>
<dd class="title"><a href="addcookie?id=${news.ep_id}">${news.ep_name}</a></dd>
<dd class="price">¥${news.ep_price}.00</dd>
</dl> </li> </c:forEach>

第二步:在Servlet创建addcookie.java页面,获取商品id:(注意:必须在web.xml写入)

        <!--商品id存在cookies-->
<servlet>
<servlet-name>addcookie</servlet-name>
<servlet-class>Servlet.addcookie</servlet-class>
</servlet> <!-- 映射servlet -->
<servlet-mapping>
<servlet-name>addcookie</servlet-name>
<url-pattern>/addcookie</url-pattern>
</servlet-mapping>
package Servlet;

import java.io.IOException;
import java.io.PrintWriter; import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class addcookie extends HttpServlet { /**
* Constructor of the object.
*/
public addcookie() {
super();
} /**
* Destruction of the servlet. <br>
*/
public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
} public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
request.setCharacterEncoding("utf-8");
//获取商品id
String id = request.getParameter("id");
//转发的页面
response.setHeader("refresh", "0;url=/yimaiWang/product-view.jsp?id="+id); Cookie[] cookies = request.getCookies(); String visitlist = null;
if (cookies != null) {
for (Cookie cookie : cookies) {
if (cookie.getName().equals("visitlist")) {
visitlist = cookie.getValue();
break;
}
}
if (visitlist == null) { Cookie cookie = new Cookie("visitlist", id);
cookie.setMaxAge(180);
response.addCookie(cookie); } else { String[] existIds = visitlist.split(",");
for (String exsitId : existIds) {
if (exsitId.equals(id)) { return;
}
} Cookie cookie = new Cookie("visitlist", visitlist + "," + id);
cookie.setMaxAge(180);
response.addCookie(cookie); }
} else { Cookie cookie = new Cookie("visitlist", id);
cookie.setMaxAge(180);
response.addCookie(cookie); }
} }

第三步:跳转商品详情页product-view.jsp(这俩个查询语句不同,一个是查询商品id,一个是商品List集合)

public easybuy_product findProductForid(int id) {
con=this.getConnection();
int i =id;
String sql = "select * from easybuy_product where ep_id =?"; easybuy_product pd = new easybuy_product(); try
{
st=con.prepareStatement(sql);
st.setInt(1,id);
rs=st.executeQuery(); while(rs.next())
{ pd.setEp_id(rs.getInt(1));
pd.setEp_name(rs.getString(2));
pd.setEp_description(rs.getString(3));
pd.setEp_price(rs.getInt(4));
pd.setEp_stock(rs.getInt(5));
pd.setEpc_id(rs.getInt(6));
pd.setEpc_child_id(rs.getInt(7));
pd.setEp_file_name(rs.getString(8));
}
} catch (SQLException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}finally{
this.ShiFang(rs, st, con); } return pd;
}
}
public List<easybuy_product> product(String id) {
List<easybuy_product> listproduct=new ArrayList<easybuy_product>();
// TODO Auto-generated method stub con = this.getConnection(); String sql="select * from easybuy_product where ep_id=?";
try {
st=con.prepareStatement(sql);
st.setString(1,id);
rs=st.executeQuery();
while(rs.next()){
easybuy_product product = new easybuy_product();
product.setEp_id(rs.getInt(1));
product.setEp_name(rs.getString(2));
product.setEp_description(rs.getString(3));
product.setEp_price(rs.getInt(4));
product.setEp_stock(rs.getInt(5));
product.setEpc_id(rs.getInt(6));
product.setEpc_child_id(rs.getInt(7));
product.setEp_file_name(rs.getString(8)); listproduct.add(product);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace(); this.ShiFang(rs, st, con);
} return listproduct;
}

<%
//获取商品id
int id = Integer.parseInt(request.getParameter("id"));
productBiz bizvoid = new productBizImpl();
easybuy_product shop = bizvoid.findProductForid(id);
request.setAttribute("shop",shop);
%>

<%
//获取商品id
request.setCharacterEncoding("utf-8");
String a = request.getParameter("id");
%>
<% //创建商品信息业务逻辑对象
productBiz productbiz = new productBizImpl(); List<easybuy_product> list =productbiz.product(a);
request.setAttribute("list",list); %>
<div id="product" class="main">
<c:forEach var="product" items="${requestScope.list}" >
<h1><%=shop.getEp_name() %></h1>
</c:forEach>
<div class="infos">
<c:forEach var="product" items="${requestScope.list}" >
<div class="thumb"><img src="${product.ep_file_name}" width="300px" /></div>
<div class="buy">
<p>商品描述:<span class="price">${product.ep_description}</span></p>
<p>商城价:<span class="price">¥${product.ep_price}.00</span></p>
<c:if test="${product.ep_stock==null}">
<p class="w1 c">缺货</p>
</c:if>
<c:if test="${product.ep_stock!=null}">
<p class="w1 c">有货</p>
</c:if>
<c:if test="${name==null}">
<script type="text/javascript">
function ck(){
alert("你未登入,请去登入吧!");
return false;
}
</script> </c:if>

使用cookies查询商品详情的更多相关文章

  1. 使用cookies查询商品浏览记录

    经历了俩个星期,易买网项目如期完工,现在总结一下如何使用cookies实现浏览商品的历史记录. 第一步:创建商品实体类. 第二步:连接oracle数据库. 第三步:创建商品三层架构. 效果图: 在要显 ...

  2. Vue框架H5商城类项目商品详情点击返回弹出推荐商品弹窗的实现方案

    需求场景: 非推荐商品详情页返回的时候弹出弹窗推荐商品,点击弹窗按钮可以直接访问推荐商品: 只有直接进入商品详情页返回才会弹出推荐商品弹窗: 每个用户访问只能弹一次(除非清除缓存). 需求分析: 1. ...

  3. 第04项目:淘淘商城(SpringMVC+Spring+Mybatis)【第九天】(商品详情页面实现)

    https://pan.baidu.com/s/1bptYGAb#list/path=%2F&parentPath=%2Fsharelink389619878-229862621083040 ...

  4. SSH网上商城---商品详情页的制作

    在前面的博文中,小编分别简单的介绍了邮件的发送以及邮件的激活,逛淘宝的小伙伴都有这样的体会,比如在搜索框中输入连衣裙这个商品的时候,会出现多种多样各种款式的连衣裙,连衣裙的信息包括价格,多少人购买,商 ...

  5. 如何用Baas快速在腾讯云上开发小程序-系列4:实现客户侧商品列表、商品详情页程序

    版权声明:本文由贺嘉 原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/431172001487671163 来源:腾云阁 h ...

  6. JAVAEE——宜立方商城09:Activemq整合spring的应用场景、添加商品同步索引库、商品详情页面动态展示与使用缓存

    1. 学习计划 1.Activemq整合spring的应用场景 2.添加商品同步索引库 3.商品详情页面动态展示 4.展示详情页面使用缓存 2. Activemq整合spring 2.1. 使用方法 ...

  7. [springboot 开发单体web shop] 8. 商品详情&评价展示

    上文回顾 上节 我们实现了根据搜索关键词查询商品列表和根据商品分类查询,并且使用到了mybatis-pagehelper插件,讲解了如何使用插件来帮助我们快速实现分页数据查询.本文我们将继续开发商品详 ...

  8. Day13_商品详情及静态化

    学于黑马和传智播客联合做的教学项目 感谢 黑马官网 传智播客官网 微信搜索"艺术行者",关注并回复关键词"乐优商城"获取视频和教程资料! b站在线视频 0.学习 ...

  9. Android开发案例 - 淘宝商品详情

    所有电商APP的商品详情页面几乎都是和淘宝的一模一样(见下图): 采用上下分页的模式 商品基本参数 & 选购参数在上页展示 商品图文详情等其他信息放在下页展示 知识要点 垂直方向的ViewPa ...

随机推荐

  1. Python基础-奇偶判断调用函数

    编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数 1/1+1/3+...+1/n. 首先写一个n为偶数的函数: def peven(n): s = 0 ...

  2. 【模板】dijkstra

    洛谷 4779 #include<cstdio> #include<cstring> #include<algorithm> #include<queue&g ...

  3. HDU 5446 Unknown Treasure

    Unknown Treasure Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Other ...

  4. [luoguP3275] [SCOI2011]糖果(差分约束)

    传送门 差分约束裸题 但是坑! 有一个点是长为10W的链,需要逆序加边才能过(真是玄学) 还有各种坑爹数据 开longlong ——代码 #include <cstdio> #includ ...

  5. HDU 5467

    第一次写LCT,各种模板加入...以后都只遇到有新意的题目再更新了 这道题就是LCT,但是,难在一个回退的操作.这时,可以通过改变执行顺序,先把要回退后再做的操作先执行了,再回退到之前的执行.这时,建 ...

  6. Codeforces Round #305 (Div. 2) C题 (数论)

    C. Mike and Frog time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  7. Maven中的dependency的scope作用域详解

    1.test范围指的是测试范围有效,在编译和打包时都不会使用这个依赖 2.compile范围指的是编译范围有效,在编译和打包时都会将依赖存储进去 3.provided依赖:在编译和测试的过程有效,最后 ...

  8. STM32的独立看门狗

    STM32 内 部自带了 2 个看门狗:独立看门狗(IWDG)和窗体看门狗(WWDG) STM32 的独立看门狗由内部专门的 40Khz 低速时钟驱动.即使主时钟发生问题.它也仍然 有效. 这里须要注 ...

  9. Codeforces Round #281 (Div. 2) A. Vasya and Football 暴力

    A. Vasya and Football   Vasya has started watching football games. He has learned that for some foul ...

  10. 解析HTTP协议六种请求方法

    标准Http协议支持六种请求方法,即: 1,GET 2,HEAD 3,PUT 4,DELETE 5,POST 6,OPTIONS 但其实我们大部分情况下只用到了GET和POST.如果想设计一个符合RE ...