javaweb mysql购物车_javaweb购物车实现的几种方式

这篇博客介绍了在JavaWeb中实现购物车功能的三种常见方法:1)使用Cookie,2)使用Session,3)结合Cookie和数据库实现购物车信息持久化。通过分析,指出单纯依赖Cookie的购物车不理想,Session保存的购物车只在会话内有效。重点讨论了结合Cookie和数据库的方法,包括用户未登录和已登录时的数据处理流程,并给出了部分关键代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前没有接触过购物车的东东,也不知道购物车应该怎么做,所以在查询了很多资料,总结一下购物车的功能实现。

查询的资料,找到三种方法:

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

/*** 用户登录

*

*@authorhongten*/

public voidlogin() {//用户登录的时候,去读取cookies,并且进行持久话操作,更多的登录操作这里省略啦....

peristShoppingCartWhenUserLogin(newUser);

}/*** 加入购物车
我的Java学习交流QQ群:589809992 我们一起学Java!

* ============================================

* 用户登录前:

* 用户在选择现金券的时候,点击现金券的加入购物车的时候,会把该现金券的信息(现金券的id,购买数量)

* 传递到这里,这时候,后台要做的就是从cookie中查询出是否有相同的记录,如果有相同的记录

* 则把相应的记录更新;否则,就添加新的记录

* 用户登录后:

* 用户在登录后,如果有添加购物车操作,则不用保存到cookie中,而是直接持久化购物车信息

*

*@throwsException*/

public void addToShoppingCart() throwsException {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= newShoppingCart();

shoppingCartTemp.setAmount(Integer.valueOf(q));

shoppingCartTemp.setUser(getUserInSession());

shoppingCartTemp.setCashTicket(cashTicketTemp);

shoppingCartTemp.setCreateTime(newDate());

shoppingCartTemp.setStatusType(StatusType.POSITIVE);

shoppingCartTemp.setUuid(UUID.randomUUID().toString());if(shoppingCartService.save(shoppingCartTemp)) {

write("success");

}

}

}

}

}

}/*** 从cookie中读取购物车信息

*

*@throwsException

*@return

*/

public void readShoppingCartFromCookie() throwsException {

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操作

*

*@paramname

* cookie的name

*@paramvalue

* cookie的value*/

public voidaddCookie(String name, String value) {

Cookie cookie= newCookie(name.trim(), value.trim());

cookie.setMaxAge(2 * 60 * 60 * 1000);//设置为2个钟

ServletActionContext.getResponse().addCookie(cookie);

}/*** 更新cookie操作

*

*@paramc

* 要修改的cookie

*@paramvalue

* 修改的cookie的值*/

public voidfixCookie(Cookie c, String value) {

c.setValue(value.trim());

c.setMaxAge(2 * 60 * 60 * 1000);//设置为2个钟

ServletActionContext.getResponse().addCookie(c);

}/*** 当用户登录的时候,持久化cookie中的购物车信息,更新为本用户的购物车信息*/

public voidperistShoppingCartWhenUserLogin(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= newShoppingCart();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(newDate());

shoppingCartTemp.setStatusType(StatusType.POSITIVE);

shoppingCartTemp.setUuid(UUID.randomUUID().toString());

shoppingCartService.save(shoppingCartTemp);

}

}

}

}//移除所有的现金券cookies

removeAllCookies();

}

}

}/*** 移除所有的现金券cookies操作*/

public voidremoveAllCookies() {

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);

}

}

}

}

这是部分代码….

效果:

用户没有登录的情况下

用户登录了以后:

数据库里面的情况:

登录前数据

---------------------

作者:优快云刘成

来源:优快云

原文:https://blog.youkuaiyun.com/sd09044901guic/article/details/80132451?utm_source=copy

版权声明:本文为博主原创文章,转载请附上博文链接!

Java Web应用中实现MySQL购物车功能通常涉及以下几个步骤: 1. **数据库设计**:创建数据库表结构,比如用户表(user)、商品表(product),以及购物车表(cart),其中购物车表可能包含用户ID、商品ID、数量等字段。 ```sql CREATE TABLE `users` ( `id` INT AUTO_INCREMENT PRIMARY KEY, `username` VARCHAR(50) NOT NULL UNIQUE ); CREATE TABLE `products` ( `id` INT AUTO_INCREMENT PRIMARY KEY, `name` VARCHAR(100), `price` DECIMAL(10, 2) ); CREATE TABLE `cart` ( `user_id` INT, `product_id` INT, `quantity` INT, FOREIGN KEY (`user_id`) REFERENCES users(id), FOREIGN KEY (`product_id`) REFERENCES products(id) ); ``` 2. **连接池管理**:使用如MyBatis或JDBC,建立到MySQL服务器的连接,并通过连接池管理复用连接,提高性能。 3. **业务逻辑**:在Java服务端,创建控制器层处理用户的操作,如添加商品、删除商品、修改数量。例如,用户点击“加入购物车”时,会将商品ID、数量当前登录用户的ID插入到cart表中。 4. **数据持久化**:使用ORM框架(如Hibernate、MyBatis),简化SQL的编写,对数据库进行增删改查操作。 5. **视图展示**:前端界面显示用户购物车内容,可以使用JSP/Spring MVC等技术渲染,显示商品列表数量。 6. **安全性**:考虑用户权限管理商品库存检查,防止恶意操作导致的问题。 7. **缓存优化**:如果流量大,可以利用Redis等缓存技术存储热门商品或购物车信息,减少数据库访问压力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值