javaweb購物車實現的幾種方式


之前沒有接觸過購物車的東東,也不知道購物車應該怎么做,所以在查詢了很多資料,總結一下購物車的功能實現。

查詢的資料,找到三種方法:

1.用cookie實現購物車;

2.用session實現購物車;

3.用cookie和數據庫(購物車信息持久化)實現購物車;

分析一下這三種方法的優缺點:

1.單純有cookie實現購物車,這樣的購物車不是很理想,設想一下,如果客戶端的瀏覽器把cookie給禁用了,

這種方法就會在這里流產…

2.session中保存購物車的信息,這個只是在一個會話中可用,如果用戶沒有登錄,或者說登錄了以后,添加購物車,在關閉瀏覽器

或者登出后,之前所添加的購物車通通都流產啦…

3.我這里要說就是這種方法啦…..

主要的流程:

A.用戶登錄前的數據流:用戶在沒有登錄系統的時候,對喜歡的商品進行添加購物車,那么這個時候,我們可以把購物車信息保存

到cookie中,這里會涉及到cookie的添加,修改操作;也即如果之前在cookie中不存對應的cookie,則就對cookie進行添加操作。

如果在cookie中存在對應的cookie,那么,這時候,就要對cookie進行修改操作了(這里涉及到用戶對同一個商品進行多次添加購物車的情況)。

B.用戶登錄后的數據流:用戶在登錄后,系統首先做的第一件事就是去獲取對應的cookies,如果存在相關的購物車cookies,那么就對該購物車

信息進行相應用戶User的持久化操作,要么添加,要么修改。(添加操作:該用戶所對應的購物車如果沒有相應的信息進行添加操作;修改操作:類似的,

如果存在對應用戶的購物車信息,就進行修改操作)。用戶登錄后,也可以進行購物車的添加操作,不過,這里不是添加到cookie中,而是直接持久化到

數據庫中。注:用戶登錄后的數據都是和數據庫打交道。

代碼部分:

 

注:

Conf.IDUONA_CASHTICKET_COOKIE_STARTNAME = "iduona_cashTicket_";
1
/**
* 用戶登錄
* 
* @author hongten
*/
public void login() {
//用戶登錄的時候,去讀取cookies,並且進行持久話操作,更多的登錄操作這里省略啦....
peristShoppingCartWhenUserLogin(newUser);
}

/**
* 加入購物車<br> 我的Java學習交流QQ群:589809992 我們一起學Java!
* ============================================<br>
* 用戶登錄前:<br>
* 用戶在選擇現金券的時候,點擊現金券的加入購物車的時候,會把該現金券的信息(現金券的id,購買數量)<br>
* 傳遞到這里,這時候,后台要做的就是從cookie中查詢出是否有相同的記錄,如果有相同的記錄<br>
* 則把相應的記錄更新;否則,就添加新的記錄<br>
* 用戶登錄后:<br>
* 用戶在登錄后,如果有添加購物車操作,則不用保存到cookie中,而是直接持久化購物車信息<br>
* 
* @throws Exception
*/
public void addToShoppingCart() throws Exception {
if (cashTicket == null || cashTicket.getId() == null || cashTicket.getId() < 1) {
write("nullId");
} else if (q == null || q == "") {
// 購買數量,默認情況下面為1
q = String.valueOf(1);
} else {
// 讀取所有的cookie
Cookie cookies[] = ServletActionContext.getRequest().getCookies();
if (cookies == null || cookies.length < 0) {
// 沒有cookie
System.out.println("there is no any cookie ..");
} else {
// 判斷用戶是否登錄
if (getUserInSession() == null) {
boolean flag = true;
for (Cookie c : cookies) {
if (c.getName().equals(Conf.IDUONA_CASHTICKET_COOKIE_STARTNAME + cashTicket.getId())) {
// 說明已有的cookies中有相應的cookie,就進行更新操作
Integer oldValue = Integer.valueOf(c.getValue());
Integer newValue = Integer.valueOf(oldValue + Integer.valueOf(q));
fixCookie(c, newValue.toString().trim());
flag = false;
}
}
// 說明已有的cookies中沒有相應的cookie,就進行添加操作
if (flag) {
addCookie(Conf.IDUONA_CASHTICKET_COOKIE_STARTNAME + cashTicket.getId(), q.trim());
}

// ==================================================
// 測試用,讀取所有的cookies
readShoppingCartFromCookie();
// ==================================================

write("success");
} else {
// 如果用戶登錄,說明session存在user,這時就持久化購物車信息
CashTicket cashTicketTemp = cashTicketService.get(cashTicket.getId());
if (shoppingCartService.isExistUserAndCashTicket(getUserInSession(), cashTicketTemp)) {
ShoppingCart oldShoppingCart = shoppingCartService.getByUserAndCashTicket(getUserInSession(), cashTicketTemp);
oldShoppingCart.setAmount(oldShoppingCart.getAmount() + Integer.valueOf(q));
if (shoppingCartService.update(oldShoppingCart)) {
write("success");
}
} else {
ShoppingCart shoppingCartTemp = new ShoppingCart();
shoppingCartTemp.setAmount(Integer.valueOf(q));
shoppingCartTemp.setUser(getUserInSession());
shoppingCartTemp.setCashTicket(cashTicketTemp);
shoppingCartTemp.setCreateTime(new Date());
shoppingCartTemp.setStatusType(StatusType.POSITIVE);
shoppingCartTemp.setUuid(UUID.randomUUID().toString());
if (shoppingCartService.save(shoppingCartTemp)) {
write("success");
}
}
}
}
}
}

/**
* 從cookie中讀取購物車信息
* 
* @throws Exception
* @return
*/
public void readShoppingCartFromCookie() throws Exception {
System.out.println("======================================================");
Cookie cookies[] = ServletActionContext.getRequest().getCookies();
if (cookies == null || cookies.length < 0) {
// System.out.println("there is no any cookie ..");
// 沒有cookie
} else {
for (Cookie c : cookies) {
System.out.println("haha there are many cookies :" + c.getName() + " " + c.getValue());
}
}
}

/**
* 添加cookie操作
* 
* @param name
* cookie的name
* @param value
* cookie的value
*/
public void addCookie(String name, String value) {
Cookie cookie = new Cookie(name.trim(), value.trim());
cookie.setMaxAge(2 * 60 * 60 * 1000);// 設置為2個鍾
ServletActionContext.getResponse().addCookie(cookie);
}

/**
* 更新cookie操作
* 
* @param c
* 要修改的cookie
* @param value
* 修改的cookie的值
*/
public void fixCookie(Cookie c, String value) {
c.setValue(value.trim());
c.setMaxAge(2 * 60 * 60 * 1000);// 設置為2個鍾
ServletActionContext.getResponse().addCookie(c);
}

/**
* 當用戶登錄的時候,持久化cookie中的購物車信息,更新為本用戶的購物車信息
*/
public void peristShoppingCartWhenUserLogin(User user) {
if (null != user) {
Cookie cookies[] = ServletActionContext.getRequest().getCookies();
if (cookies != null) {
for (Cookie c : cookies) {
if (c.getName().startsWith(Conf.IDUONA_CASHTICKET_COOKIE_STARTNAME)) {
// 獲取cookie的名稱:"iduona_cashTicket_45" 和 cookie的值: "21"
String name = c.getName();
Integer amount = Integer.valueOf(Integer.valueOf(c.getValue())+Integer.valueOf(q));
Integer ct_id = Integer.valueOf(name.substring(name.lastIndexOf("_") + 1));
CashTicket temp = cashTicketService.get(ct_id);
ShoppingCart shoppingCartTemp = new ShoppingCart();
if (null != temp) {
if (shoppingCartService.isExistUserAndCashTicket(user, temp)) {
// 進行更新操作
ShoppingCart oldShoppingCart = shoppingCartService.getByUserAndCashTicket(user, temp);
oldShoppingCart.setAmount(amount);
shoppingCartService.update(oldShoppingCart);
} else {
// 否則進行保存記錄
shoppingCartTemp.setAmount(amount);
shoppingCartTemp.setUser(user);
shoppingCartTemp.setCashTicket(temp);
shoppingCartTemp.setCreateTime(new Date());
shoppingCartTemp.setStatusType(StatusType.POSITIVE);
shoppingCartTemp.setUuid(UUID.randomUUID().toString());
shoppingCartService.save(shoppingCartTemp);
}
}
}
}
// 移除所有的現金券cookies
removeAllCookies();
}
}
}

/**
* 移除所有的現金券cookies操作
*/
public void removeAllCookies() {
Cookie cookies[] = ServletActionContext.getRequest().getCookies();
if (cookies == null || cookies.length < 0) {
// 沒有cookie
System.out.println("there is no any cookie ..");
} else {
System.out.println("開始刪除cookies..");
for (Cookie c : cookies) {
if (c.getName().startsWith(Conf.IDUONA_CASHTICKET_COOKIE_STARTNAME)) {
c.setMaxAge(0);// 設置為0
ServletActionContext.getResponse().addCookie(c);
}
}
}
}

 


這是部分代碼….
效果:
用戶沒有登錄的情況下

 

用戶登錄了以后:

 

數據庫里面的情況:
登錄前數據

 


---------------------
作者:CSDN劉成
來源:CSDN
原文:https://blog.csdn.net/sd09044901guic/article/details/80132451?utm_source=copy
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM