学习笔记之加密

在项目接触中,经常用的两种加密方式,UUID和MD5,在这里做些记录方便以后的参考使用。

加密的方式有很多,同样解密的方式也有很多,没有绝对安全。

第一种:Shiro框架+UUID

关于shiro框架的使用可参考:shiro框架使用的学习笔记

public int saveOrUpdateRole(SysUser sysUser,Integer... roleIds) {
        if (sysUser == null){
            throw new ServiceException("更新保存用户不能为空");
        }
        if (StringUtils.isEmpty(sysUser.getUsername())){
            throw new ServiceException("用户用户名不能为空");
        }
        if (roleIds == null || roleIds.length <= 0){
            throw new ServiceException("必须为用户分配角色");
        }
        sysUser.setCreatedUser("admin");
        sysUser.setModifiedUser("admin");
        int row ;
        if (sysUser.getId() == null){
            if (StringUtils.isEmpty(sysUser.getPassword())){
                throw new ServiceException("用户密码不能为空");
            }
            //利用shiro框架,UUID进行加密
            //利用UUID生成盐值
            String salt = UUID.randomUUID().toString();
            //利用shiro框架的SimpleHash生成密码
            SimpleHash password = new SimpleHash("MD5",sysUser.getPassword(),salt);
            //将密码转化16进制进行保存
            sysUser.setPassword(password.toHex());
            sysUser.setSalt(salt);
            row = sysUserDao.saveSysUser(sysUser);
            sysUser = sysUserDao.findUserByUserName(sysUser.getUsername());
            sysRoleDao.saveRoleIdAndUserId(sysUser.getId(),roleIds);
            log.debug("保存用户成功");
        }else{
           /* UserDeptVo userDo = sysUserDao.findUserById(sysUser.getDeptId());
            sysUser.setSalt(userDo.getSalt());
            //将页面输入密码进行加密同数据库密码进行比较,判断密码是否匹配
            if(StringUtils.equals(new SimpleHash("MD5",sysUser.getPassword(),sysUser.getSalt()).toHex(),userDo.getPassword())){
                throw new ServiceException("用户密码不匹配,请核实");
            }*/
            row = sysUserDao.updateSysUserById(sysUser);
            sysRoleDao.deleteRoleIdByUserId(sysUser.getId());
            sysRoleDao.saveRoleIdAndUserId(sysUser.getId(),roleIds);
            System.out.print(sysUser.getId());
        }
        return row;
    }

第二种:MD5

@Override
    public int saveUser(User user) {
        //对密码进行加密 利用digestUtils工具类进行加密
        String password = DigestUtils.md5DigestAsHex(user.getPassword().getBytes());
        user.setEmail(user.getPhone())
                .setPassword(password)
                .setCreated(new Date())
                .setUpdated(user.getCreated());
        int row = userDao.insert(user);
        return row;
    }

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值