| | |
| | | package com.panzhihua.shop_backstage.api; |
| | | |
| | | import static java.util.Objects.isNull; |
| | | import static java.util.Objects.nonNull; |
| | | |
| | | import java.util.regex.Pattern; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.validation.Valid; |
| | | |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.util.ObjectUtils; |
| | | import org.springframework.validation.annotation.Validated; |
| | | import org.springframework.web.bind.annotation.DeleteMapping; |
| | | import org.springframework.web.bind.annotation.GetMapping; |
| | | import org.springframework.web.bind.annotation.PostMapping; |
| | | import org.springframework.web.bind.annotation.PutMapping; |
| | | import org.springframework.web.bind.annotation.RequestBody; |
| | | import org.springframework.web.bind.annotation.RequestMapping; |
| | | import org.springframework.web.bind.annotation.RequestParam; |
| | | import org.springframework.web.bind.annotation.RestController; |
| | | |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.panzhihua.common.controller.BaseController; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.BindUserPhoneDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.DeleteProductDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.LoginWithPhoneDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.McsEvaluateDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.McsGameDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.McsInfoDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.McsMerchantDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.McsProductDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageJoinGameListDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageMcsEvaluateDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageMcsGameDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageMcsInformationDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageMcsMerchantDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageMcsProductDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PageVerifyRecordDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.PutUserInfoDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.SetShelfForGameDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.SetShelfForInfoDTO; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.SetShelfForProductDTO; |
| | | import com.panzhihua.common.exceptions.ServiceException; |
| | | import com.panzhihua.common.model.dtos.community.microCommercialStreet.*; |
| | | import com.panzhihua.common.model.vos.LoginReturnVO; |
| | | import com.panzhihua.common.model.vos.LoginUserInfoVO; |
| | | import com.panzhihua.common.model.vos.R; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.GameStatisticsVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.IndexTopStatisticsVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsConfigVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsCouponVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsEvaluateVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsGameVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsInformationVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsLabelVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsLoginUserInfoVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsMerchantVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsProductVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.McsVerifyRecordVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.MyCouponVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.TopStatisticsVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.VerifiedReturnVO; |
| | | import com.panzhihua.common.model.vos.community.microCommercialStreet.*; |
| | | import com.panzhihua.common.service.auth.TokenService; |
| | | import com.panzhihua.common.service.community.CommunityService; |
| | | import com.panzhihua.common.service.user.UserService; |
| | | import com.panzhihua.common.validated.AddGroup; |
| | | import com.panzhihua.common.validated.PutGroup; |
| | | import com.panzhihua.shop_backstage.aop.CheckMcsMerchantExpiration; |
| | | import com.panzhihua.shop_backstage.config.MyAESUtil; |
| | | import com.panzhihua.shop_backstage.config.WxMaConfiguration; |
| | | import com.panzhihua.shop_backstage.model.request.LoginRequest; |
| | | import com.panzhihua.shop_backstage.model.vos.LoginBody; |
| | | |
| | | import io.swagger.annotations.Api; |
| | | import io.swagger.annotations.ApiImplicitParam; |
| | | import io.swagger.annotations.ApiImplicitParams; |
| | | import io.swagger.annotations.ApiOperation; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.data.redis.core.RedisTemplate; |
| | | import org.springframework.util.ObjectUtils; |
| | | import org.springframework.validation.annotation.Validated; |
| | | import org.springframework.web.bind.annotation.*; |
| | | |
| | | import javax.annotation.Resource; |
| | | import javax.validation.Valid; |
| | | import java.time.Duration; |
| | | import java.util.regex.Pattern; |
| | | |
| | | import static java.util.Objects.isNull; |
| | | import static java.util.Objects.nonNull; |
| | | |
| | | /** |
| | | * @title: MicroCommercialStreetApi |
| | |
| | | @Slf4j |
| | | public class MicroCommercialStreetApi extends BaseController { |
| | | |
| | | private static String LOGIN_FAIL = "LOGIN_FAIL_"; |
| | | @Resource |
| | | private CommunityService communityService; |
| | | @Resource |
| | |
| | | private UserService userService; |
| | | @Resource |
| | | private WxMaConfiguration wxMaConfiguration; |
| | | @Resource |
| | | private RedisTemplate redisTemplate; |
| | | |
| | | @ApiOperation(value = "H5授权登录", response = LoginReturnVO.class) |
| | | @PostMapping("/auth/login") |
| | |
| | | @PostMapping("/merchant/login") |
| | | public R merchantLogin(@RequestBody @Valid LoginBody loginBody) { |
| | | String account = loginBody.getAccount(); |
| | | String password = loginBody.getPassword(); |
| | | log.info("登录用户信息【{}】", loginBody); |
| | | try { |
| | | password = MyAESUtil.Decrypt(loginBody.getPassword(), "Ryo7M3n8loC5Abcd"); |
| | | } catch (Exception e) { |
| | | return R.fail("账号或密码错误!"); |
| | | } |
| | | boolean flag = redisTemplate.hasKey(LOGIN_FAIL + account); |
| | | try { |
| | | R r = communityService.getMcsMerchantByAccount(account); |
| | | Boolean isValid = false; |
| | |
| | | McsMerchantVO merchantVO = JSONObject.parseObject(JSONObject.toJSONString(r.getData()), McsMerchantVO.class); |
| | | isValid = merchantVO.getAccountStatus() == 1; |
| | | if (isValid) { |
| | | R result = tokenService.loginMcsUser(account, loginBody.getPassword()); |
| | | if (flag) { |
| | | Integer time = (Integer) redisTemplate.opsForValue().get(LOGIN_FAIL + account); |
| | | if (time >= 5) { |
| | | redisTemplate.opsForValue().set(LOGIN_FAIL + account, 5, Duration.ofMinutes(5)); |
| | | throw new ServiceException("登录错误超过限制,请五分钟后重试"); |
| | | } |
| | | } |
| | | R result = tokenService.loginMcsUser(account, password); |
| | | return result; |
| | | } else { |
| | | return R.fail("账号被禁用"); |
| | |
| | | } |
| | | return R.fail(r.getMsg()); |
| | | } catch (Exception e) { |
| | | lockLogin(flag, account); |
| | | return R.fail("登陆失败了"); |
| | | } |
| | | } |
| | | |
| | | private void lockLogin(Boolean flag, String userName) { |
| | | if (flag) { |
| | | Integer time = (Integer) redisTemplate.opsForValue().get(LOGIN_FAIL + userName); |
| | | redisTemplate.opsForValue().set(LOGIN_FAIL + userName, time + 1, Duration.ofMinutes(5)); |
| | | } else { |
| | | redisTemplate.opsForValue().set(LOGIN_FAIL + userName, 1, Duration.ofMinutes(5)); |
| | | } |
| | | } |
| | | |
| | | @ApiOperation(value = "微商业街用户登录", response = LoginReturnVO.class) |
| | | @PostMapping("/loginWithPhone") |
| | | public R loginWithPhone(@RequestBody @Valid LoginWithPhoneDTO loginDTO) { |