最终效果

image.png

数据库表设计

用户地址单独为一张表,因为一个用户可能会设置多个收货地址
image.png

编写service

  1. package com.shiers.service;
  2. import com.shiers.pojo.UserAddress;
  3. import com.shiers.pojo.bo.AddressBO;
  4. import java.util.List;
  5. /**
  6. * Demo class
  7. *
  8. * @author shierS
  9. * @date 2021/5/29
  10. */
  11. public interface AddressService {
  12. /**
  13. * 根据用户Id查询用户收货地址列表
  14. * @param userId
  15. * @return
  16. */
  17. public List<UserAddress> queryAll(String userId);
  18. /**
  19. * 用于新增用户地址
  20. * @param addressBO
  21. */
  22. public void addNewUserAddress(AddressBO addressBO);
  23. /**
  24. * 用户修改地址
  25. * @param addressBO
  26. */
  27. public void updateUserAddress(AddressBO addressBO);
  28. /**
  29. * 根据用户id和地址id,删除对应的地址信息
  30. * @param userId
  31. * @param addressId
  32. */
  33. public void deleteUserAddress(String userId,String addressId);
  34. /**
  35. * 根据用户id和地址id,设置默认地址
  36. * @param userId
  37. * @param addressId
  38. */
  39. public void updateUserAddressToBeDefault(String userId,String addressId);
  40. }
  1. package com.shiers.service.impl;
  2. import com.shiers.enums.YesOrNo;
  3. import com.shiers.mapper.UserAddressMapper;
  4. import com.shiers.pojo.UserAddress;
  5. import com.shiers.pojo.bo.AddressBO;
  6. import com.shiers.service.AddressService;
  7. import org.n3r.idworker.Sid;
  8. import org.springframework.beans.BeanUtils;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.stereotype.Service;
  11. import org.springframework.transaction.annotation.Propagation;
  12. import org.springframework.transaction.annotation.Transactional;
  13. import java.util.Date;
  14. import java.util.List;
  15. /**
  16. * Demo class
  17. *
  18. * @author shierS
  19. * @date 2021/5/29
  20. */
  21. @Service
  22. public class AddressServiceImpl implements AddressService {
  23. @Autowired
  24. private UserAddressMapper userAddressMapper;
  25. @Autowired
  26. private Sid sid;
  27. @Transactional(propagation = Propagation.SUPPORTS)
  28. @Override
  29. public List<UserAddress> queryAll(String userId) {
  30. UserAddress ua = new UserAddress();
  31. ua.setUserId(userId);
  32. return userAddressMapper.select(ua);
  33. }
  34. @Transactional(propagation = Propagation.REQUIRED)
  35. @Override
  36. public void addNewUserAddress(AddressBO addressBO) {
  37. //1、判断当前用户是否存在地址,如果没有,则新增为默认地址
  38. Integer isDefault = 0;
  39. List<UserAddress> addressList = this.queryAll(addressBO.getUserId());
  40. if (addressList == null || addressList.isEmpty() || addressList.size() == 0) {
  41. isDefault = 1;
  42. }
  43. //定义主键Id
  44. String addressId = sid.nextShort();
  45. //2、保存地址到数据库
  46. UserAddress newAddress = new UserAddress();
  47. //将addressBO中对应的属性字段填充到newAddress中
  48. BeanUtils.copyProperties(addressBO,newAddress);
  49. //填充剩余字段
  50. newAddress.setId(addressId);
  51. newAddress.setIsDefault(isDefault);
  52. newAddress.setCreatedTime(new Date());
  53. newAddress.setUpdatedTime(new Date());
  54. userAddressMapper.insert(newAddress);
  55. }
  56. @Transactional(propagation = Propagation.REQUIRED)
  57. @Override
  58. public void updateUserAddress(AddressBO addressBO) {
  59. String addressId = addressBO.getAddressId();
  60. UserAddress pendingAddress = new UserAddress();
  61. BeanUtils.copyProperties(addressBO,pendingAddress);
  62. pendingAddress.setId(addressId);
  63. pendingAddress.setUpdatedTime(new Date());
  64. userAddressMapper.updateByPrimaryKeySelective(pendingAddress);
  65. }
  66. @Transactional(propagation = Propagation.REQUIRED)
  67. @Override
  68. public void deleteUserAddress(String userId, String addressId) {
  69. UserAddress address = new UserAddress();
  70. address.setId(addressId);
  71. address.setUserId(userId);
  72. userAddressMapper.delete(address);
  73. }
  74. @Transactional(propagation = Propagation.REQUIRED)
  75. @Override
  76. public void updateUserAddressToBeDefault(String userId, String addressId) {
  77. //1.查找默认地址设置为不默认
  78. UserAddress queryAddress = new UserAddress();
  79. queryAddress.setUserId(userId);
  80. queryAddress.setIsDefault(YesOrNo.YES.type);
  81. //将为默认地址的数据都查询出来,主要是为了放置数据紊乱,有多个默认地址出现,这样可以解决数据紊乱,为一种保险措施
  82. List<UserAddress> list = userAddressMapper.select(queryAddress);
  83. for (UserAddress ua : list) {
  84. ua.setIsDefault(YesOrNo.NO.type);
  85. userAddressMapper.updateByPrimaryKeySelective(ua);
  86. }
  87. //2.根据地址id修改为默认地址
  88. UserAddress defaultAddress = new UserAddress();
  89. defaultAddress.setId(addressId);
  90. defaultAddress.setUserId(userId);
  91. defaultAddress.setIsDefault(YesOrNo.YES.type);
  92. userAddressMapper.updateByPrimaryKeySelective(defaultAddress);
  93. }
  94. }

编写Controller

  1. package com.shiers.controller;
  2. import com.shiers.pojo.UserAddress;
  3. import com.shiers.pojo.bo.AddressBO;
  4. import com.shiers.service.AddressService;
  5. import com.shiers.utils.MobileEmailUtils;
  6. import com.shiers.utils.MyJSONResult;
  7. import io.swagger.annotations.Api;
  8. import io.swagger.annotations.ApiOperation;
  9. import org.apache.commons.lang3.StringUtils;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.web.bind.annotation.*;
  12. import springfox.documentation.annotations.ApiIgnore;
  13. import java.util.List;
  14. /**
  15. * Demo classO
  16. *
  17. * @author shierS
  18. * @date 2021/5/21
  19. */
  20. @Api(value = "地址相关" ,tags = {"地址相关API接口"})
  21. @RequestMapping("address")
  22. @RestController
  23. public class AddressController {
  24. /**
  25. * 用户在确认订单页面,可以针对收货地址做如下操作:
  26. * 1、查询用户所有收货地址列表
  27. * 2、新增地址
  28. * 3、删除地址
  29. * 4、修改地址
  30. * 5、设置默认地址
  31. */
  32. @Autowired
  33. private AddressService addressService;
  34. @ApiOperation(value = "根据用户id查询收货地址列表",notes = "根据用户id查询收货地址列表",httpMethod = "POST")
  35. @PostMapping("/list")
  36. public MyJSONResult list(@RequestParam String userId){
  37. if (StringUtils.isBlank(userId)){
  38. return MyJSONResult.errorMsg("");
  39. }
  40. List<UserAddress> list = addressService.queryAll(userId);
  41. return MyJSONResult.ok(list);
  42. }
  43. @ApiOperation(value = "用户新增地址",notes = "用户新增地址",httpMethod = "POST")
  44. @PostMapping("/add")
  45. public MyJSONResult add(@RequestBody AddressBO addressBO) {
  46. MyJSONResult checkRes = checkAddress(addressBO);
  47. if (checkRes.getStatus() != 200) {
  48. return checkRes;
  49. }
  50. addressService.addNewUserAddress(addressBO);
  51. return MyJSONResult.ok();
  52. }
  53. private MyJSONResult checkAddress(AddressBO addressBO) {
  54. String receiver = addressBO.getReceiver();
  55. if (StringUtils.isBlank(receiver)) {
  56. return MyJSONResult.errorMsg("收货人不能为空");
  57. }
  58. if (receiver.length() > 12) {
  59. return MyJSONResult.errorMsg("收货人姓名不能太长");
  60. }
  61. String mobile = addressBO.getMobile();
  62. if (StringUtils.isBlank(mobile)) {
  63. return MyJSONResult.errorMsg("收货人手机号不能为空");
  64. }
  65. if (mobile.length() != 11) {
  66. return MyJSONResult.errorMsg("收货人手机号长度不正确");
  67. }
  68. boolean isMobileOk = MobileEmailUtils.checkMobileIsOk(mobile);
  69. if (!isMobileOk) {
  70. return MyJSONResult.errorMsg("收货人手机号格式不正确");
  71. }
  72. String province = addressBO.getProvince();
  73. String city = addressBO.getCity();
  74. String district = addressBO.getDistrict();
  75. String detail = addressBO.getDetail();
  76. if (StringUtils.isBlank(province) ||
  77. StringUtils.isBlank(city) ||
  78. StringUtils.isBlank(district) ||
  79. StringUtils.isBlank(detail)) {
  80. return MyJSONResult.errorMsg("收货地址信息不能为空");
  81. }
  82. return MyJSONResult.ok();
  83. }
  84. @ApiOperation(value = "用户修改地址",notes = "用户修改地址",httpMethod = "POST")
  85. @PostMapping("/update")
  86. public MyJSONResult update(@RequestBody AddressBO addressBO) {
  87. if (StringUtils.isBlank(addressBO.getAddressId())){
  88. return MyJSONResult.errorMsg("修改地址错误:addressId不能为空");
  89. }
  90. MyJSONResult checkRes = checkAddress(addressBO);
  91. if (checkRes.getStatus() != 200) {
  92. return checkRes;
  93. }
  94. addressService.updateUserAddress(addressBO);
  95. return MyJSONResult.ok();
  96. }
  97. @ApiOperation(value = "用户删除地址",notes = "用户删除地址",httpMethod = "POST")
  98. @PostMapping("/delete")
  99. public MyJSONResult delete(
  100. @RequestParam String userId,
  101. @RequestParam String addressId) {
  102. if (StringUtils.isBlank(userId) || StringUtils.isBlank(addressId) ){
  103. return MyJSONResult.errorMsg("");
  104. }
  105. addressService.deleteUserAddress(userId,addressId);
  106. return MyJSONResult.ok();
  107. }
  108. @ApiOperation(value = "用户设置默认地址",notes = "用户设置默认地址",httpMethod = "POST")
  109. @PostMapping("/setDefalut")
  110. public MyJSONResult setDefalut(
  111. @RequestParam String userId,
  112. @RequestParam String addressId) {
  113. if (StringUtils.isBlank(userId) || StringUtils.isBlank(addressId) ){
  114. return MyJSONResult.errorMsg("");
  115. }
  116. addressService.updateUserAddressToBeDefault(userId,addressId);
  117. return MyJSONResult.ok();
  118. }
  119. }