package com.alatus.mall.member.controller;
import java.util.Arrays;
import java.util.Map;
import com.alatus.mall.member.vo.MemberRegisterVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import com.alatus.mall.member.entity.MemberEntity;
import com.alatus.mall.member.service.MemberService;
import com.alatus.common.utils.PageUtils;
import com.alatus.common.utils.R;
/**
* 会员
*
* @author alatus
* @email 1571345941@qq.com
* @date 2024-03-12 13:40:22
*/
@RestController
@RequestMapping("member/member")
public class MemberController {
@Autowired
private MemberService memberService;
@PostMapping("register")
public R register(@RequestBody MemberRegisterVo memberRegisterVo){
try{
memberService.register(memberRegisterVo);
}
catch (Exception e){
}
return R.ok();
}
/**
* 列表
*/
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params){
PageUtils page = memberService.queryPage(params);
return R.ok().put("page", page);
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
MemberEntity member = memberService.getById(id);
return R.ok().put("member", member);
}
/**
* 保存
*/
@RequestMapping("/save")
public R save(@RequestBody MemberEntity member){
memberService.save(member);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody MemberEntity member){
memberService.updateById(member);
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
memberService.removeByIds(Arrays.asList(ids));
return R.ok();
}
}
package com.alatus.mall.member.controller;
import java.util.Arrays;
import java.util.Map;
import com.alatus.mall.member.vo.MemberRegisterVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import com.alatus.mall.member.entity.MemberEntity;
import com.alatus.mall.member.service.MemberService;
import com.alatus.common.utils.PageUtils;
import com.alatus.common.utils.R;
/**
* 会员
*
* @author alatus
* @email 1571345941@qq.com
* @date 2024-03-12 13:40:22
*/
@RestController
@RequestMapping("member/member")
public class MemberController {
@Autowired
private MemberService memberService;
@PostMapping("register")
public R register(@RequestBody MemberRegisterVo memberRegisterVo){
try{
memberService.register(memberRegisterVo);
}
catch (Exception e){
}
return R.ok();
}
/**
* 列表
*/
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params){
PageUtils page = memberService.queryPage(params);
return R.ok().put("page", page);
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
MemberEntity member = memberService.getById(id);
return R.ok().put("member", member);
}
/**
* 保存
*/
@RequestMapping("/save")
public R save(@RequestBody MemberEntity member){
memberService.save(member);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody MemberEntity member){
memberService.updateById(member);
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
memberService.removeByIds(Arrays.asList(ids));
return R.ok();
}
}
package com.alatus.mall.auth.app;
import com.alatus.common.constant.AuthServerConstant;
import com.alatus.common.exception.BizCodeEnum;
import com.alatus.common.utils.R;
import com.alatus.mall.auth.feign.ThirdPartFeignService;
import com.alatus.mall.auth.vo.UserRegisterVo;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
import javax.validation.Valid;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
import java.util.concurrent.TimeUnit;
import java.util.stream.Collectors;
@Controller
public class LoginController {
@Autowired
private ThirdPartFeignService thirdPartFeignService;
@Autowired
private StringRedisTemplate redisTemplate;
@GetMapping("/sms/sendCode")
@ResponseBody
public R sendCode(@RequestParam("phone") String phone){
// TODO 接口防刷
// 防止反复刷验证码
String value = redisTemplate.opsForValue().get(AuthServerConstant.SMS_CODE_CACHE_PREFIX + phone);
if(value!=null&&!StringUtils.isEmpty(value)){
long time = Long.parseLong(value.split("_")[1]);
if(System.currentTimeMillis() - time < 60000){
// 60秒内不能再发
return R.error(BizCodeEnum.SMS_CODE_EXCEPTION.getCode(),BizCodeEnum.SMS_CODE_EXCEPTION.getMsg());
}
}
String code = UUID.randomUUID().toString().substring(0, 5);
R sendCode = thirdPartFeignService.sendCode(phone, code);
// 缓存验证码
redisTemplate.opsForValue().set(AuthServerConstant.SMS_CODE_CACHE_PREFIX+phone,code+"_"+System.currentTimeMillis(),10, TimeUnit.MINUTES);
if(sendCode.getCode()==0){
return R.ok();
}
else{
return R.error();
}
}
//RedirectAttributes redirectAttributes模拟重定向携带数据
// TODO 重定向携带数据,利用session原理,将数据放在session中
// 只要跳到下一个页面取出这个数据后,session的数据就被删掉了
// TODO 分布式Session问题解决!!!
@PostMapping("/register")
public String register(@Valid UserRegisterVo vo, BindingResult result, RedirectAttributes redirectAttributes){
if(result.hasErrors()){
// 收集错误信息返回
Map<String, String> collect = result.getFieldErrors().stream().collect(Collectors.toMap(FieldError::getField,FieldError::getDefaultMessage));
redirectAttributes.addFlashAttribute("errors",collect);
// 原请求是post请求,当我们失败以后,在这里转发,转发是会保持请求方式不变的,但是路径访问默认是get
// 就会出现错误
// 原理是使用了HttpSession的底层实现
return "redirect:http://auth.alatusmall.com/reg.html";
}
else{
// 校验验证码
String code = vo.getCode();
String codeValue = redisTemplate.opsForValue().get(AuthServerConstant.SMS_CODE_CACHE_PREFIX + vo.getPhone());
if(codeValue!=null&&!StringUtils.isEmpty(codeValue)){
// 截串获取验证码信息
String redisCode = codeValue.split("_")[0];
if(redisCode.equals(code)){
// 验证码通过以后,删除验证码,令牌机制,验证码用过就不再可用了
redisTemplate.delete(AuthServerConstant.SMS_CODE_CACHE_PREFIX + vo.getPhone());
// 调用远程服务进行注册
}
else{
// 验证码错误
return CodeError(redirectAttributes);
}
}
else{
// 没有验证码
return CodeError(redirectAttributes);
}
return "login";
}
}
private String CodeError(RedirectAttributes redirectAttributes){
Map<String,String> errors = new HashMap<>();
errors.put("code","验证码错误");
redirectAttributes.addFlashAttribute("errors",errors);
return "redirect:http://auth.alatusmall.com/reg.html";
}
}
package com.alatus.mall.auth.app;
import com.alatus.common.constant.AuthServerConstant;
import com.alatus.common.exception.BizCodeEnum;
import com.alatus.common.utils.R;
import com.alatus.mall.auth.feign.ThirdPartFeignService;
import com.alatus.mall.auth.vo.UserRegisterVo;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.validation.FieldError;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
import javax.validation.Valid;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
import java.util.concurrent.TimeUnit;
import java.util.stream.Collectors;
@Controller
public class LoginController {
@Autowired
private ThirdPartFeignService thirdPartFeignService;
@Autowired
private StringRedisTemplate redisTemplate;
@GetMapping("/sms/sendCode")
@ResponseBody
public R sendCode(@RequestParam("phone") String phone){
// TODO 接口防刷
// 防止反复刷验证码
String value = redisTemplate.opsForValue().get(AuthServerConstant.SMS_CODE_CACHE_PREFIX + phone);
if(value!=null&&!StringUtils.isEmpty(value)){
long time = Long.parseLong(value.split("_")[1]);
if(System.currentTimeMillis() - time < 60000){
// 60秒内不能再发
return R.error(BizCodeEnum.SMS_CODE_EXCEPTION.getCode(),BizCodeEnum.SMS_CODE_EXCEPTION.getMsg());
}
}
String code = UUID.randomUUID().toString().substring(0, 5);
R sendCode = thirdPartFeignService.sendCode(phone, code);
// 缓存验证码
redisTemplate.opsForValue().set(AuthServerConstant.SMS_CODE_CACHE_PREFIX+phone,code+"_"+System.currentTimeMillis(),10, TimeUnit.MINUTES);
if(sendCode.getCode()==0){
return R.ok();
}
else{
return R.error();
}
}
//RedirectAttributes redirectAttributes模拟重定向携带数据
// TODO 重定向携带数据,利用session原理,将数据放在session中
// 只要跳到下一个页面取出这个数据后,session的数据就被删掉了
// TODO 分布式Session问题解决!!!
@PostMapping("/register")
public String register(@Valid UserRegisterVo vo, BindingResult result, RedirectAttributes redirectAttributes){
if(result.hasErrors()){
// 收集错误信息返回
Map<String, String> collect = result.getFieldErrors().stream().collect(Collectors.toMap(FieldError::getField,FieldError::getDefaultMessage));
redirectAttributes.addFlashAttribute("errors",collect);
// 原请求是post请求,当我们失败以后,在这里转发,转发是会保持请求方式不变的,但是路径访问默认是get
// 就会出现错误
// 原理是使用了HttpSession的底层实现
return "redirect:http://auth.alatusmall.com/reg.html";
}
else{
// 校验验证码
String code = vo.getCode();
String codeValue = redisTemplate.opsForValue().get(AuthServerConstant.SMS_CODE_CACHE_PREFIX + vo.getPhone());
if(codeValue!=null&&!StringUtils.isEmpty(codeValue)){
// 截串获取验证码信息
String redisCode = codeValue.split("_")[0];
if(redisCode.equals(code)){
// 验证码通过以后,删除验证码,令牌机制,验证码用过就不再可用了
redisTemplate.delete(AuthServerConstant.SMS_CODE_CACHE_PREFIX + vo.getPhone());
// 调用远程服务进行注册
}
else{
// 验证码错误
return CodeError(redirectAttributes);
}
}
else{
// 没有验证码
return CodeError(redirectAttributes);
}
return "login";
}
}
private String CodeError(RedirectAttributes redirectAttributes){
Map<String,String> errors = new HashMap<>();
errors.put("code","验证码错误");
redirectAttributes.addFlashAttribute("errors",errors);
return "redirect:http://auth.alatusmall.com/reg.html";
}
}
package com.alatus.mall.member.service;
import com.alatus.mall.member.exception.PhoneExistException;
import com.alatus.mall.member.exception.UsernameExistException;
import com.alatus.mall.member.vo.MemberRegisterVo;
import com.baomidou.mybatisplus.extension.service.IService;
import com.alatus.common.utils.PageUtils;
import com.alatus.mall.member.entity.MemberEntity;
import java.util.Map;
/**
* 会员
*
* @author alatus
* @email 1571345941@qq.com
* @date 2024-03-12 13:40:22
*/
public interface MemberService extends IService<MemberEntity> {
PageUtils queryPage(Map<String, Object> params);
void register(MemberRegisterVo memberRegisterVo);
void checkPhoneUnique(String phone) throws PhoneExistException;
void checkUsernameUnique(String username) throws UsernameExistException;
}
package com.alatus.mall.member.service;
import com.alatus.mall.member.exception.PhoneExistException;
import com.alatus.mall.member.exception.UsernameExistException;
import com.alatus.mall.member.vo.MemberRegisterVo;
import com.baomidou.mybatisplus.extension.service.IService;
import com.alatus.common.utils.PageUtils;
import com.alatus.mall.member.entity.MemberEntity;
import java.util.Map;
/**
* 会员
*
* @author alatus
* @email 1571345941@qq.com
* @date 2024-03-12 13:40:22
*/
public interface MemberService extends IService<MemberEntity> {
PageUtils queryPage(Map<String, Object> params);
void register(MemberRegisterVo memberRegisterVo);
void checkPhoneUnique(String phone) throws PhoneExistException;
void checkUsernameUnique(String username) throws UsernameExistException;
}
package com.alatus.mall.member.service.impl;
import com.alatus.mall.member.entity.MemberLevelEntity;
import com.alatus.mall.member.exception.PhoneExistException;
import com.alatus.mall.member.exception.UsernameExistException;
import com.alatus.mall.member.service.MemberLevelService;
import com.alatus.mall.member.vo.MemberRegisterVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.Map;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.alatus.common.utils.PageUtils;
import com.alatus.common.utils.Query;
import com.alatus.mall.member.dao.MemberDao;
import com.alatus.mall.member.entity.MemberEntity;
import com.alatus.mall.member.service.MemberService;
@Service("memberService")
public class MemberServiceImpl extends ServiceImpl<MemberDao, MemberEntity> implements MemberService {
@Autowired
private MemberLevelService memberLevelService;
@Override
public PageUtils queryPage(Map<String, Object> params) {
IPage<MemberEntity> page = this.page(
new Query<MemberEntity>().getPage(params),
new QueryWrapper<MemberEntity>()
);
return new PageUtils(page);
}
@Override
public void register(MemberRegisterVo memberRegisterVo) {
MemberEntity memberEntity = new MemberEntity();
// 设置默认等级
MemberLevelEntity memberLevelEntity = memberLevelService.getDefaultLevel();
memberEntity.setLevelId(memberLevelEntity.getId());
// 密码
memberEntity.setPassword(memberRegisterVo.getPassword());
// 检查用户名和手机号是否唯一(为了能让上层感知异常,我们这里抛出去)采用异常机制
checkPhoneUnique(memberRegisterVo.getPhone());
checkUsernameUnique(memberRegisterVo.getUsername());
// 用户名
memberEntity.setUsername(memberRegisterVo.getUsername());
// 手机号
memberEntity.setMobile(memberRegisterVo.getPhone());
}
@Override
public void checkPhoneUnique(String phone) throws PhoneExistException{
Integer count = this.baseMapper.selectCount(new QueryWrapper<MemberEntity>().eq("mobile", phone));
if(count>0){
throw new PhoneExistException();
}
}
@Override
public void checkUsernameUnique(String username) throws UsernameExistException{
Integer count = this.baseMapper.selectCount(new QueryWrapper<MemberEntity>().eq("username", username));
if(count>0){
throw new UsernameExistException();
}
}
}
package com.alatus.mall.member.service.impl;
import com.alatus.mall.member.entity.MemberLevelEntity;
import com.alatus.mall.member.exception.PhoneExistException;
import com.alatus.mall.member.exception.UsernameExistException;
import com.alatus.mall.member.service.MemberLevelService;
import com.alatus.mall.member.vo.MemberRegisterVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.Map;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.alatus.common.utils.PageUtils;
import com.alatus.common.utils.Query;
import com.alatus.mall.member.dao.MemberDao;
import com.alatus.mall.member.entity.MemberEntity;
import com.alatus.mall.member.service.MemberService;
@Service("memberService")
public class MemberServiceImpl extends ServiceImpl<MemberDao, MemberEntity> implements MemberService {
@Autowired
private MemberLevelService memberLevelService;
@Override
public PageUtils queryPage(Map<String, Object> params) {
IPage<MemberEntity> page = this.page(
new Query<MemberEntity>().getPage(params),
new QueryWrapper<MemberEntity>()
);
return new PageUtils(page);
}
@Override
public void register(MemberRegisterVo memberRegisterVo) {
MemberEntity memberEntity = new MemberEntity();
// 设置默认等级
MemberLevelEntity memberLevelEntity = memberLevelService.getDefaultLevel();
memberEntity.setLevelId(memberLevelEntity.getId());
// 密码
memberEntity.setPassword(memberRegisterVo.getPassword());
// 检查用户名和手机号是否唯一(为了能让上层感知异常,我们这里抛出去)采用异常机制
checkPhoneUnique(memberRegisterVo.getPhone());
checkUsernameUnique(memberRegisterVo.getUsername());
// 用户名
memberEntity.setUsername(memberRegisterVo.getUsername());
// 手机号
memberEntity.setMobile(memberRegisterVo.getPhone());
}
@Override
public void checkPhoneUnique(String phone) throws PhoneExistException{
Integer count = this.baseMapper.selectCount(new QueryWrapper<MemberEntity>().eq("mobile", phone));
if(count>0){
throw new PhoneExistException();
}
}
@Override
public void checkUsernameUnique(String username) throws UsernameExistException{
Integer count = this.baseMapper.selectCount(new QueryWrapper<MemberEntity>().eq("username", username));
if(count>0){
throw new UsernameExistException();
}
}
}
package com.alatus.mall.member.exception;
public class UsernameExistException extends RuntimeException{
public UsernameExistException() {
super("用户名已存在");
}
}
package com.alatus.mall.member.exception;
public class UsernameExistException extends RuntimeException{
public UsernameExistException() {
super("用户名已存在");
}
}
package com.alatus.mall.member.exception;
public class PhoneExistException extends RuntimeException{
public PhoneExistException() {
super("手机号已被使用");
}
}
package com.alatus.mall.member.exception;
public class PhoneExistException extends RuntimeException{
public PhoneExistException() {
super("手机号已被使用");
}
}
package com.alatus.mall.member.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.alatus.common.utils.PageUtils;
import com.alatus.mall.member.entity.MemberLevelEntity;
import java.util.Map;
/**
* 会员等级
*
* @author alatus
* @email 1571345941@qq.com
* @date 2024-03-12 13:40:22
*/
public interface MemberLevelService extends IService<MemberLevelEntity> {
PageUtils queryPage(Map<String, Object> params);
MemberLevelEntity getDefaultLevel();
}
package com.alatus.mall.member.service;
import com.baomidou.mybatisplus.extension.service.IService;
import com.alatus.common.utils.PageUtils;
import com.alatus.mall.member.entity.MemberLevelEntity;
import java.util.Map;
/**
* 会员等级
*
* @author alatus
* @email 1571345941@qq.com
* @date 2024-03-12 13:40:22
*/
public interface MemberLevelService extends IService<MemberLevelEntity> {
PageUtils queryPage(Map<String, Object> params);
MemberLevelEntity getDefaultLevel();
}
package com.alatus.mall.member.service.impl;
import org.springframework.stereotype.Service;
import java.util.Map;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.alatus.common.utils.PageUtils;
import com.alatus.common.utils.Query;
import com.alatus.mall.member.dao.MemberLevelDao;
import com.alatus.mall.member.entity.MemberLevelEntity;
import com.alatus.mall.member.service.MemberLevelService;
@Service("memberLevelService")
public class MemberLevelServiceImpl extends ServiceImpl<MemberLevelDao, MemberLevelEntity> implements MemberLevelService {
@Override
public PageUtils queryPage(Map<String, Object> params) {
IPage<MemberLevelEntity> page = this.page(
new Query<MemberLevelEntity>().getPage(params),
new QueryWrapper<MemberLevelEntity>()
);
return new PageUtils(page);
}
@Override
public MemberLevelEntity getDefaultLevel() {
return this.getOne(new QueryWrapper<MemberLevelEntity>().eq("default_status", 1));
}
}
package com.alatus.mall.member.service.impl;
import org.springframework.stereotype.Service;
import java.util.Map;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.alatus.common.utils.PageUtils;
import com.alatus.common.utils.Query;
import com.alatus.mall.member.dao.MemberLevelDao;
import com.alatus.mall.member.entity.MemberLevelEntity;
import com.alatus.mall.member.service.MemberLevelService;
@Service("memberLevelService")
public class MemberLevelServiceImpl extends ServiceImpl<MemberLevelDao, MemberLevelEntity> implements MemberLevelService {
@Override
public PageUtils queryPage(Map<String, Object> params) {
IPage<MemberLevelEntity> page = this.page(
new Query<MemberLevelEntity>().getPage(params),
new QueryWrapper<MemberLevelEntity>()
);
return new PageUtils(page);
}
@Override
public MemberLevelEntity getDefaultLevel() {
return this.getOne(new QueryWrapper<MemberLevelEntity>().eq("default_status", 1));
}
}
package com.alatus.mall.member.vo;
import lombok.Data;
@Data
public class MemberRegisterVo {
private String username;
private String password;
private String phone;
}
package com.alatus.mall.member.vo;
import lombok.Data;
@Data
public class MemberRegisterVo {
private String username;
private String password;
private String phone;
}