使用SSM重构Bookstore——产品模块及购物车部分

一、产品模块

1、产品列表

主要是分页——在此使用MybatisPageHelper分页插件

POM添加依赖

<dependency>
	<groupId>com.github.pagehelper</groupId>
	<artifactId>pagehelper</artifactId>
	<version>5.1.8</version>
</dependency>

Spring 修改 Mybatis 配置部分

<!-- Mybatis -->
<!-- 配置SqlSessionFactory对象 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
	<!-- 注入数据库连接池 -->
	<property name="dataSource" ref="dataSource" />
	<!-- 扫描sql配置文件:mapper需要的xml文件 -->
	<property name="mapperLocations" value="classpath:Mapper/*.xml" />
	<!--自动在下划线驼峰命名方式间转换 -->
	<property name="configuration" >
		<bean class="org.apache.ibatis.session.Configuration" >
			<property name="mapUnderscoreToCamelCase" value="true" />
			<property name="logImpl" value="org.apache.ibatis.logging.stdout.StdOutImpl"/>
			<!--"org.apache.ibatis.logging.log4j.Log4jImpl" --> <!-- 日志 -->
		</bean>
	</property>

	<property name="plugins" >
		<array> 
			<bean class="com.github.pagehelper.PageInterceptor">
				<property name="properties"><!--参数配置详见其github,下面这些注释掉StartPage也能正常工作 -->
				<value>
				    offsetAsPageNum=true <!-- 将 RowBounds 中的 offset 参数当成 pageNum 使用,可以用页码和页面大小两个参数进行分页-->
				    rowBoundsWithCount=true <!-- 使用 RowBounds 分页会进行 count 查询,需要使用PageInfo也得设置为true -->
					reasonable=true <!-- ageNum<=0 时会查询第一页, pageNum>pages(超过总数时),会查询最后一页 -->   
				</value>
				</property>
			</bean>
		</array>
	</property>
</bean>

<mybatis:scan base-package="com.bookstore.Dao" />

ProductController.java

package com.bookstore.Controller;

import com.bookstore.Domain.Product;
import com.bookstore.Service.ProductService;
import com.github.pagehelper.PageInfo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;

import java.util.List;

@Controller
public class ProductController {
   

    @Autowired
    private ProductService productService;

    @GetMapping("/productlist")
    public String productList(@RequestParam(required = false) String catagory, @RequestParam(value="page", required = false, defaultValue = "1") Integer curPage, Model model) {
   
        Integer pageSize = 5;
        List<Product> productList = productService.findProductsOnPage(curPage, pageSize, catagory); //实际类型分页插件修改后的Page<E>,它扩展了ArrayList
        model.addAttribute("pageInfo", new PageInfo(productList));
        model.addAttribute("productList", productList);
        return "product_list";
    }
}

ProductService.java

package com.bookstore.Controller;

import com.bookstore.Domain.Product;
import com.bookstore.Service.ProductService;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.github.pagehelper.PageInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;

import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletResponse;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.List;

@Service
public class ProductService {
   

    @Autowired
    private ProductMapper productDao;

    public List<Product> findProductsOnPage(Integer curPage, Integer pageSize, String catagory) {
   
        ProductExample productExample = new ProductExample();
        ProductExample.Criteria criteria = productExample.createCriteria();
        if(catagory == null || "".equals(catagory)){
   
            criteria.andCategoryIsNotNull();
        }else{
   
            criteria.andCategoryEqualTo(catagory);
        }
        PageHelper.startPage(curPage, pageSize
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,让我来为您具体讲解一下基于IDEA平台的SSM框架的农产品交易系统购物车模块的实现步骤。 1. 在前端页面中,添加购物车功能,包括添加商品、删除商品、修改商品数量、查看购物车等操作。可以使用Cookie或Session来存储购物车信息。 2. 在Controller中编写添加商品、删除商品、修改商品数量等操作的处理方法,该方法接收前端传递的商品信息和操作指令,然后进行相应的操作。 3. 在Service中编写购物车操作的实现方法,该方法将操作指令和商品信息传递给DAO进行操作,并返回购物车信息。 4. 在DAO中编写添加商品、删除商品、修改商品数量等操作的方法,用于对购物车信息进行操作。 5. 在前端页面中显示购物车信息,如商品名称、单价、数量、小计等,并提供结算功能,用于将购物车中的商品提交给后台进行结算。 6. 在Controller中编写结算功能的处理方法,该方法接收前端传递的购物车信息,并进行相应的结算操作,如生成订单、减少库存、计算总价等。 7. 在Service中编写结算功能的实现方法,该方法将购物车信息和其他必要信息传递给DAO进行结算操作,并返回结算结果。 8. 在DAO中编写生成订单、减少库存、计算总价等操作的方法,用于将购物车中的商品信息提交给数据库进行结算操作。 需要注意的是,在实现购物车功能时应当注意并发问题,如多个用户同时对同一件商品进行操作,可能会出现库存不足、订单重复等问题,需要进行合理的处理。 以上就是基于IDEA平台的SSM框架的农产品交易系统购物车模块的主要实现步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值