当前位置: 首页>>代码示例>>Java>>正文


Java ECPoint.F2m方法代码示例

本文整理汇总了Java中org.bouncycastle.math.ec.ECPoint.F2m方法的典型用法代码示例。如果您正苦于以下问题:Java ECPoint.F2m方法的具体用法?Java ECPoint.F2m怎么用?Java ECPoint.F2m使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.bouncycastle.math.ec.ECPoint的用法示例。


在下文中一共展示了ECPoint.F2m方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: decodePoint

import org.bouncycastle.math.ec.ECPoint; //导入方法依赖的package包/类
public static ECPoint decodePoint(ECCurve curve, byte[] bytes)
{
    /*byte[] bp_enc=new byte[bytes.length+1];
      if (0==(bytes[bytes.length-1]&0x1))
          bp_enc[0]=0x02;
      else
          bp_enc[0]=0x03;
      System.arraycopy(bytes, 0, bp_enc, 1, bytes.length);
      if (!trace(curve.fromBigInteger(new BigInteger(1, bytes))).equals(curve.getA().toBigInteger()))
          bp_enc[bp_enc.length-1]^=0x01;

      return curve.decodePoint(bp_enc);*/

    BigInteger k = BigInteger.valueOf(bytes[bytes.length - 1] & 0x1);
    if (!trace(curve.fromBigInteger(new BigInteger(1, bytes))).equals(curve.getA().toBigInteger()))
    {
        bytes = Arrays.clone(bytes);
        bytes[bytes.length - 1] ^= 0x01;
    }
    ECCurve.F2m c = (ECCurve.F2m)curve;
    ECFieldElement xp = curve.fromBigInteger(new BigInteger(1, bytes));
    ECFieldElement yp = null;
    if (xp.toBigInteger().equals(ECConstants.ZERO))
    {
        yp = (ECFieldElement.F2m)curve.getB();
        for (int i = 0; i < c.getM() - 1; i++)
        {
            yp = yp.square();
        }
    }
    else
    {
        ECFieldElement beta = xp.add(curve.getA()).add(
            curve.getB().multiply(xp.square().invert()));
        ECFieldElement z = solveQuadradicEquation(beta);
        if (z == null)
        {
            throw new RuntimeException("Invalid point compression");
        }
        if (!trace(z).equals(k))
        {
            z = z.add(curve.fromBigInteger(ECConstants.ONE));
        }
        yp = xp.multiply(z);
    }

    return new ECPoint.F2m(curve, xp, yp);
}
 
开发者ID:Appdome,项目名称:ipack,代码行数:49,代码来源:DSTU4145PointEncoder.java


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