⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 securerandom.java~

📁 KeePass for J2ME is a J2ME port of KeePass Password Safe, a free, open source, light-weight and easy
💻 JAVA~
字号:
//package java.security;package org.bouncycastle.crypto;import java.util.Random;import org.bouncycastle.crypto.digests.SHA1Digest;import org.bouncycastle.crypto.digests.SHA256Digest;import org.bouncycastle.crypto.prng.RandomGenerator;import org.bouncycastle.crypto.prng.DigestRandomGenerator;/** * An implementation of SecureRandom specifically for the light-weight API, JDK * 1.0, and the J2ME. Random generation is based on the traditional SHA1 with * counter. Calling setSeed will always increase the entropy of the hash. */public class SecureRandom extends java.util.Random{    private static SecureRandom rand    = new SecureRandom(new DigestRandomGenerator(new SHA1Digest()));    protected RandomGenerator             generator;    // public constructors    public SecureRandom()    {        super(0);        this.generator = new DigestRandomGenerator(new SHA1Digest());        setSeed(System.currentTimeMillis());    }    public SecureRandom(byte[] inSeed)    {        super(0);        this.generator = new DigestRandomGenerator(new SHA1Digest());        setSeed(inSeed);    }    protected SecureRandom(        RandomGenerator generator)    {        super(0);        this.generator = generator;    }    // protected constructors    // protected SecureRandom(SecureRandomSpi srs, Provider provider);    // public class methods    public static SecureRandom getInstance(String algorithm)    {        if (algorithm.equals("SHA1PRNG"))        {            return new SecureRandom(new DigestRandomGenerator(new SHA1Digest()));        }        if (algorithm.equals("SHA256PRNG"))        {            return new SecureRandom(new DigestRandomGenerator(new SHA256Digest()));        }        return new SecureRandom();    // follow old behaviour    }    public static SecureRandom getInstance(String algorithm, String provider)    {        return getInstance(algorithm);    }    public static byte[] getSeed(int numBytes)    {        byte[] rv = new byte[numBytes];        rand.setSeed(System.currentTimeMillis());        rand.nextBytes(rv);        return rv;    }    // public instance methods    public byte[] generateSeed(int numBytes)    {        byte[] rv = new byte[numBytes];        nextBytes(rv);        return rv;    }    // public final Provider getProvider();    public void setSeed(byte[] inSeed)    {        generator.addSeedMaterial(inSeed);    }    // public methods overriding random    public void nextBytes(byte[] bytes)    {        generator.nextBytes(bytes);    }    public void setSeed(long rSeed)    {        if (rSeed != 0)    // to avoid problems with Random calling setSeed in construction        {            generator.addSeedMaterial(rSeed);        }    }    public int nextInt()    {        byte[] intBytes = new byte[4];        nextBytes(intBytes);        int result = 0;        for (int i = 0; i < 4; i++)        {            result = (result << 8) + (intBytes[i] & 0xff);        }        return result;    }    protected final int next(int numBits)    {        int size = (numBits + 7) / 8;        byte[] bytes = new byte[size];        nextBytes(bytes);        int result = 0;        for (int i = 0; i < size; i++)        {            result = (result << 8) + (bytes[i] & 0xff);        }        return result & ((1 << numBits) - 1);    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -