type A1使用

区别

我们常使用type A,type A1两种曲线。type A是素数阶的,type A1与其很类似,但其 G 1 , G 2 , G T G_1,G_2,G_T G1,G2,GT的阶是合数 N N N. N N N是一系列素数的乘积 N = p 1 p 2 . . . p n N=p_1 p_2...p_n N=p1p2...pn.对双线性映射 e : G 1 × G 2 → G T e:G_1 \times G_2 \rightarrow G_T e:G1×G2GT同样满足双线性的性质。
合数阶群与素数阶群的区别在于,他有一系列子群:阶为 p i p_i pi的子群 G p i ( i ∈ { 1 , 2 , . . . , n } ) G_{p_i} (i \in \{1,2,...,n\}) Gpi(i{1,2,...,n}).对于不同的子群之间是正交的. e ( h i , g j ) = 1 ( h i ∈ G P i , g i ∈ G p j ) e(h_i,g_j)=1 (h_i \in G_{P_i} ,g_i \in G_{p_j}) e(hi,gj)=1(hiGPi,giGpj)

使用

	public static void main(String[] args) {
		// TODO Auto-generated method stub	
		int num=3;
		TypeA1CurveGenerator pg = new TypeA1CurveGenerator(num, 517);
		PairingParameters s=pg.generate();
		Pairing pairing=PairingFactory.getPairing(s);
		
		Field Zn=pairing.getZr();
		Field Gt=pairing.getGT();
		Element zn1=Zn.newRandomElement().getImmutable();
		Element gt1=Gt.newRandomElement().getImmutable();
		System.out.println("zn1:"+zn1.toString());
		System.out.println("gt:"+gt1.toString());
		Element generator=pairing.getG1().newRandomElement().getImmutable();
		//使用生成阶为pi的子群,生成随机元素 :
		Element Gp1=ElementUtils.getGenerator(pairing, generator, s, 0, num).getImmutable();
		System.out.println("Gp1:"+Gp1.toString());
		}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Android studio 配置 jPBC 2.0.0 1、在压缩包的jars文件夹下找到下面两个文件:jpbc-api-2.0.0.jar    和   jpbc-plaf-2.0.0.jar 2、将上述两个jar包导入工程依赖包!!不会的百度一下Android studio怎么导入jar包!!! 3、在压缩包的jpbc-android文件夹下的assets文件夹下有4个用于测试的椭圆曲线常数Properties:a.properties、d159.properties、d201.properties,以及d224.properties,应该挪到Android 工程的assets文件夹下(当然也不一定非是这4个,只要是.properties参数文件都可以放进去,以供调用!!!),重点来了,Android studio 中并没有assets文件夹(assets文件夹是基于Eclipse进行android开发时专门存放资源文件的地方),怎么办呢?(android  studio老鸟勿喷)。实际上Android studio 也有存放资源文件的地方,那就是res文件夹!!!所以在Android strudio中我们可以新建一个与res文件夹并列的assets文件夹,具体步骤为:          点击main文件夹,然后右键---->New---->Folder---->Assets Folder---->点击完成      然后就可以发现main文件夹下多了一个assets资源文件夹!!!然后再把上述4个文件放进去就好了!!! 注意在加密中经常用到.properties文件,所以可以采用如下方式调用:                 Pairing pairing = PairingFactory.getPairing("assets/e_181_1024.properties");                 Field G = pairing.getG1();                 Field GT = pairing.getGT();                 Field Zq = pairing.getZr(); 之后就可以在工程里正常调用jpbc相关库函数并进行加密了!!!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

帅逼码农

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值