SecureRandom 在Linux 环境下线程阻塞问题

项目中遇到一个问题,排查了一天,终于知道原因了。

环境介绍:本地 windos,正式 linux

用Random生成随机数,然后扫描软件说不安全,不推荐用,推荐用SecureRandom,然后改成这样。

Random rand = SecureRandom.getInstanceStrong();
int i2 = rand.nextInt(i);

改完之后测试本地没有问题,发布,然后正式调用这个方法的页面,死活保存不了,后台也不报错。用最笨的方法每行代码下面打印一句话的方法,发现是随机数的问题。

然后搜了之后发现,说是SecureRandom在Linux环境容易线程阻塞。

解决 办法:我们先改回Random了。

网上提供了三种解决办法:

1.获取SecureRandom 实例时指定SHA1PRNG算法:

SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");

2.启动命令加上参数:

-Djava.security.egd=file:/dev/urandom 

3.使用org.apache.commons.lang3包的RandomStringUtils

等我们试过之后,我再更新。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值