fortify测试前端js 不能使用Math.random()的问题

在使用Fortify进行前端JavaScript代码扫描时遇到了Insecure Randomness错误,原因是Math.random()被认为存在漏洞。为了解决这个问题,文章提供了一个自定义的随机数生成函数,用以替代Math.random()。通过引入新的随机数生成算法,实现了安全的随机数生成,并将此函数应用到实际的代码中,成功解决了Fortify扫描的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

fortify扫描前端源代码,报Insecure Randomness错误,如何解决呢?

说是Math.random()有漏洞,不知道是个什么鬼,但是不解决就过不去。测试那边也是死板的要命,没办法,只能自己写一个随机数函数了。

在网上查了一下,以下代码有效:

<html>
<head>
<script>
    
    
    rnd.today=new Date();
    rnd.seed=rnd.today.getTime();
    function rnd() {
     rnd.seed = (rnd.seed*9301+49297) % 233280;
     return rnd.seed/(233280.0);
    };
    function rand(number) {
     return Math.ceil(rnd()*number);
    };
    function doooo(){
        alert("1111");
        alert(rnd());
        
        var item=rand(100

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阳光正好2024

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值