zoukankan      html  css  js  c++  java
  • 登录和注册功能的实现

    1.引入关键依赖

     <!-- redis -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-redis</artifactId>
            </dependency>
    
            <!-- spring2.X集成redis所需common-pool2-->
            <dependency>
                <groupId>org.apache.commons</groupId>
                <artifactId>commons-pool2</artifactId>
                <version>2.6.0</version>
            </dependency>
    
            <!-- JWT-->
            <dependency>
                <groupId>io.jsonwebtoken</groupId>
                <artifactId>jjwt</artifactId>
            </dependency>

    2.jwt .md5 redis工具类

    public class JwtUtils {
    
        //常量
        public static final long EXPIRE = 1000 * 60 * 60 * 24; //token过期时间
        public static final String APP_SECRET = "ukc8BDbRigUDaY6pZFfWus2jZWLPHO"; //秘钥
    
        //生成token字符串的方法
        public static String getJwtToken(String id, String nickname){
    
            String JwtToken = Jwts.builder()
                    .setHeaderParam("typ", "JWT")
                    .setHeaderParam("alg", "HS256")
    
                    .setSubject("guli-user")
                    .setIssuedAt(new Date())
                    .setExpiration(new Date(System.currentTimeMillis() + EXPIRE))
    
                    .claim("id", id)  //设置token主体部分 ,存储用户信息
                    .claim("nickname", nickname)
    
                    .signWith(SignatureAlgorithm.HS256, APP_SECRET)
                    .compact();
    
            return JwtToken;
        }
    
        /**
         * 判断token是否存在与有效
         * @param jwtToken
         * @return
         */
        public static boolean checkToken(String jwtToken) {
            if(StringUtils.isEmpty(jwtToken)) return false;
            try {
                Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
            } catch (Exception e) {
                e.printStackTrace();
                return false;
            }
            return true;
        }
    
        /**
         * 判断token是否存在与有效
         * @param request
         * @return
         */
        public static boolean checkToken(HttpServletRequest request) {
            try {
                String jwtToken = request.getHeader("token");
                if(StringUtils.isEmpty(jwtToken)) return false;
                Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
            } catch (Exception e) {
                e.printStackTrace();
                return false;
            }
            return true;
        }
    
        /**
         * 根据token字符串获取会员id
         * @param request
         * @return
         */
        public static String getMemberIdByJwtToken(HttpServletRequest request) {
            String jwtToken = request.getHeader("token");
            if(StringUtils.isEmpty(jwtToken)) return "";
            Jws<Claims> claimsJws = Jwts.parser().setSigningKey(APP_SECRET).parseClaimsJws(jwtToken);
            Claims claims = claimsJws.getBody();
            return (String)claims.get("id");
        }
    }
    public final class MD5 {
    
        public static String encrypt(String strSrc) {
            try {
                char hexChars[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8',
                        '9', 'a', 'b', 'c', 'd', 'e', 'f' };
                byte[] bytes = strSrc.getBytes();
                MessageDigest md = MessageDigest.getInstance("MD5");
                md.update(bytes);
                bytes = md.digest();
                int j = bytes.length;
                char[] chars = new char[j * 2];
                int k = 0;
                for (int i = 0; i < bytes.length; i++) {
                    byte b = bytes[i];
                    chars[k++] = hexChars[b >>> 4 & 0xf];
                    chars[k++] = hexChars[b & 0xf];
                }
                return new String(chars);
            } catch (NoSuchAlgorithmException e) {
                e.printStackTrace();
                throw new RuntimeException("MD5加密出错!!+" + e);
            }
        }
    
        public static void main(String[] args) {
            System.out.println(MD5.encrypt("111111"));
        }
    
    }
    @EnableCaching //开启缓存
    @Configuration  //配置类
    public class RedisConfig extends CachingConfigurerSupport {
    
        @Bean
        public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
            RedisTemplate<String, Object> template = new RedisTemplate<>();
            RedisSerializer<String> redisSerializer = new StringRedisSerializer();
            Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
            ObjectMapper om = new ObjectMapper();
            om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
            om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
            jackson2JsonRedisSerializer.setObjectMapper(om);
            template.setConnectionFactory(factory);
            //key序列化方式
            template.setKeySerializer(redisSerializer);
            //value序列化
            template.setValueSerializer(jackson2JsonRedisSerializer);
            //value hashmap序列化
            template.setHashValueSerializer(jackson2JsonRedisSerializer);
            return template;
        }
    
        @Bean
        public CacheManager cacheManager(RedisConnectionFactory factory) {
            RedisSerializer<String> redisSerializer = new StringRedisSerializer();
            Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
            //解决查询缓存转换异常的问题
            ObjectMapper om = new ObjectMapper();
            om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
            om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
            jackson2JsonRedisSerializer.setObjectMapper(om);
            // 配置序列化(解决乱码的问题),过期时间600秒
            RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                    .entryTtl(Duration.ofSeconds(600))
                    .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                    .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer))
                    .disableCachingNullValues();
            RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                    .cacheDefaults(config)
                    .build();
            return cacheManager;
        }
    }

    3.controller层

    @RestController
    @RequestMapping("/educenter/member")
    @CrossOrigin
    public class UcenterMemberController {
    
        @Autowired
        private UcenterMemberService memberService;
    
        //登录
        @PostMapping("login")
        public R loginUser(@RequestBody UcenterMember member) {
            //member对象封装手机号和密码
            //调用service方法实现登录
            //返回token值,使用jwt生成
            String token = memberService.login(member);
            return R.ok().data("token",token);
        }
    
        //注册
        @PostMapping("register")
        public R registerUser(@RequestBody RegisterVo registerVo) {
            memberService.register(registerVo);
            return R.ok();
        }
    
        //根据token获取用户信息
        @GetMapping("getMemberInfo")
        public R getMemberInfo(HttpServletRequest request) {
            //调用jwt工具类的方法。根据request对象获取头信息,返回用户id
            String memberId = JwtUtils.getMemberIdByJwtToken(request);
            //查询数据库根据用户id获取用户信息
            UcenterMember member = memberService.getById(memberId);
            return R.ok().data("userInfo",member);
        }
    
    }

    4.service层

    @Service
    public class UcenterMemberServiceImpl extends ServiceImpl<UcenterMemberMapper, UcenterMember> implements UcenterMemberService {
        @Autowired
        private RedisTemplate<String,String> redisTemplate;
        //登录的方法
        @Override
        public String login(UcenterMember member) {
            //获取登录手机号和密码
            String mobile = member.getMobile();
            String password = member.getPassword();
    
            //手机号和密码非空判断
            if(StringUtils.isEmpty(mobile) || StringUtils.isEmpty(password)) {
                throw new GuliException(20001,"登录失败");
            }
    
            //判断手机号是否正确
            QueryWrapper<UcenterMember> wrapper = new QueryWrapper<>();
            wrapper.eq("mobile",mobile);
            UcenterMember mobileMember = baseMapper.selectOne(wrapper);
            //判断查询对象是否为空
            if(mobileMember == null) {//没有这个手机号
                throw new GuliException(20001,"登录失败");
            }
    
            //判断密码
            //因为存储到数据库密码肯定加密的
            //把输入的密码进行加密,再和数据库密码进行比较
            //加密方式 MD5
            if(!MD5.encrypt(password).equals(mobileMember.getPassword())) {
                throw new GuliException(20001,"登录失败");
            }
    
            //判断用户是否禁用
            if(mobileMember.getIsDisabled()) {
                throw new GuliException(20001,"登录失败");
            }
    
            //登录成功
            //生成token字符串,使用jwt工具类
            String jwtToken = JwtUtils.getJwtToken(mobileMember.getId(), mobileMember.getNickname());
            return jwtToken;
        }
    
        //注册的方法
        @Override
        public void register(RegisterVo registerVo) {
            //获取注册的数据
            String code = registerVo.getCode(); //验证码
            String mobile = registerVo.getMobile(); //手机号
            String nickname = registerVo.getNickname(); //昵称
            String password = registerVo.getPassword(); //密码
    
            //非空判断
            if(StringUtils.isEmpty(mobile) || StringUtils.isEmpty(password)
                    || StringUtils.isEmpty(code) || StringUtils.isEmpty(nickname)) {
                throw new GuliException(20001,"注册失败");
            }
            //判断验证码
            //获取redis验证码
            String redisCode = redisTemplate.opsForValue().get(mobile);
            if(!code.equals(redisCode)) {
                throw new GuliException(20001,"注册失败");
            }
    
            //判断手机号是否重复,表里面存在相同手机号不进行添加
            QueryWrapper<UcenterMember> wrapper = new QueryWrapper<>();
            wrapper.eq("mobile",mobile);
            Integer count = baseMapper.selectCount(wrapper);
            if(count > 0) {
                throw new GuliException(20001,"注册失败");
            }
    
            //数据添加数据库中
            UcenterMember member = new UcenterMember();
            member.setMobile(mobile);
            member.setNickname(nickname);
            member.setPassword(MD5.encrypt(password));//密码需要加密的
            member.setIsDisabled(false);//用户不禁用
            member.setAvatar("http://thirdwx.");
            baseMapper.insert(member);
        }
    }

    5.vo类

    @Data
    public class RegisterVo {
        @ApiModelProperty(value = "昵称")
        private String nickname;
        @ApiModelProperty(value = "手机号")
        private String mobile;
        @ApiModelProperty(value = "密码")
        private String password;
        @ApiModelProperty(value = "验证码")
        private String code;
    }
  • 相关阅读:
    poj2096(概率dp)
    bzoj4318/洛谷P1654OSU!(期望dp,立方版本)
    hdu1027(逆康托展开)
    hdu3734(数位dp,相减抵消影响)
    hdu2089(数位dp模版)
    hdu2856(倍增lca模版题)
    COI2007 Patrik 音乐会的等待 洛谷P1823
    校门外的树2 contest 树状数组练习 T4
    数星星 contest 树状数组练习 T2
    A simple problem with integer 树状数组区间查询模板题 contest 树状数组练习 T1
  • 原文地址:https://www.cnblogs.com/liuyi13535496566/p/12846646.html
Copyright © 2011-2022 走看看