Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
JDK 17 jdk.crypto.cryptoki.jmod - Crypto KI Module
JDK 17 jdk.crypto.cryptoki.jmod is the JMOD file for JDK 17 Crypto Cryptoki module.
JDK 17 Crypto KI module compiled class files are stored in \fyicenter\jdk-17.0.5\jmods\jdk.crypto.cryptoki.jmod.
JDK 17 Crypto KI module compiled class files are also linked and stored in the \fyicenter\jdk-17.0.5\lib\modules JImage file.
JDK 17 Crypto KI module source code files are stored in \fyicenter\jdk-17.0.5\lib\src.zip\jdk.crypto.cryptoki.
You can click and view the content of each source code file in the list below.
✍: FYIcenter
⏎ sun/security/pkcs11/P11SecureRandom.java
/* * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package sun.security.pkcs11; import java.io.*; import java.security.*; import sun.security.pkcs11.wrapper.*; /** * SecureRandom implementation class. Some tokens support only * C_GenerateRandom() and not C_SeedRandom(). In order not to lose an * application specified seed, we create a SHA1PRNG that we mix with in that * case. * * Note that since SecureRandom is thread safe, we only need one * instance per PKCS#11 token instance. It is created on demand and cached * in the SunPKCS11 class. * * Also note that we obtain the PKCS#11 session on demand, no need to tie one * up. * * @author Andreas Sterbenz * @since 1.5 */ final class P11SecureRandom extends SecureRandomSpi { private static final long serialVersionUID = -8939510236124553291L; // token instance private final Token token; // PRNG for mixing, non-null if active (i.e. setSeed() has been called) private volatile SecureRandom mixRandom; // buffer, if mixing is used private byte[] mixBuffer; // bytes remaining in mixBuffer, if mixing is used private int buffered; /* * we buffer data internally for efficiency but limit the lifetime * to avoid using stale bits. */ // lifetime in ms, currently 100 ms (0.1 s) private static final long MAX_IBUFFER_TIME = 100; // size of the internal buffer private static final int IBUFFER_SIZE = 32; // internal buffer for the random bits private transient byte[] iBuffer = new byte[IBUFFER_SIZE]; // number of bytes remain in iBuffer private transient int ibuffered = 0; // time that data was read into iBuffer private transient long lastRead = 0L; P11SecureRandom(Token token) { this.token = token; } // see JCA spec @Override protected synchronized void engineSetSeed(byte[] seed) { if (seed == null) { throw new NullPointerException("seed must not be null"); } Session session = null; try { session = token.getOpSession(); token.p11.C_SeedRandom(session.id(), seed); } catch (PKCS11Exception e) { // cannot set seed // let a SHA1PRNG use that seed instead SecureRandom random = mixRandom; if (random != null) { random.setSeed(seed); } else { try { mixBuffer = new byte[20]; random = SecureRandom.getInstance("SHA1PRNG"); // initialize object before assigning to class field random.setSeed(seed); mixRandom = random; } catch (NoSuchAlgorithmException ee) { throw new ProviderException(ee); } } } finally { token.releaseSession(session); } } // see JCA spec @Override protected void engineNextBytes(byte[] bytes) { if ((bytes == null) || (bytes.length == 0)) { return; } if (bytes.length <= IBUFFER_SIZE) { int ofs = 0; synchronized (iBuffer) { while (ofs < bytes.length) { long time = System.currentTimeMillis(); // refill the internal buffer if empty or stale if ((ibuffered == 0) || !(time - lastRead < MAX_IBUFFER_TIME)) { lastRead = time; implNextBytes(iBuffer); ibuffered = IBUFFER_SIZE; } // copy the buffered bytes into 'bytes' while ((ofs < bytes.length) && (ibuffered > 0)) { bytes[ofs++] = iBuffer[IBUFFER_SIZE - ibuffered--]; } } } } else { // avoid using the buffer - just fill bytes directly implNextBytes(bytes); } } // see JCA spec @Override protected byte[] engineGenerateSeed(int numBytes) { byte[] b = new byte[numBytes]; engineNextBytes(b); return b; } private void mix(byte[] b) { SecureRandom random = mixRandom; if (random == null) { // avoid mixing if setSeed() has never been called return; } synchronized (this) { int ofs = 0; int len = b.length; while (len-- > 0) { if (buffered == 0) { random.nextBytes(mixBuffer); buffered = mixBuffer.length; } b[ofs++] ^= mixBuffer[mixBuffer.length - buffered]; buffered--; } } } // fill up the specified buffer with random bytes, and mix them private void implNextBytes(byte[] bytes) { Session session = null; try { session = token.getOpSession(); token.p11.C_GenerateRandom(session.id(), bytes); mix(bytes); } catch (PKCS11Exception e) { throw new ProviderException("nextBytes() failed", e); } finally { token.releaseSession(session); } } private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException { in.defaultReadObject(); // assign default values to non-null transient fields iBuffer = new byte[IBUFFER_SIZE]; ibuffered = 0; lastRead = 0L; } }
⏎ sun/security/pkcs11/P11SecureRandom.java
Or download all of them as a single archive file:
File name: jdk.crypto.cryptoki-17.0.5-src.zip File size: 239109 bytes Release date: 2022-09-13 Download
⇒ JDK 17 jdk.crypto.ec.jmod - Crypto EC Module
2023-10-15, 3896👍, 0💬
Popular Posts:
How to run "javac" command from JDK tools.jar file? "javac" is the Java compiler command that allows...
XML Serializer, Release 2.7.1, allows you to write out XML, HTML etc. as a stream of characters from...
HttpComponents Core Source Code Files are provided in the source package file, httpcomponents-core-5...
What Is ojdbc14.jar for Oracle 10g R2? ojdbc14.jar for Oracle 10g R2 is the JAR files of ojdbc.jar, ...
JDK 6 tools.jar is the JAR file for JDK 6 tools. It contains Java classes to support different JDK t...