apache shiro中SHA512使用salt并迭代N次进行加密对应C#的加密方法

项目需求:

     在java web项目中使用apache shiro来进行安全保护,并使用shiro提供的加密方法来对密码进行加密。

     在另外一个c#项目中,需要对接这个java web项目,并且验证的密码是shiro进行加密的。

     这个时候就需要对C#端的加密方式稍作修改,才能达到java和c#的加密结果的一致性

    注:如果shiro跟springmvc集成了,只需要在spring中配置好加密方式(例如sha,md5.....)以及迭代次数,shiro在认证的时候不需要写一下代码,以下代码只是用于特殊场景。


java代码:

     Sha512Hash encodedPassword = new Sha512Hash("123456", "itrider", 1024);//该类使用的是shiro的类,参数对应的是密码/盐值/迭代次数

     String result = encodedPassword.toBase64(); //得到的即加密后的结果


c#代码:

     string salt = "itrider";
     string password = "123456";
     byte[] saltPasswordValue = UTF8Encoding.UTF8.GetBytes(salt + password);
     // 计算哈希值
     SHA512 sha512 = SHA512.Create();
     saltPasswordValue  = sha512.ComputeHash(saltPasswordValue );

     for (int i = 0; i < 1023; i++)//因为上面计算了一次hash,所以只需要迭代1023次
     {
           saltPasswordValue = sha512.ComputeHash(saltPasswordValue );
     }
     string result = Convert.ToBase64String(saltPasswordValue );


最终两个输出结果是完全一致的~

其它加密方式应该也差不多,暂没时间测试




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值