Merge branch 'master' of gitee.com:beijing_hongye_huicheng/lilishop into feature/pg
This commit is contained in:
		
						commit
						d470192ac6
					
				| @ -47,6 +47,7 @@ public enum ResultCode { | |||||||
|     CATEGORY_HAS_CHILDREN(10005, "此类别下存在子类别不能删除"), |     CATEGORY_HAS_CHILDREN(10005, "此类别下存在子类别不能删除"), | ||||||
|     CATEGORY_HAS_GOODS(10006, "此类别下存在商品不能删除"), |     CATEGORY_HAS_GOODS(10006, "此类别下存在商品不能删除"), | ||||||
|     CATEGORY_SAVE_ERROR(10007, "此类别下存在商品不能删除"), |     CATEGORY_SAVE_ERROR(10007, "此类别下存在商品不能删除"), | ||||||
|  |     CATEGORY_PARAMETER_NOT_EXIST(10012, "分类绑定参数组不存在"), | ||||||
|     CATEGORY_PARAMETER_SAVE_ERROR(10008, "分类绑定参数组添加失败"), |     CATEGORY_PARAMETER_SAVE_ERROR(10008, "分类绑定参数组添加失败"), | ||||||
|     CATEGORY_PARAMETER_UPDATE_ERROR(10009, "分类绑定参数组添加失败"), |     CATEGORY_PARAMETER_UPDATE_ERROR(10009, "分类绑定参数组添加失败"), | ||||||
|     CATEGORY_DELETE_FLAG_ERROR(10010, "子类状态不能与父类不一致!"), |     CATEGORY_DELETE_FLAG_ERROR(10010, "子类状态不能与父类不一致!"), | ||||||
| @ -72,6 +73,7 @@ public enum ResultCode { | |||||||
|     GOODS_PARAMS_ERROR(11013, "商品参数错误,刷新后重试"), |     GOODS_PARAMS_ERROR(11013, "商品参数错误,刷新后重试"), | ||||||
|     PHYSICAL_GOODS_NEED_TEMP(11014, "实物商品需选择配送模板"), |     PHYSICAL_GOODS_NEED_TEMP(11014, "实物商品需选择配送模板"), | ||||||
|     VIRTUAL_GOODS_NOT_NEED_TEMP(11015, "实物商品需选择配送模板"), |     VIRTUAL_GOODS_NOT_NEED_TEMP(11015, "实物商品需选择配送模板"), | ||||||
|  |     GOODS_NOT_EXIST_STORE(11017, "当前用户无权操作此商品"), | ||||||
|     GOODS_TYPE_ERROR(11016, "需选择商品类型"), |     GOODS_TYPE_ERROR(11016, "需选择商品类型"), | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  | |||||||
| @ -13,6 +13,8 @@ import java.io.Serializable; | |||||||
| @AllArgsConstructor | @AllArgsConstructor | ||||||
| public class AuthUser implements Serializable { | public class AuthUser implements Serializable { | ||||||
| 
 | 
 | ||||||
|  |     private static final long serialVersionUID = 582441893336003319L; | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * 用户名 |      * 用户名 | ||||||
|      */ |      */ | ||||||
|  | |||||||
| @ -1,6 +1,8 @@ | |||||||
| package cn.lili.common.security.filter; | package cn.lili.common.security.filter; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | import cn.hutool.http.HtmlUtil; | ||||||
|  | 
 | ||||||
| import javax.servlet.http.HttpServletRequest; | import javax.servlet.http.HttpServletRequest; | ||||||
| import javax.servlet.http.HttpServletRequestWrapper; | import javax.servlet.http.HttpServletRequestWrapper; | ||||||
| import java.util.regex.Pattern; | import java.util.regex.Pattern; | ||||||
| @ -107,25 +109,26 @@ public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper { | |||||||
| 
 | 
 | ||||||
|     private String cleanXSS(String value) { |     private String cleanXSS(String value) { | ||||||
|         if (value != null) { |         if (value != null) { | ||||||
|             //推荐使用ESAPI库来避免脚本攻击,value = ESAPI.encoder().canonicalize(value); | //            //推荐使用ESAPI库来避免脚本攻击,value = ESAPI.encoder().canonicalize(value); | ||||||
|             //避免script 标签 | //            //避免script 标签 | ||||||
|             value = SCRIPT_PATTERN1.matcher(value).replaceAll(""); | //            value = SCRIPT_PATTERN1.matcher(value).replaceAll(""); | ||||||
|             //删除单个的 </script> 标签 | //            //删除单个的 </script> 标签 | ||||||
|             value = SCRIPT_PATTERN2.matcher(value).replaceAll(""); | //            value = SCRIPT_PATTERN2.matcher(value).replaceAll(""); | ||||||
|             //删除单个的<script ...> 标签 | //            //删除单个的<script ...> 标签 | ||||||
|             value = SCRIPT_PATTERN3.matcher(value).replaceAll(""); | //            value = SCRIPT_PATTERN3.matcher(value).replaceAll(""); | ||||||
|             //避免 javascript: 表达式 | //            //避免 javascript: 表达式 | ||||||
|             value = SCRIPT_PATTERN4.matcher(value).replaceAll(""); | //            value = SCRIPT_PATTERN4.matcher(value).replaceAll(""); | ||||||
|             //避免src形式的表达式 | //            //避免src形式的表达式 | ||||||
|             value = SRC_PATTERN.matcher(value).replaceAll(""); | //            value = SRC_PATTERN.matcher(value).replaceAll(""); | ||||||
|             //避免 eval(...) 形式表达式 | //            //避免 eval(...) 形式表达式 | ||||||
|             value = EVAL_PATTERN.matcher(value).replaceAll(""); | //            value = EVAL_PATTERN.matcher(value).replaceAll(""); | ||||||
|             //避免 expression(...) 表达式 | //            //避免 expression(...) 表达式 | ||||||
|             value = E__XPRESSION_PATTERN.matcher(value).replaceAll(""); | //            value = E__XPRESSION_PATTERN.matcher(value).replaceAll(""); | ||||||
|             //避免 vbscript:表达式 | //            //避免 vbscript:表达式 | ||||||
|             value = VB_SCRIPT_PATTERN.matcher(value).replaceAll(""); | //            value = VB_SCRIPT_PATTERN.matcher(value).replaceAll(""); | ||||||
|             //避免 onload= 表达式 | //            //避免 onload= 表达式 | ||||||
|             value = ONLOAD_PATTERN.matcher(value).replaceAll(""); | //            value = ONLOAD_PATTERN.matcher(value).replaceAll(""); | ||||||
|  |             value = HtmlUtil.filter(value); | ||||||
|         } |         } | ||||||
|         return value; |         return value; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ import com.baomidou.mybatisplus.annotation.TableName; | |||||||
| import io.swagger.annotations.ApiModel; | import io.swagger.annotations.ApiModel; | ||||||
| import io.swagger.annotations.ApiModelProperty; | import io.swagger.annotations.ApiModelProperty; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
| import org.hibernate.validator.constraints.Length; | import org.hibernate.validator.constraints.Length; | ||||||
| 
 | 
 | ||||||
| import javax.validation.constraints.NotEmpty; | import javax.validation.constraints.NotEmpty; | ||||||
| @ -16,6 +17,7 @@ import javax.validation.constraints.NotNull; | |||||||
|  * @author pikachu |  * @author pikachu | ||||||
|  * @since 2020-02-26 10:34:02 |  * @since 2020-02-26 10:34:02 | ||||||
|  */ |  */ | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
| @Data | @Data | ||||||
| @TableName("li_category_parameter_group") | @TableName("li_category_parameter_group") | ||||||
| @ApiModel(value = "分类绑定参数组") | @ApiModel(value = "分类绑定参数组") | ||||||
|  | |||||||
| @ -5,6 +5,7 @@ import com.baomidou.mybatisplus.annotation.TableName; | |||||||
| import io.swagger.annotations.ApiModel; | import io.swagger.annotations.ApiModel; | ||||||
| import io.swagger.annotations.ApiModelProperty; | import io.swagger.annotations.ApiModelProperty; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
|  | import lombok.EqualsAndHashCode; | ||||||
| import org.hibernate.validator.constraints.Length; | import org.hibernate.validator.constraints.Length; | ||||||
| 
 | 
 | ||||||
| import javax.validation.constraints.Max; | import javax.validation.constraints.Max; | ||||||
| @ -18,6 +19,7 @@ import javax.validation.constraints.NotNull; | |||||||
|  * @author pikachu |  * @author pikachu | ||||||
|  * @since 2020-02-23 9:14:33 |  * @since 2020-02-23 9:14:33 | ||||||
|  */ |  */ | ||||||
|  | @EqualsAndHashCode(callSuper = true) | ||||||
| @Data | @Data | ||||||
| @TableName("li_parameters") | @TableName("li_parameters") | ||||||
| @ApiModel(value = "商品参数") | @ApiModel(value = "商品参数") | ||||||
|  | |||||||
| @ -31,4 +31,13 @@ public interface CategoryParameterGroupService extends IService<CategoryParamete | |||||||
|      */ |      */ | ||||||
|     List<CategoryParameterGroup> getCategoryGroup(String categoryId); |     List<CategoryParameterGroup> getCategoryGroup(String categoryId); | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * 更新分类参数组绑定信息 | ||||||
|  |      * | ||||||
|  |      * @param categoryParameterGroup 分类参数组信息 | ||||||
|  |      * @return 是否成功 | ||||||
|  |      */ | ||||||
|  |     boolean updateCategoryGroup(CategoryParameterGroup categoryParameterGroup); | ||||||
|  |      | ||||||
| } | } | ||||||
| @ -1,5 +1,7 @@ | |||||||
| package cn.lili.modules.goods.serviceimpl; | package cn.lili.modules.goods.serviceimpl; | ||||||
| 
 | 
 | ||||||
|  | import cn.lili.common.enums.ResultCode; | ||||||
|  | import cn.lili.common.exception.ServiceException; | ||||||
| import cn.lili.modules.goods.entity.dos.CategoryParameterGroup; | import cn.lili.modules.goods.entity.dos.CategoryParameterGroup; | ||||||
| import cn.lili.modules.goods.entity.dos.Parameters; | import cn.lili.modules.goods.entity.dos.Parameters; | ||||||
| import cn.lili.modules.goods.entity.vos.ParameterGroupVO; | import cn.lili.modules.goods.entity.vos.ParameterGroupVO; | ||||||
| @ -49,12 +51,28 @@ public class CategoryParameterGroupServiceImpl extends ServiceImpl<CategoryParam | |||||||
|         return this.list(new QueryWrapper<CategoryParameterGroup>().eq("category_id", categoryId)); |         return this.list(new QueryWrapper<CategoryParameterGroup>().eq("category_id", categoryId)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * 更新分类参数组绑定信息 | ||||||
|  |      * | ||||||
|  |      * @param categoryParameterGroup 分类参数组信息 | ||||||
|  |      * @return 是否成功 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public boolean updateCategoryGroup(CategoryParameterGroup categoryParameterGroup) { | ||||||
|  |         CategoryParameterGroup origin = this.getById(categoryParameterGroup.getId()); | ||||||
|  |         if (origin == null) { | ||||||
|  |             throw new ServiceException(ResultCode.CATEGORY_PARAMETER_NOT_EXIST); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * 拼装参数组和参数的返回值 |      * 拼装参数组和参数的返回值 | ||||||
|      * |      * | ||||||
|      * @param groupList 参数组list |      * @param groupList 参数组list | ||||||
|      * @param paramList 商品参数list |      * @param paramList 商品参数list | ||||||
|      * @return |      * @return 参数组和参数的返回值 | ||||||
|      */ |      */ | ||||||
|     public List<ParameterGroupVO> convertParamList(List<CategoryParameterGroup> groupList, List<Parameters> paramList) { |     public List<ParameterGroupVO> convertParamList(List<CategoryParameterGroup> groupList, List<Parameters> paramList) { | ||||||
|         Map<String, List<Parameters>> map = new HashMap<>(paramList.size()); |         Map<String, List<Parameters>> map = new HashMap<>(paramList.size()); | ||||||
|  | |||||||
| @ -274,6 +274,12 @@ public class GoodsServiceImpl extends ServiceImpl<GoodsMapper, Goods> implements | |||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public Boolean updateGoodsMarketAble(List<String> goodsIds, GoodsStatusEnum goodsStatusEnum, String underReason) { |     public Boolean updateGoodsMarketAble(List<String> goodsIds, GoodsStatusEnum goodsStatusEnum, String underReason) { | ||||||
|  |         boolean result; | ||||||
|  | 
 | ||||||
|  |         if (UserContext.getCurrentUser() == null || UserContext.getCurrentUser().getStoreId() == null) { | ||||||
|  |             throw new ServiceException(ResultCode.USER_NOT_LOGIN); | ||||||
|  |         } | ||||||
|  |         String storeId = UserContext.getCurrentUser().getStoreId(); | ||||||
| 
 | 
 | ||||||
|         //如果商品为空,直接返回 |         //如果商品为空,直接返回 | ||||||
|         if (goodsIds == null || goodsIds.isEmpty()) { |         if (goodsIds == null || goodsIds.isEmpty()) { | ||||||
| @ -283,16 +289,16 @@ public class GoodsServiceImpl extends ServiceImpl<GoodsMapper, Goods> implements | |||||||
|         LambdaUpdateWrapper<Goods> updateWrapper = Wrappers.lambdaUpdate(); |         LambdaUpdateWrapper<Goods> updateWrapper = Wrappers.lambdaUpdate(); | ||||||
|         updateWrapper.set(Goods::getMarketEnable, goodsStatusEnum.name()); |         updateWrapper.set(Goods::getMarketEnable, goodsStatusEnum.name()); | ||||||
|         updateWrapper.set(Goods::getUnderMessage, underReason); |         updateWrapper.set(Goods::getUnderMessage, underReason); | ||||||
|  |         updateWrapper.eq(Goods::getStoreId, storeId); | ||||||
|         updateWrapper.in(Goods::getId, goodsIds); |         updateWrapper.in(Goods::getId, goodsIds); | ||||||
|         this.update(updateWrapper); |         result = this.update(updateWrapper); | ||||||
| 
 | 
 | ||||||
|         //修改规格商品 |         //修改规格商品 | ||||||
|         List<Goods> goodsList = this.list(new LambdaQueryWrapper<Goods>().in(Goods::getId, goodsIds)); |         List<Goods> goodsList = this.list(new LambdaQueryWrapper<Goods>().in(Goods::getId, goodsIds).eq(Goods::getStoreId, storeId)); | ||||||
|         for (Goods goods : goodsList) { |         for (Goods goods : goodsList) { | ||||||
|             goodsSkuService.updateGoodsSkuStatus(goods); |             goodsSkuService.updateGoodsSkuStatus(goods); | ||||||
|         } |         } | ||||||
|         return true; |         return result; | ||||||
| 
 |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|  | |||||||
| @ -85,6 +85,9 @@ public class EsGoodsSearchServiceImpl implements EsGoodsSearchService { | |||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public List<String> getHotWords(Integer count) { |     public List<String> getHotWords(Integer count) { | ||||||
|  |         if (count == null) { | ||||||
|  |             count = 0; | ||||||
|  |         } | ||||||
|         List<String> hotWords = new ArrayList<>(); |         List<String> hotWords = new ArrayList<>(); | ||||||
|         // redis 排序中,下标从0开始,所以这里需要 -1 处理 |         // redis 排序中,下标从0开始,所以这里需要 -1 处理 | ||||||
|         count = count - 1; |         count = count - 1; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 paulGao
						paulGao