本文整理汇总了Java中com.subgraph.orchid.crypto.TorTapKeyAgreement.deriveKeysFromDHPublicAndHash方法的典型用法代码示例。如果您正苦于以下问题:Java TorTapKeyAgreement.deriveKeysFromDHPublicAndHash方法的具体用法?Java TorTapKeyAgreement.deriveKeysFromDHPublicAndHash怎么用?Java TorTapKeyAgreement.deriveKeysFromDHPublicAndHash使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类com.subgraph.orchid.crypto.TorTapKeyAgreement
的用法示例。
在下文中一共展示了TorTapKeyAgreement.deriveKeysFromDHPublicAndHash方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: processRendezvous2
import com.subgraph.orchid.crypto.TorTapKeyAgreement; //导入方法依赖的package包/类
HiddenServiceCircuit processRendezvous2(TorTapKeyAgreement kex) {
final RelayCell cell = circuit.receiveRelayCell();
if(cell == null) {
logger.info("Timeout waiting for RENDEZVOUS2");
return null;
} else if (cell.getRelayCommand() != RelayCell.RELAY_COMMAND_RENDEZVOUS2) {
logger.info("Unexpected Relay cell type received while waiting for RENDEZVOUS2: "+ cell.getRelayCommand());
return null;
}
final BigInteger peerPublic = readPeerPublic(cell);
final HexDigest handshakeDigest = readHandshakeDigest(cell);
if(peerPublic == null || handshakeDigest == null) {
return null;
}
final byte[] verifyHash = new byte[TorMessageDigest.TOR_DIGEST_SIZE];
final byte[] keyMaterial = new byte[CircuitNodeCryptoState.KEY_MATERIAL_SIZE];
if(!kex.deriveKeysFromDHPublicAndHash(peerPublic, handshakeDigest.getRawBytes(), keyMaterial, verifyHash)) {
logger.info("Error deriving session keys while extending to hidden service");
return null;
}
return circuit.connectHiddenService(CircuitNodeImpl.createAnonymous(circuit.getFinalCircuitNode(), keyMaterial, verifyHash));
}