java web開發——購物車功能實現
之前沒有接觸過購物車的東東,也不知道購物車應該怎麼做,所以在查詢了很多資料,總結一下購物車的功能實現。
查詢的資料,找到三種方法:
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_";
/**
* 使用者登入
*
* @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);
}
}
}
}
這是部分程式碼….
效果:
使用者沒有登入的情況下
使用者登入了以後:
資料庫裡面的情況:
登入前資料