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

Java ElGamalPrivateKeyParameters类代码示例

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

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



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

示例1: generateKeyPair

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
public AsymmetricCipherKeyPair generateKeyPair()
  {
      BigInteger           p, g, x, y;
      int                  qLength = param.getStrength() - 1;
      ElGamalParameters    elParams = param.getParameters();

      p = elParams.getP();
      g = elParams.getG();
  
      //
      // calculate the private key
      //
x = new BigInteger(qLength, param.getRandom());

      //
      // calculate the public key.
      //
      y = g.modPow(x, p);

      return new AsymmetricCipherKeyPair(
              new ElGamalPublicKeyParameters(y, elParams),
              new ElGamalPrivateKeyParameters(x, elParams));
  }
 
开发者ID:thangbn,项目名称:Direct-File-Downloader,代码行数:24,代码来源:ElGamalKeyPairGenerator.java


示例2: testInvalidP

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
private void testInvalidP()
{
    ElGamalParameters               dhParams = new ElGamalParameters(pPgpBogusPSamp, gPgpBogusPSamp, lPgpBogusPSamp);
    ElGamalPublicKeyParameters      pu = new ElGamalPublicKeyParameters(yPgpBogusPSamp, dhParams);
    ElGamalPrivateKeyParameters     pv = new ElGamalPrivateKeyParameters(xPgpBogusPSamp, dhParams);

    ElGamalEngine    e = new ElGamalEngine();

    e.init(true, pu);

    byte[]  message = Hex.decode("5468697320697320612074657374");

    byte[]  pText = message;
    byte[]  cText = e.processBlock(pText, 0, pText.length);

    e.init(false, pv);

    pText = e.processBlock(cText, 0, cText.length);

    if (Arrays.areEqual(message, pText))
    {
        fail("invalid test failed");
    }
}
 
开发者ID:ttt43ttt,项目名称:gwt-crypto,代码行数:25,代码来源:ElGamalTest.java


示例3: generateKeyPair

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
public AsymmetricCipherKeyPair generateKeyPair()
{
    DHKeyGeneratorHelper helper = DHKeyGeneratorHelper.INSTANCE;
    ElGamalParameters egp = param.getParameters();
    DHParameters dhp = new DHParameters(egp.getP(), egp.getG(), null, egp.getL());  

    BigInteger x = helper.calculatePrivate(dhp, param.getRandom()); 
    BigInteger y = helper.calculatePublic(dhp, x);

    return new AsymmetricCipherKeyPair(
        new ElGamalPublicKeyParameters(y, egp),
        new ElGamalPrivateKeyParameters(x, egp));
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:14,代码来源:ElGamalKeyPairGenerator.java


示例4: generatePrivateKeyParameter

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
static public AsymmetricKeyParameter generatePrivateKeyParameter(
    PrivateKey    key)
    throws InvalidKeyException
{
    if (key instanceof ElGamalPrivateKey)
    {
        ElGamalPrivateKey    k = (ElGamalPrivateKey)key;

        return new ElGamalPrivateKeyParameters(k.getX(),
            new ElGamalParameters(k.getParams().getP(), k.getParams().getG()));
    }
                    
    throw new InvalidKeyException("can't identify ElGamal private key.");
}
 
开发者ID:thangbn,项目名称:Direct-File-Downloader,代码行数:15,代码来源:ElGamalUtil.java


示例5: checkKeySize

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
private void checkKeySize(
    int privateValueSize,
    ElGamalPrivateKeyParameters priv)
{
    if (privateValueSize != 0)
    {
        if (priv.getX().bitLength() != privateValueSize)
        {
            fail("limited key check failed for key size " + privateValueSize);
        }
    }
}
 
开发者ID:ttt43ttt,项目名称:gwt-crypto,代码行数:13,代码来源:ElGamalTest.java


示例6: decryptWithPrivateKey

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
@Override
public  byte[] decryptWithPrivateKey(byte[] data) {
	ElGamalParameters params = new ElGamalParameters(keys.getP(), keys.getG());
	ElGamalPrivateKeyParameters privKey = new ElGamalPrivateKeyParameters(keys.getPrivateKey(), params);
	
	ElGamalEngine e = new ElGamalEngine();
	e.init(false, privKey);
	
       return e.processBlock(data, 0, data.length) ;
}
 
开发者ID:pja35,项目名称:p2pEngine,代码行数:11,代码来源:ElGamal.java


示例7: GenerateKeys

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
/**
 * This method is used to generate Public Key and Private Key
 * @param params
 */
private void GenerateKeys(ElGamalParameters params, String password){
	ElGamalKeyGenerationParameters elGP = new ElGamalKeyGenerationParameters(random,params);
	ElGamalKeyPairGenerator KeyPair = new ElGamalKeyPairGenerator();
	KeyPair.init(elGP);
	AsymmetricCipherKeyPair cipher1 = KeyPair.generateKeyPair();
	publicKey = ((ElGamalPublicKeyParameters) cipher1.getPublic()).getY();
	privateKey = ((ElGamalPrivateKeyParameters)cipher1.getPrivate()).getX();
	wellGenerated = true;
	encryptPrivateKey(password);
}
 
开发者ID:pja35,项目名称:p2pEngine,代码行数:15,代码来源:AsymKeysImpl.java


示例8: generates1536bitKeys

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
@Test
public void generates1536bitKeys() throws Exception {
    final AsymmetricCipherKeyPair pair = ElgamalKeyGenerator.elgamal1536().generate(random);

    assertThat(pair.getPrivate())
            .isInstanceOf(ElGamalPrivateKeyParameters.class);

    final ElGamalPrivateKeyParameters privateKeys = (ElGamalPrivateKeyParameters) pair.getPrivate();
    assertThat(privateKeys.getParameters().getP().toByteArray().length)
            .isEqualTo(193);
}
 
开发者ID:codahale,项目名称:gpgj,代码行数:12,代码来源:ElgamalKeyGeneratorTest.java


示例9: generates2048bitKeys

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
@Test
public void generates2048bitKeys() throws Exception {
    final AsymmetricCipherKeyPair pair = ElgamalKeyGenerator.elgamal2048().generate(random);

    assertThat(pair.getPrivate())
            .isInstanceOf(ElGamalPrivateKeyParameters.class);

    final ElGamalPrivateKeyParameters privateKeys = (ElGamalPrivateKeyParameters) pair
            .getPrivate();
    assertThat(privateKeys.getParameters().getP().toByteArray().length)
            .isEqualTo(257);
}
 
开发者ID:codahale,项目名称:gpgj,代码行数:13,代码来源:ElgamalKeyGeneratorTest.java


示例10: generates4096bitKeys

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
@Test
public void generates4096bitKeys() throws Exception {
    final AsymmetricCipherKeyPair pair = ElgamalKeyGenerator.elgamal4096().generate(random);

    assertThat(pair.getPrivate())
            .isInstanceOf(ElGamalPrivateKeyParameters.class);

    final ElGamalPrivateKeyParameters privateKeys = (ElGamalPrivateKeyParameters) pair
            .getPrivate();
    assertThat(privateKeys.getParameters().getP().toByteArray().length)
            .isEqualTo(513);
}
 
开发者ID:codahale,项目名称:gpgj,代码行数:13,代码来源:ElgamalKeyGeneratorTest.java


示例11: generates8192bitKeys

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
@Test
public void generates8192bitKeys() throws Exception {
    final AsymmetricCipherKeyPair pair = ElgamalKeyGenerator.elgamal8192().generate(random);

    assertThat(pair.getPrivate())
            .isInstanceOf(ElGamalPrivateKeyParameters.class);

    final ElGamalPrivateKeyParameters privateKeys = (ElGamalPrivateKeyParameters) pair
            .getPrivate();
    assertThat(privateKeys.getParameters().getP().toByteArray().length)
            .isEqualTo(1025);
}
 
开发者ID:codahale,项目名称:gpgj,代码行数:13,代码来源:ElgamalKeyGeneratorTest.java


示例12: JCEElGamalPrivateKey

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
JCEElGamalPrivateKey(
    ElGamalPrivateKeyParameters  params)
{
    this.x = params.getX();
    this.elSpec = new ElGamalParameterSpec(params.getParameters().getP(), params.getParameters().getG());
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:7,代码来源:JCEElGamalPrivateKey.java


示例13: BCElGamalPrivateKey

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
BCElGamalPrivateKey(
    ElGamalPrivateKeyParameters params)
{
    this.x = params.getX();
    this.elSpec = new ElGamalParameterSpec(params.getParameters().getP(), params.getParameters().getG());
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:7,代码来源:BCElGamalPrivateKey.java


示例14: testGeneration

import org.bouncycastle.crypto.params.ElGamalPrivateKeyParameters; //导入依赖的package包/类
/**
 * this test is can take quiet a while
 *
 * @param size size of key in bits.
 */
private void testGeneration(
    int         size)
{
    ElGamalParametersGenerator       pGen = new ElGamalParametersGenerator();

    pGen.init(size, 10, new SecureRandom());

    ElGamalParameters                elParams = pGen.generateParameters();

    if (elParams.getL() != 0)
    {
        fail("ElGamalParametersGenerator failed to set L to 0 in generated ElGamalParameters");
    }

    ElGamalKeyGenerationParameters   params = new ElGamalKeyGenerationParameters(new SecureRandom(), elParams);

    ElGamalKeyPairGenerator          kpGen = new ElGamalKeyPairGenerator();

    kpGen.init(params);

    //
    // generate first pair
    //
    AsymmetricCipherKeyPair         pair = kpGen.generateKeyPair();

    ElGamalPublicKeyParameters      pu = (ElGamalPublicKeyParameters)pair.getPublic();
    ElGamalPrivateKeyParameters     pv = (ElGamalPrivateKeyParameters)pair.getPrivate();

    ElGamalEngine    e = new ElGamalEngine();

    e.init(true, new ParametersWithRandom(pu, new SecureRandom()));

    byte[]  message = Hex.decode("5468697320697320612074657374");

    byte[]  pText = message;
    byte[]  cText = e.processBlock(pText, 0, pText.length);

    e.init(false, pv);

    pText = e.processBlock(cText, 0, cText.length);

    if (!Arrays.areEqual(message, pText))
    {
        fail("generation test failed");
    }
}
 
开发者ID:ttt43ttt,项目名称:gwt-crypto,代码行数:52,代码来源:ElGamalTest.java



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


鲜花

握手

雷人

路过

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

请发表评论

全部评论

专题导读
上一篇:
Java TypeResolver类代码示例发布时间:2022-05-22
下一篇:
Java IRCConnection类代码示例发布时间: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