• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Java RSADigestSigner类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了Java中org.bouncycastle.crypto.signers.RSADigestSigner的典型用法代码示例。如果您正苦于以下问题:Java RSADigestSigner类的具体用法?Java RSADigestSigner怎么用?Java RSADigestSigner使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



RSADigestSigner类属于org.bouncycastle.crypto.signers包,在下文中一共展示了RSADigestSigner类的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。

示例1: createSigner

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
protected Signer createSigner(AlgorithmIdentifier sigAlgId, AlgorithmIdentifier digAlgId)
        throws OperatorCreationException {
    if (!AlgorithmUtil.isRSASigAlgId(sigAlgId)) {
        throw new OperatorCreationException(
                "the given algorithm is not a valid RSA signature algirthm '"
                + sigAlgId.getAlgorithm().getId() + "'");
    }

    if (!PKCSObjectIdentifiers.id_RSASSA_PSS.equals(sigAlgId.getAlgorithm())) {
        Digest dig = digestProvider.get(digAlgId);
        return new RSADigestSigner(dig);
    }

    try {
        return SignerUtil.createPSSRSASigner(sigAlgId);
    } catch (XiSecurityException ex) {
        throw new OperatorCreationException(ex.getMessage(), ex);
    }
}
 
开发者ID:xipki,项目名称:xitk,代码行数:20,代码来源:SoftTokenContentSignerBuilder.java


示例2: createSigner

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
static Signer createSigner(int keyAlgorithm, int hashAlgorithm)
    throws PGPException
{
    switch(keyAlgorithm)
    {
    case PublicKeyAlgorithmTags.RSA_GENERAL:
    case PublicKeyAlgorithmTags.RSA_SIGN:
        return new RSADigestSigner(createDigest(hashAlgorithm));
    case PublicKeyAlgorithmTags.DSA:
        return new DSADigestSigner(new DSASigner(), createDigest(hashAlgorithm));
    case PublicKeyAlgorithmTags.ECDSA:
        return new DSADigestSigner(new ECDSASigner(), createDigest(hashAlgorithm));
    default:
        throw new PGPException("cannot recognise keyAlgorithm: " + keyAlgorithm);
    }
}
 
开发者ID:ttt43ttt,项目名称:gwt-crypto,代码行数:17,代码来源:BcImplProvider.java


示例3: signTicket

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
/**
 * Calculates the signature of a ticket and updates the given {@link Ticket} object directly.
 * 
 * @throws IllegalStateException
 *           If ticket cannot be signed.
 */
public void signTicket(Ticket ticket) throws IllegalStateException {
  byte[] serialized = TicketUtil.serialize(ticket);
  byte[] claimBytes = TicketUtil.deserialize(ByteBuffer.wrap(serialized)).getRight();

  RSAPrivateCrtKeyParameters signingKey = keyManager.getPrivateSigningKey();

  if (signingKey == null)
    throw new IllegalStateException("Cannot sign ticket because there is no private signing key available.");

  RSADigestSigner signer = new RSADigestSigner(new SHA256Digest());
  signer.init(true, signingKey);
  signer.update(claimBytes, 0, claimBytes.length);
  try {
    byte[] signature = signer.generateSignature();
    ticket.setSignature(signature);
  } catch (DataLengthException | CryptoException e) {
    throw new IllegalStateException("Cannot sign ticket", e);
  }
}
 
开发者ID:diqube,项目名称:diqube,代码行数:26,代码来源:TicketSignatureService.java


示例4: createSigner

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
protected Signer createSigner(AlgorithmIdentifier sigAlgId)
    throws OperatorCreationException
{
    AlgorithmIdentifier digAlg = digestAlgorithmFinder.find(sigAlgId);
    Digest dig = digestProvider.get(digAlg);

    return new RSADigestSigner(dig);
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:9,代码来源:BcRSAContentVerifierProviderBuilder.java


示例5: createSigner

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
protected Signer createSigner(AlgorithmIdentifier sigAlgId, AlgorithmIdentifier digAlgId)
    throws OperatorCreationException
{
    Digest dig = digestProvider.get(digAlgId);

    return new RSADigestSigner(dig);
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:8,代码来源:BcRSAContentSignerBuilder.java


示例6: createSigner

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
@Override
protected Signer createSigner(AlgorithmIdentifier sigAlgId) throws OperatorCreationException {
    if (PKCSObjectIdentifiers.id_RSASSA_PSS.equals(sigAlgId.getAlgorithm())) {
        try {
            return SignerUtil.createPSSRSASigner(sigAlgId);
        } catch (XiSecurityException ex) {
            throw new OperatorCreationException(ex.getMessage(), ex);
        }
    } else {
        AlgorithmIdentifier digAlg = digestAlgorithmFinder.find(sigAlgId);
        return new RSADigestSigner(digestProvider.get(digAlg));
    }
}
 
开发者ID:xipki,项目名称:xitk,代码行数:14,代码来源:XiRSAContentVerifierProviderBuilder.java


示例7: verifySignatureSHA256

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
public static void verifySignatureSHA256(APublicKey publicKey, byte[] payload, byte[] sig) throws Exception
{
	CipherParameters pub = getCipherParameters(publicKey);
	RSADigestSigner signer = new RSADigestSigner(new SHA256Digest());
	signer.init(false, pub);
	signer.update(payload, 0, payload.length);
	if(!signer.verifySignature(sig))
	{
		throw new Exception("failed signature verification");
	}
}
 
开发者ID:andy-goryachev,项目名称:PasswordSafe,代码行数:12,代码来源:Crypto.java


示例8: generateSignatureSHA256

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
public static byte[] generateSignatureSHA256(APrivateKey privateKey, byte[] payload) throws Exception
{
	CipherParameters pub = getCipherParameters(privateKey);
	RSADigestSigner signer = new RSADigestSigner(new SHA256Digest());
	signer.init(true, pub);
	signer.update(payload, 0, payload.length);
	return signer.generateSignature();
}
 
开发者ID:andy-goryachev,项目名称:PasswordSafe,代码行数:9,代码来源:Crypto.java


示例9: isValidTicketSignature

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
/**
 * Checks if a {@link Ticket} has a valid signature.
 * 
 * @param deserializedTicket
 *          The result of {@link TicketUtil#deserialize(ByteBuffer)} of the serialized {@link Ticket}.
 * @return true if {@link Ticket} signature is valid.
 */
public boolean isValidTicketSignature(Pair<Ticket, byte[]> deserializedTicket) {
  for (RSAKeyParameters pubKey : keyManager.getPublicValidationKeys()) {
    RSADigestSigner signer = new RSADigestSigner(new SHA256Digest());
    signer.init(false, pubKey);
    signer.update(deserializedTicket.getRight(), 0, deserializedTicket.getRight().length);
    if (signer.verifySignature(deserializedTicket.getLeft().getSignature()))
      return true;
  }
  return false;
}
 
开发者ID:diqube,项目名称:diqube,代码行数:18,代码来源:TicketSignatureService.java


示例10: createSigner

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
static Signer createSigner(int keyAlgorithm, int hashAlgorithm)
    throws PGPException
{
    switch(keyAlgorithm)
    {
    case PublicKeyAlgorithmTags.RSA_GENERAL:
    case PublicKeyAlgorithmTags.RSA_SIGN:
        return new RSADigestSigner(createDigest(hashAlgorithm));
    case PublicKeyAlgorithmTags.DSA:
        return new DSADigestSigner(new DSASigner(), createDigest(hashAlgorithm));
    default:
        throw new PGPException("cannot recognise keyAlgorithm");
    }
}
 
开发者ID:NoYouShutup,项目名称:CryptMeme,代码行数:15,代码来源:BcImplProvider.java


示例11: RSASignature

import org.bouncycastle.crypto.signers.RSADigestSigner; //导入依赖的package包/类
/**
 * Creates a new RSA signature class that uses the given digest algorithm
 * for message digest computation.
 *
 * @param d
 *            Message digest algorithm.
 */
public RSASignature(final DigestAlgorithm d) {
	super(ALGORITHM);
	digest = d;
	signer = new RSADigestSigner(d.getDigest());
}
 
开发者ID:shivam091,项目名称:Java-Security,代码行数:13,代码来源:RSASignature.java



注:本文中的org.bouncycastle.crypto.signers.RSADigestSigner类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java SimpleEventBus类代码示例发布时间:2022-05-22
下一篇:
Java RowSet类代码示例发布时间:2022-05-22
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap