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

Java ElGamalPublicKeyParameters类代码示例

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

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



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

示例1: generateKeyPair

import org.bouncycastle.crypto.params.ElGamalPublicKeyParameters; //导入依赖的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.ElGamalPublicKeyParameters; //导入依赖的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.ElGamalPublicKeyParameters; //导入依赖的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: generatePublicKeyParameter

import org.bouncycastle.crypto.params.ElGamalPublicKeyParameters; //导入依赖的package包/类
static public AsymmetricKeyParameter generatePublicKeyParameter(
    PublicKey    key)
    throws InvalidKeyException
{
    if (key instanceof ElGamalPublicKey)
    {
        ElGamalPublicKey    k = (ElGamalPublicKey)key;

        return new ElGamalPublicKeyParameters(k.getY(),
            new ElGamalParameters(k.getParams().getP(), k.getParams().getG()));
    }

    throw new InvalidKeyException("can't identify ElGamal public key.");
}
 
开发者ID:thangbn,项目名称:Direct-File-Downloader,代码行数:15,代码来源:ElGamalUtil.java


示例5: encryptWithPublicKey

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


示例6: encryptForContract

import org.bouncycastle.crypto.params.ElGamalPublicKeyParameters; //导入依赖的package包/类
public ElGamalEncrypt encryptForContract(byte[] data) {
	ElGamalParameters params = new ElGamalParameters(keys.getP(), keys.getG());
	ElGamalPublicKeyParameters pubKey = new ElGamalPublicKeyParameters(keys.getPublicKey(), params);
	
	ElGamalEngine e = new ElGamalEngine();
	e.init(true, pubKey);
	byte[] m = e.processBlock(data, 0, data.length);
	BigInteger k = e.getK();
       BigInteger u = keys.getG().modPow(k,keys.getP());
       BigInteger v = (keys.getPublicKey().modPow(e.getK(), keys.getP()).multiply(new BigInteger(data)));
       return new ElGamalEncrypt (u,v,k, m);
}
 
开发者ID:pja35,项目名称:p2pEngine,代码行数:13,代码来源:ElGamal.java


示例7: GenerateKeys

import org.bouncycastle.crypto.params.ElGamalPublicKeyParameters; //导入依赖的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: JCEElGamalPublicKey

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


示例9: BCElGamalPublicKey

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


示例10: testGeneration

import org.bouncycastle.crypto.params.ElGamalPublicKeyParameters; //导入依赖的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.ElGamalPublicKeyParameters类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

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

请发表评论

全部评论

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