JPBC的使用

JPBC的使用

质数双线性群可以由五元组(p,G1,G2,GT,e)来描述。五元组中p是一个与给定安全常数λ相关的大质数,G1,G2,GT均是阶为p的乘法循环群,e为双线性映射e:G1×G2→GT,它满足以下3个条件:
双线性(Bilinearity):对于任意的g∈G1,h∈G2,a,b∈Zp,有e(ga,hb)=e(g,h)ab;
非退化性(Non-degeneracy):至少存在元素g1∈G1,g2∈G2,满足e(g1,g2)≠1;
可计算性(Efficiency):对于任意的u∈G1,v∈G2,存在一个与给定安全常数λ相关的多项式时间算法,可以高效地计算e(u,v);

G1、G2椭圆曲线上的群(只有一种运算,加法群乘法群效果一样,阶为r)
Zr整数有限域(有加法和乘法,会模r)
GT是模乘群

r=160 Bits Zr的模为 20字节 160/8
q=512 Bits 一个G1、Gt曲线上的点横纵坐标 共128字节 512*2/8

depuliate() 和 getImmutable()确保了g在参与运算后本身的值不会发生改变。

参考:
https://www.bbsmax.com/A/gAJG4aL35Z/

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相关库函数并进行加密了!!!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值