Cookie实现商品浏览记录--方式二:JS实现
使用Cookie实现商品浏览记录:
方式二:JS方法实现cookie的获取以及写入。
当某一个产品被点击时,触发JS方法。利用JS方法判断一下,此产品是否在浏览记录中。如果不存在,则将产品ID加入到cookie中。否则将此id之前的id全部后移一位,然后将此id移动至第一位。
注意的问题是:通过js方法写入cookie,在java代码中获取cookie的值,需要进行转码
java.net.URLDecoder.decode(listView,"UTF-8");
具体实现如下:
(1). JSP页面:当浏览某一个产品时,调用goView(id)方法,并将产品id作为参数传入。
```
<dt><a href="javascript:goView(${product.ep_id});">.....</a></dt>
```
(2). 在JS文件中,创建goView()方法。该方法的功能是,根据id写入cookie,并将页面跳转到Servlet中。
```
function goView(id) {
var aid = id;
var newCookie = "";
//获得key值为viewRecode的cookie的value值
var oldCookie = getCookie("viewRecode");
//如果oldCookie不为null
if (oldCookie) {
//将value值按照","分割成数组
var array = oldCookie.split(",");
//如果产品id在此数组中,则判断此id是否处于数组中第一个位置。如果不在第一个位置,则让此产品位置之前的id全部后移一位,然后将此id至于第一个位置。否则数组不变。
if (inArray(array, id)) {
for ( var a = 0; a < array.length; a++) {
if (array[a] == id) {
if (a != 0) {
array[a] = null;
for ( var j = a; j >= 0; j--) {
array[j] = array[j - 1];
array[j - 1] = null;
}
array[0] = id;
}
}
}
//将上述的数组按","拼接成字符串
newCookie = array.join(",");
}
//如果id不在此数组中,则将此id放在原字符串的最前面,并用","分割。
else {
newCookie = id + "," + oldCookie;
}
}
//如果cookie中不存在此key值,则是第一次访问产品,key值为 viewRecode的cookie不存在,则先设定value值为此id。
else {
newCookie = id;
}
//最后,将cookie写入进去.
setCookie("viewRecode", newCookie);
//页面跳转到servlet中.
location.href = "servlet/ProductServlet?param=productView&pid="+id;
}
//根据Cookie的key值得到对应的value.如果不存在,则返回null.
function getCookie(name)
{
var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));
if(arr != null) return unescape(arr[2]); return null;
}
//如果str在array数组中,返回true;否则返回false
function inArray(array, str) {
for(var a in array){
if(array[a] == str){
return true;
}
}
return false;
}
//写入cookie
function setCookie(name,value)
{
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000);
//在最后追加 ;path=/ 非常有必要。否则容易出现 在不同的目录下,调用同一个js方法来存储Cookie,到别的目录取不出或取出的值是不对的这种情况
document.cookie = name + "="+ escape(value) +";expires="+ exp.toGMTString()+";path=/";
}
```
(3). 在Servlet中通过获取Cookie中的值,得到商品列表,并显示到jsp页面中。
```
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
PrintWriter out = response.getWriter();
String param=request.getParameter("param");
CookieService cookieService = new CookieSerivceImpl();
Cookie[] cookies = request.getCookies();
if("listView".equals(param)){
String pid = request.getParameter("pid");
List<Product> products = new ArrayList<Product>();
//获取cookie,读取缓存
String listView = "";
if (cookies != null && cookies.length > 0) {
for (Cookie c : cookies) {
if ("listView".equals(c.getName())) {
System.out.println(c.toString());
listView = c.getValue();
break;
}
}
}
//这一步非常重要。因为Java接收JS传递值,需要解码。否则","会被解析成 "%2C"
//解码之后的字符串就是正常的。
String listView=java.net.URLDecoder.decode(listView,"UTF-8");
//根据产品id列表获得产品列表
products = cookieService.onLineProductList(listView);
request.getSession().setAttribute("products", products);
request.getRequestDispatcher("/servlet/ProductServlet?param=productView&pid="+pid).forward(request, response);
out.flush();
out.close();
}
}
```
最后在页面中通过EL表达式循环显示出列表即可。
针对以上内容,欢迎指正!
谢谢你来看我!
Cookie实现商品浏览记录--方式二:JS实现的更多相关文章
- Cookie实现商品浏览记录--方式一:Java实现
方式一:Java代码方式实现:此种方式实现思路较为顺畅.难点在于,如何实现将最近浏览的产品显示在最前面:实现方式是借助LinkedList提供的remove()方法,先将此id从列表中移除,然后再借助 ...
- 使用Cookie保存商品浏览记录
数据流程:页面上是商品列表,点击<a href="productServlet">商品名</a> ==>跳转到自定义的servlet中进行处理,先得到 ...
- javaWeb 使用cookie显示商品浏览记录
package de.bvb.cookie; import java.io.IOException; import java.io.PrintWriter; import java.util.Date ...
- Java遇见HTML——JSP篇之商品浏览记录的实现
一.项目总体介绍 使用Cookie实现商品浏览记录. 要实现这个程序采取的是Model1(Jsp+JavaBean)架构实现,具体步骤: 首先要有个数据库,商品表,操作数据库的一个类DBHelper类 ...
- (JS实现顾客商品浏览记录以及购物车)Cookie的保存与删除
//JS实现顾客浏览商品的记录以及实现购物车的功能function setCookie(name,value) { var Days = 30; var exp = new Date(); exp.s ...
- 使用cookie实现打印浏览记录的功能
可以用cookie知识来实现打印浏览记录.这里面用到的思路是将浏览记录以字符串的方式保存到cookie中,当浏览记录增加时,再将其转化为数组. $uri=$_SERVER['REQUEST_URI'] ...
- 使用cookies查询商品浏览记录
经历了俩个星期,易买网项目如期完工,现在总结一下如何使用cookies实现浏览商品的历史记录. 第一步:创建商品实体类. 第二步:连接oracle数据库. 第三步:创建商品三层架构. 效果图: 在要显 ...
- destoon系统开发-最新利用浏览器的cookie 做历史浏览记录
注意: 代码 放在要显示的为 (一般放在详情页),注意本教程不入库,直接利用浏览器的 cookie 缓存判断 <!--历史浏览记录 S--> <div class=&quo ...
- cookie的应用——浏览记录
实体类 package entity; public class Product { private String id; private String proName; private String ...
随机推荐
- PAT (Advanced Level) Practise:1001. A+B Format
[题目链接] Calculate a + b and output the sum in standard format -- that is, the digits must be separate ...
- Oracle数据类型隐式转换小析
测试使用环境:oracle 11g r1 平常写sql语句时,大大咧咧,不太注意和数字有关的数据类型,有时例如 where c1=111 和 where c1='111'这样混用,却不曾想这里面另有蹊 ...
- 用eclipse碰到的一些错误,然后自己去网上找的解决办法
错误一: [Please check logcat output for more details.Launch canceled! 解决办法:在配置文件:AndroidManifest.xml加入如 ...
- int类型究竟占几个字节
我最近也在看深入理解计算机系统这本书,上面提到了在32位机器和64机器中int类型都占用4个字节.后来,别人查了The C Programming language这本书,里面有一句话是这样的: Ea ...
- oracle 执行计划查看
1) sql command窗口里explain plan for select * from emp: 2) select * from table(dbms_xplan.display);
- 使用cocos2d-x3.4结合cocos2.1.5制作小游戏《亲亲小熊》
在最新的cocos集成环境中,CocosStudio已经集成到cocos中了,至于界面的制作和编辑器的基本使用在cocos官网有详细教程, 这里就不细说,资源下载和详情请参看官网教程:http://c ...
- python 3 学习笔记 (三)
1. 字典 定义:{key1:value1,key2:value2},key-value结构,key必须可hash特性:1.可存放多个值2.可修改指定key对应的值,可变3.无序 1.1. 创建字典 ...
- centos安装sublime
在官网下载,tarball 下载链接 http://www.sublimetext.com/3 提示信息: Ubuntu 64 bit - also available as a ...
- 修复FreeBSD上的ufs文件系统
昨天在两台FreeBSD上配置好Heartbeat服务(两台机器是用网线连通的,做为Heartbeat的两个节点),启动服务时Heartbeat检测到crmd守护进程没起来,于是它就尝试重启两台机器以 ...
- apache不断占内存过大,导致虚拟机内存不足,处理方法。
我用512M的vps,访问量不大,但内存占用很大,甚至宕机. 我用top,然后shitf+m发现,httpd占用内存极大.经过网上找资料设置后,用过一段时间终于没再出现内存问题了. 首先查找配置文件的 ...