當前位置: 首頁>>代碼示例>>Java>>正文


Java SSLEngineResult.bytesProduced方法代碼示例

本文整理匯總了Java中javax.net.ssl.SSLEngineResult.bytesProduced方法的典型用法代碼示例。如果您正苦於以下問題:Java SSLEngineResult.bytesProduced方法的具體用法?Java SSLEngineResult.bytesProduced怎麽用?Java SSLEngineResult.bytesProduced使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在javax.net.ssl.SSLEngineResult的用法示例。


在下文中一共展示了SSLEngineResult.bytesProduced方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: checkResult

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
private void checkResult(SSLEngineResult result, boolean wrap)
        throws SSLException {

    handshakeStatus = result.getHandshakeStatus();
    resultStatus = result.getStatus();

    if (resultStatus != Status.OK &&
            (wrap || resultStatus != Status.BUFFER_UNDERFLOW)) {
        throw new SSLException("TODO");
    }
    if (wrap && result.bytesConsumed() != 0) {
        throw new SSLException("TODO");
    }
    if (!wrap && result.bytesProduced() != 0) {
        throw new SSLException("TODO");
    }
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:18,代碼來源:AsyncChannelWrapperSecure.java

示例2: checkResult

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
private void checkResult(SSLEngineResult result, boolean wrap) throws SSLException {

			handshakeStatus = result.getHandshakeStatus();
			resultStatus = result.getStatus();

			if (resultStatus != Status.OK && (wrap || resultStatus != Status.BUFFER_UNDERFLOW)) {
				throw new SSLException("TODO");
			}
			if (wrap && result.bytesConsumed() != 0) {
				throw new SSLException("TODO");
			}
			if (!wrap && result.bytesProduced() != 0) {
				throw new SSLException("TODO");
			}
		}
 
開發者ID:how2j,項目名稱:lazycat,代碼行數:16,代碼來源:AsyncChannelWrapperSecure.java

示例3: readMessage

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
private void readMessage() throws IOException {
    int totalProduced = 0;
    while (!stopping) {
        SSLEngineResult result = unwrap();
        if (result.getStatus() != Status.OK) {
            throw new RuntimeException("Failed reading message: " + result);
        }
        totalProduced += result.bytesProduced();
        if (totalProduced == MESSAGE_LENGTH) {
            return;
        }
    }
}
 
開發者ID:google,項目名稱:conscrypt,代碼行數:14,代碼來源:RenegotiationTest.java

示例4: writeInternal

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
private void writeInternal(ByteBuffer buffer) throws IOException {
    Platform.blockGuardOnNetwork();
    checkOpen();
    init();

    // Need to loop through at least once to enable handshaking where no application
    // bytes are
    // processed.
    int len = buffer.remaining();
    SSLEngineResult engineResult;
    do {
        target.clear();
        engineResult = engine.wrap(buffer, target);
        if (engineResult.getStatus() != OK) {
            throw new SSLException("Unexpected engine result " + engineResult.getStatus());
        }
        if (target.position() != engineResult.bytesProduced()) {
            throw new SSLException("Engine bytesProduced " + engineResult.bytesProduced()
                    + " does not match bytes written " + target.position());
        }
        len -= engineResult.bytesConsumed();
        if (len != buffer.remaining()) {
            throw new SSLException("Engine did not read the correct number of bytes");
        }

        target.flip();

        // Write the data to the socket.
        writeToSocket();
    } while (len > 0);
}
 
開發者ID:google,項目名稱:conscrypt,代碼行數:32,代碼來源:ConscryptEngineSocket.java

示例5: write

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
public void write(byte[] b, int off, int len) throws IOException {
    runHandshake();
    try (DefaultByteBufferPool.PooledByteBuffer uncompressedPooled = DefaultByteBufferPool.WRITE_DIRECT_POOL.allocate()) {
            try (DefaultByteBufferPool.PooledByteBuffer encryptedPooled = DefaultByteBufferPool.HEAP_POOL.allocate()) {
                ByteBuffer buf = uncompressedPooled.getBuffer();
                int toWrite = len;
                int written = 0;
                while (toWrite > 0) {
                    buf.clear();
                    int thisBufferAmount = Math.min(toWrite, buf.remaining());
                    buf.put(b, off + written, thisBufferAmount);
                    toWrite -= thisBufferAmount;
                    written += thisBufferAmount;
                    buf.flip();
                    while (buf.hasRemaining()) {
                        encryptedPooled.getBuffer().clear();
                        SSLEngineResult result = sslEngine.wrap(buf, encryptedPooled.getBuffer());
                        encryptedPooled.getBuffer().flip();
                        if (result.getStatus() == SSLEngineResult.Status.BUFFER_OVERFLOW) {
                            close();
                            throw new IOException(MESSAGES.bufferOverflow());//should never happen
                        } else if (result.getStatus() == SSLEngineResult.Status.BUFFER_UNDERFLOW) {
                            close();
                            throw new IOException(MESSAGES.bufferUnderflow());//should never happen
                        } else if (result.getStatus() == SSLEngineResult.Status.CLOSED) {
                            close();
                            throw new IOException(MESSAGES.streamIsClosed());
                        }
                        int produced = result.bytesProduced();
                        if (produced > 0) {
                            getDelegateOutputStream().write(encryptedPooled.getBuffer().array(), encryptedPooled.getBuffer().arrayOffset(), encryptedPooled.getBuffer().remaining());
                        }
                    }
                }
            }
    }

}
 
開發者ID:wildfly,項目名稱:wildfly-openssl,代碼行數:39,代碼來源:OpenSSLSocket.java

示例6: read

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
@Override public int read(byte[] buf, int off, int len) throws IOException
{
  if (!initialHandshakeDone ||
      engine.getHandshakeStatus() != HandshakeStatus.NOT_HANDSHAKING)
    {
      doHandshake();
      if (handshakeException != null)
        throw handshakeException;
    }

  if (!appBuffer.hasRemaining())
    {
      int x = in.read();
      if (x == -1)
        return -1;
      inBuffer.clear();
      inBuffer.put((byte) x);
      inBuffer.putInt(in.readInt());
      int reclen = inBuffer.getShort(3) & 0xFFFF;
      in.readFully(inBuffer.array(), 5, reclen);
      inBuffer.position(0).limit(reclen + 5);
      synchronized (engine)
        {
          appBuffer.clear();
          SSLEngineResult result = engine.unwrap(inBuffer, appBuffer);
          Status status = result.getStatus();
          if (status == Status.CLOSED && result.bytesProduced() == 0)
            return -1;
        }
      inBuffer.compact();
      appBuffer.flip();
    }
  int l = Math.min(len, appBuffer.remaining());
  appBuffer.get(buf, off, l);
  return l;
}
 
開發者ID:vilie,項目名稱:javify,代碼行數:37,代碼來源:SSLSocketImpl.java

示例7: run

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
@Override
public void run() {
    long written = 0;

    try {
        for (int i = offset; i < offset + length; i++) {
            ByteBuffer src = srcs[i];
            while (src.hasRemaining()) {
                socketWriteBuffer.clear();

                // Encrypt the data
                SSLEngineResult r = sslEngine.wrap(src, socketWriteBuffer);
                written += r.bytesConsumed();
                Status s = r.getStatus();

                if (s == Status.OK || s == Status.BUFFER_OVERFLOW) {
                    // Need to write out the bytes and may need to read from
                    // the source again to empty it
                } else {
                    // Status.BUFFER_UNDERFLOW - only happens on unwrap
                    // Status.CLOSED - unexpected
                    throw new IllegalStateException(sm.getString(
                            "asyncChannelWrapperSecure.statusWrap"));
                }

                // Check for tasks
                if (r.getHandshakeStatus() == HandshakeStatus.NEED_TASK) {
                    Runnable runnable = sslEngine.getDelegatedTask();
                    while (runnable != null) {
                        runnable.run();
                        runnable = sslEngine.getDelegatedTask();
                    }
                }

                socketWriteBuffer.flip();

                // Do the write
                int toWrite = r.bytesProduced();
                while (toWrite > 0) {
                    Future<Integer> f =
                            socketChannel.write(socketWriteBuffer);
                    Integer socketWrite = f.get();
                    toWrite -= socketWrite.intValue();
                }
            }
        }


        if (writing.compareAndSet(true, false)) {
            future.complete(Long.valueOf(written));
        } else {
            future.fail(new IllegalStateException(sm.getString(
                    "asyncChannelWrapperSecure.wrongStateWrite")));
        }
    } catch (Exception e) {
        future.fail(e);
    }
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:59,代碼來源:AsyncChannelWrapperSecure.java

示例8: run

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
@Override
public void run() {
	long written = 0;

	try {
		for (int i = offset; i < offset + length; i++) {
			ByteBuffer src = srcs[i];
			while (src.hasRemaining()) {
				socketWriteBuffer.clear();

				// Encrypt the data
				SSLEngineResult r = sslEngine.wrap(src, socketWriteBuffer);
				written += r.bytesConsumed();
				Status s = r.getStatus();

				if (s == Status.OK || s == Status.BUFFER_OVERFLOW) {
					// Need to write out the bytes and may need to read
					// from
					// the source again to empty it
				} else {
					// Status.BUFFER_UNDERFLOW - only happens on unwrap
					// Status.CLOSED - unexpected
					throw new IllegalStateException(sm.getString("asyncChannelWrapperSecure.statusWrap"));
				}

				// Check for tasks
				if (r.getHandshakeStatus() == HandshakeStatus.NEED_TASK) {
					Runnable runnable = sslEngine.getDelegatedTask();
					while (runnable != null) {
						runnable.run();
						runnable = sslEngine.getDelegatedTask();
					}
				}

				socketWriteBuffer.flip();

				// Do the write
				int toWrite = r.bytesProduced();
				while (toWrite > 0) {
					Future<Integer> f = socketChannel.write(socketWriteBuffer);
					Integer socketWrite = f.get();
					toWrite -= socketWrite.intValue();
				}
			}
		}

		if (writing.compareAndSet(true, false)) {
			future.complete(Long.valueOf(written));
		} else {
			future.fail(new IllegalStateException(sm.getString("asyncChannelWrapperSecure.wrongStateWrite")));
		}
	} catch (Exception e) {
		future.fail(e);
	}
}
 
開發者ID:how2j,項目名稱:lazycat,代碼行數:56,代碼來源:AsyncChannelWrapperSecure.java

示例9: unwrap

import javax.net.ssl.SSLEngineResult; //導入方法依賴的package包/類
private byte[] unwrap(ByteBuffer[] encryptedBuffers, SSLEngine engine) throws IOException {
    ByteArrayOutputStream cleartextStream = new ByteArrayOutputStream();
    int decryptedBufferSize = 8192;
    final ByteBuffer encryptedBuffer = combine(encryptedBuffers);
    final ByteBuffer decryptedBuffer = bufferType.newBuffer(decryptedBufferSize);
    while (encryptedBuffer.hasRemaining()) {
        if (!decryptedBuffer.hasRemaining()) {
            decryptedBuffer.clear();
        }
        int prevPos = decryptedBuffer.position();
        SSLEngineResult unwrapResult = engine.unwrap(encryptedBuffer, decryptedBuffer);
        SSLEngineResult.Status status = unwrapResult.getStatus();
        switch (status) {
            case BUFFER_OVERFLOW:
            case OK: {
                break;
            }
            default: { throw new RuntimeException("Unexpected SSLEngine status: " + status); }
        }
        int newPos = decryptedBuffer.position();
        int bytesProduced = unwrapResult.bytesProduced();
        assertEquals(bytesProduced, newPos - prevPos);

        // Add any generated bytes to the output stream.
        if (bytesProduced > 0 || status == Status.BUFFER_OVERFLOW) {
            byte[] decryptedBytes = new byte[unwrapResult.bytesProduced()];

            // Read the chunk that was just written to the output array.
            int limit = decryptedBuffer.limit();
            decryptedBuffer.limit(newPos);
            decryptedBuffer.position(prevPos);
            decryptedBuffer.get(decryptedBytes);

            // Restore the position and limit.
            decryptedBuffer.limit(limit);

            // Write the decrypted bytes to the stream.
            cleartextStream.write(decryptedBytes);
        }
    }

    return cleartextStream.toByteArray();
}
 
開發者ID:google,項目名稱:conscrypt,代碼行數:44,代碼來源:ConscryptEngineTest.java


注:本文中的javax.net.ssl.SSLEngineResult.bytesProduced方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。