苍穹外卖 08导入地址簿模块功能代码用户下单订单支付
2-15 导入地址簿模块功能代码&用户下单
01 01-今日课程内容介绍
02 02-导入地址簿模块功能代码_需求分析和设计
分析功能如下:
六个功能一定要设置六个接口吗?不是的,比如修改地址,修改前肯定要先查出之前的地址来进行页面回显。
这里请求参数是空的,因为我们常从拦截器解析 请求头得出用户id,所以不需要传出id。
03 03-导入地址簿模块功能代码_代码导入
都是简单的单表查询,去资料里面下载吧。
重点可能需要理解一下对默认地址的应用,默认地址只能存在一个,所以设置默认地址的时候需要先清除之前的默认地址再添加新的默认地址。
测试下来没什么问题。
2-16 用户下单&订单支付
05 05-用户下单_需求分析和设计_接口设计
06 06-用户下单_需求分析和设计_数据库设计
07 07-用户下单_代码开发
1,先根据返回值设置好对应的dto和vo
2,controller:
@RestController("userOrderController")
@RequestMapping("/user/order")
@Api(tags = "C端订单接口")
@Slf4j
public class OrderController {@Autowiredprivate OrderService orderService;/*** 用户下单* @param ordersSubmitDTO* @return*/@ApiOperation("用户下单")@PostMapping("/submit")public Result<OrderSubmitVO> Submit(@RequestBody OrdersSubmitDTO ordersSubmitDTO){log.info("用户下单:{}",ordersSubmitDTO);OrderSubmitVO orderSubmitVO = orderService.submitOrder(ordersSubmitDTO);return Result.success(orderSubmitVO);}}
实现类:
package com.sky.service.impl;import com.sky.constant.MessageConstant;
import com.sky.context.BaseContext;
import com.sky.dto.OrdersSubmitDTO;
import com.sky.entity.AddressBook;
import com.sky.entity.OrderDetail;
import com.sky.entity.Orders;
import com.sky.entity.ShoppingCart;
import com.sky.exception.AddressBookBusinessException;
import com.sky.mapper.AddressBookMapper;
import com.sky.mapper.OrderDetailMapper;
import com.sky.mapper.OrderMapper;
import com.sky.mapper.ShoppingCartMapper;
import com.sky.service.OrderService;
import com.sky.vo.OrderSubmitVO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;@Service
@Slf4j
public class OrderServiceImpl implements OrderService {@Autowiredprivate OrderMapper orderMapper;@Autowiredprivate OrderDetailMapper orderDetailMapper;@Autowiredprivate AddressBookMapper addressBookMapper;@Autowiredprivate ShoppingCartMapper shoppingCartMapper;/*** 用户下单* @param ordersSubmitDTO* @return*/@Override@Transactionalpublic OrderSubmitVO submitOrder(OrdersSubmitDTO ordersSubmitDTO) {log.info("用户下单:{}",ordersSubmitDTO);//处理各种业务异常://地址为空,不能下单AddressBook addressBook = addressBookMapper.getById(ordersSubmitDTO.getAddressBookId());if (addressBook == null) {//地址为空,不能下单throw new AddressBookBusinessException(MessageConstant.ADDRESS_BOOK_IS_NULL);}//购物车为空不能下单Long userId = BaseContext.getCurrentId();ShoppingCart shoppingCart = new ShoppingCart();shoppingCart.setUserId(userId);//将购物车数据存储在一个list购物车集合当中。List<ShoppingCart> list = shoppingCartMapper.list(shoppingCart);if (list == null || list.size() == 0) {//购物车为空不能下单throw new AddressBookBusinessException(MessageConstant.SHOPPING_CART_IS_NULL);}//------用户下单后向订单表插入一条数据-------log.info("用户下单,向订单表插入一条数据");Orders orders = new Orders();//拷贝BeanUtils.copyProperties(ordersSubmitDTO,orders);//补全orders.setOrderTime(LocalDateTime.now());orders.setPayStatus(Orders.UN_PAID);orders.setStatus(Orders.PENDING_PAYMENT);orders.setNumber(String.valueOf(System.currentTimeMillis()));//当前时间系统时间戳,前面的(String.valueOf用于转换类型orders.setPhone(addressBook.getPhone());orders.setConsignee(addressBook.getConsignee());orders.setUserId(userId);//插入orderMapper.insert(orders);//用户下单后向订单明细表插入n条数据log.info("用户下单,向订单明细表插入n条数据");//遍历购物车数据List<OrderDetail> orderDetails = new ArrayList<>();for (ShoppingCart cart : list){OrderDetail orderDetail = new OrderDetail();BeanUtils.copyProperties(cart,orderDetail);orderDetail.setOrderId(orders.getId());orderDetails.add(orderDetail);}//批量插入orderDetailMapper.insertBatch(orderDetails);//用户下单后要清空购物车数据shoppingCartMapper.deleteByUserId(userId);//返回订单数据VOOrderSubmitVO orderSubmitVO =OrderSubmitVO.builder().id(orders.getId()).orderTime(orders.getOrderTime()).orderNumber(orders.getNumber()).orderAmount(orders.getAmount()).build();return orderSubmitVO;}
}
涉及到了四个mapper的调用。所以要加@Transactional注解确保同时进行
要熟悉里面的操作流程和步骤。
首先:进行业务异常判断,要求地址不能为空且购物车不能为空
其次:将数据存入订单表中
再次:将订单明细存入订单明细表,由于之前从请求头当中获取到了对应的userid,我们就可以对应查询到用户购物车的信息。然后遍历用户购物车信息存储到一个订单明细对象当中,再将这个list类型的订单明细对象存储到订单明细表中。由于是集合,在mapper中要考虑foreach来处理数据内容了。
最后:删除该用户的购物车数据,将订单数据builder给对应的VO对象,返回VO。
测试:
到此,订单业务代码开发完毕!