亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? ibe_lib.c

?? 斯坦福大學(xué)密碼學(xué)家Boneh的基于身份的公鑰密碼系統(tǒng)
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/* IBE library routines, see ibe.h for usage * Ben Lynn *//*Copyright (C) 2001 Benjamin Lynn (blynn@cs.stanford.edu)See LICENSE for license*/#include <assert.h>#include <stdio.h>#include <stdlib.h>#include <time.h>#include <string.h>#include "curve.h"#include "version.h"#include "benchmark.h"#include "ibe.h"#include "crypto.h"#include "mm.h"void preprocessed_key_init(preprocessed_key_t pk, params_t params){    miller_cache_init(pk->mc, params->curve);}void preprocessed_key_clear(preprocessed_key_t pk){    miller_cache_clear(pk->mc);}int mympz_sizeinbytes(mpz_t x){    int i, n;    n = mpz_sizeinbase(x, 2);    i = n >> 3;    if (n % 8) i++;    return i;}void mympz_out_raw(mpz_t x, unsigned char *c, int n){    unsigned long l;    mpz_t z;    int i = n - 1;    mpz_init_set(z, x);    while(i >= 0) {	l = mpz_get_ui(z);	c[i] = (unsigned char) l;	mpz_tdiv_q_2exp(z, z, 8);	i--;    }    mpz_clear(z);}void mympz_inp_raw(mpz_t z, const unsigned char* c, int n){    int i = 0;    mpz_set_ui(z, 0);    while(i < n) {	mpz_mul_2exp(z, z, 8);	mpz_add_ui(z, z, c[i]);	i++;    }}static void mympz_from_hash(mpz_t x, mpz_t limit, byte_string_t hash)//let z = number represented in c//x = z || 1 || z || 2 || z || 3 ...//until there are enough bits//should be rewritten more efficiently?{    mpz_t z;    int countlen;    mpz_t count;    int i = 0, j;    int bits = mpz_sizeinbase(limit, 2);    int zbits;    char *c = hash->data;    int len = hash->len;    mpz_init(z);    mpz_init(count);    mpz_set_ui(count, 1);    mympz_inp_raw(z, c, len);    zbits = mpz_sizeinbase(z, 2);    mpz_set_ui(x, 0);    do {	for (j=0; j<zbits; j++) {	    if (mpz_tstbit(z, j)) {		mpz_setbit(x, i);	    }	    i++;	}	bits -= zbits;	if (bits <= 0) break;	countlen = mpz_sizeinbase(count, 2);	for (j=0; j<countlen; j++) {	    if (mpz_tstbit(count, j)) {		mpz_setbit(x, i);	    }	    i++;	}	bits -= countlen;	mpz_add_ui(count, count, 1);    } while (bits > 0);    /*    printf("hash: ");    mpz_out_str(NULL, 0, x);    printf("\n");    */    while (mpz_cmp(x, limit) > 0) {	mpz_clrbit(x, mpz_sizeinbase(x, 2) - 1);    }    mpz_clear(z);    mpz_clear(count);}void byte_string_set_mpz(byte_string_t bs, mpz_t x){    int i = mympz_sizeinbytes(x);    byte_string_init(bs, i);    mympz_out_raw(x, bs->data, i);}void byte_string_set_fp2(byte_string_t bs, fp2_t x){    byte_string_t bs1, bs2;    byte_string_set_mpz(bs1, x->a);    byte_string_set_mpz(bs2, x->b);    byte_string_join(bs, bs1, bs2);    byte_string_clear(bs1);    byte_string_clear(bs2);}void byte_string_set_point(byte_string_t bs, point_t P){    byte_string_t bs1, bs2;    byte_string_set_fp2(bs1, P->x);    byte_string_set_fp2(bs2, P->y);    byte_string_join(bs, bs1, bs2);    byte_string_clear(bs1);    byte_string_clear(bs2);}void mympz_set_byte_string(mpz_t z, byte_string_t bs){    mympz_inp_raw(z, bs->data, bs->len);}void fp2_set_byte_string(fp2_t x, byte_string_t bs){    byte_string_t bs1, bs2;    byte_string_split(bs1, bs2, bs);    mympz_set_byte_string(x->a, bs1);    mympz_set_byte_string(x->b, bs2);    byte_string_clear(bs1);    byte_string_clear(bs2);}void point_set_byte_string(point_t P, byte_string_t bs){    byte_string_t bs1, bs2;    byte_string_split(bs1, bs2, bs);    fp2_set_byte_string(P->x, bs1);    fp2_set_byte_string(P->y, bs2);    byte_string_clear(bs1);    byte_string_clear(bs2);}static void point_Phi(point_t PhiP, point_t P, params_t params){    fp2_mul(PhiP->x, P->x, params->zeta, params->p);    fp2_set(PhiP->y, P->y);}static void point_make_order_q(point_t P, params_t params)//P = ((p + 1)/q)P //so it has order q{    point_mul(P, params->p1onq, P, params->curve);}static void initpq(params_t params)//calculate system parameters that can be determined from p and q//also initialize the elliptic curve library so points can be used{    mpz_init(params->p1onq);    mpz_add_ui(params->p1onq, params->p, 1);    mpz_divexact(params->p1onq, params->p1onq, params->q);    //initialize the elliptic curve library    curve_init(params->curve, params->p, params->q);    fp2_init(params->zeta);    fp2_set_cbrt_unity(params->zeta, params->p);}void hash_G(mpz_t h, byte_string_t bs, params_t params)//hash a byte_string to an element of Z_p{    byte_string_t md_value;    crypto_hash(md_value, bs);    mympz_from_hash(h, params->p, md_value);    byte_string_clear(md_value);}void hash_H(byte_string_t md_value, fp2_t x, params_t params)//hash a point of E/F_p^2 to a byte_string{    byte_string_t bs;    byte_string_set_fp2(bs, x);    crypto_hash(md_value, bs);    byte_string_clear(bs);}static void map_byte_string_to_point(point_t d,	byte_string_t bs, params_t params)//converts byte_string into a point of order q on E/F_p{    int i;    fp2_t x, y;    bm_put(bm_get_time(), "mtp0");    fp2_init(x);    fp2_init(y);    //first use G function to choose x coordinate    hash_G(y->a, bs, params);    mpz_set_ui(x->b, 0);    mpz_set_ui(y->b, 0);    bm_put(bm_get_time(), "mtp1");    for (i=1;;i++) {	x_from_y(x->a, y->a, params->curve);	//we now have a point d	fp2_set(d->x, x);	fp2_set(d->y, y);	//make it order q	point_make_order_q(d, params);	if (!d->infinity) break;	//unlikely case: pick first available point	mpz_set_ui(y->a, i);    }    bm_put(bm_get_time(), "mtp2");    /*    printf("mapped to ");    point_out_str(NULL, 0, d);    printf("\n");    */    fp2_clear(x);    fp2_clear(y);}static void map_to_point(point_t d, const char *id, params_t params)//converts id into a point of order q on E/F_p{    byte_string_t bsid;    byte_string_set(bsid, id);    map_byte_string_to_point(d, bsid, params);    byte_string_clear(bsid);}void IBE_init(void)//NOT THREAD-SAFE. May add contexts here eventually...{    crypto_init();}void IBE_clear(void)/* Free memory used by library */{    crypto_clear();}void params_robust_clear(params_t params){    int i;    for (i=0; i<params->sharen; i++) {	point_clear(params->robustP[i]);	mpz_clear(params->robustx[i]);    }    free(params->robustP);    free(params->robustx);    params->sharet = params->sharen = 0;}void params_clear(params_t params){    curve_clear(params->curve);    mpz_clear(params->p1onq);    fp2_clear(params->zeta);    miller_cache_clear(params->Ppub_mc);    if (params->sharen) params_robust_clear(params);    mpz_clear(params->p);    mpz_clear(params->q);    point_clear(params->P);    point_clear(params->Ppub);    point_clear(params->PhiPpub);    free(params->version);    free(params->id);}void IBE_setup(params_t params, byte_string_t master, int k, int qk, char *id)/* generate system parameters * k = number of bits in p (should be at least 512) * qk = number of bits in q (size of subgroup, 160 is typical) * id = system ID */{    mpz_t p, q, r;    mpz_t x;    point_ptr P;    int solinasa, solinasb;    int kqk = k - qk - 4; //lose 4 bits since 12 is a 4-bit no.    unsigned int seed;    mpz_init(p); mpz_init(q); mpz_init(r); mpz_init(x);    //find random k-bit prime p such that    //p = 2 mod 3 and q = (p+1)/12r is prime as well for some r    //now also want q to be a Solinas prime    //we use rand() to help us find one: should be ok    crypto_rand_bytes((unsigned char *) &seed, sizeof(int));    srand(seed);    for(;;) {	//once q was just a random qk-bit prime	//now it must be a Solinas one	mpz_set_ui(q, 0);	solinasa = qk - 1;	mpz_setbit(q, solinasa);	mpz_set_ui(r, 0);	solinasb = rand() % qk;	mpz_setbit(r, solinasb);	if (rand() % 2) {	    mpz_add(q, q, r);	} else {	    mpz_sub(q, q, r);	    solinasb = -solinasb;	}	mpz_set_ui(r, 1);	if (rand() % 2) {	    mpz_add(q, q, r);	} else {	    mpz_sub(q, q, r);	    solinasa = -solinasa;	}	if (!mpz_probab_prime_p(q, 10)) continue;	mympz_randomb(r, kqk);	//p = q * r	mpz_mul(p, q, r);	//r = (((p << 1) + p) << 2) (= 12p)	mpz_mul_2exp(r, p, 1);	mpz_add(r, r, p);	mpz_mul_2exp(r, r, 2);	//p = r - 1	mpz_set_ui(p, 1);	mpz_sub(p, r, p);	if (mpz_probab_prime_p(p, 10)) break;    }    //pick master key x from F_q    mympz_randomm(x, q);    byte_string_set_mpz(master, x);    mpz_init(params->p);    mpz_init(params->q);    mpz_set(params->p, p);    mpz_set(params->q, q);    initpq(params);    //pick random point P of order q from E/F_p    point_init(params->P);    P = params->P;    do {	point_random(P, params->curve);	point_make_order_q(P, params);    } while (P->infinity);    point_init(params->Ppub);    point_mul(params->Ppub, x, P, params->curve);    point_mul_preprocess(P, params->curve);    miller_cache_init(params->Ppub_mc, params->curve);    tate_preprocess(params->Ppub_mc, params->Ppub, params->curve);    point_init(params->PhiPpub);    point_Phi(params->PhiPpub, params->Ppub, params);    params->id = (char *) malloc(strlen(id) + 1);    strcpy(params->id, id);    params->sharet = params->sharen = 0;    params->version = (char *) malloc(strlen(IBE_VERSION) + 1);    strcpy(params->version, IBE_VERSION);    mpz_clear(p); mpz_clear(q); mpz_clear(r); mpz_clear(x);}void IBE_extract_byte_string(byte_string_t bs, byte_string_t master,	byte_string_t id, params_t params)//for testing purposes{    point_t key;    mpz_t x;    mpz_init(x);    point_init(key);    map_byte_string_to_point(key, id, params);    mympz_set_byte_string(x, master);    point_mul(key, x, key, params->curve);    byte_string_set_point(bs, key);    point_clear(key);    mpz_clear(x);}void IBE_extract(byte_string_t bs,	byte_string_t master, const char *id, params_t params)//same as above, char * version{    byte_string_t bsid;    byte_string_set(bsid, id);    IBE_extract_byte_string(bs, master, bsid, params);    byte_string_clear(bsid);}void IBE_extract_share_byte_string(byte_string_t share, byte_string_t mshare,	byte_string_t id, params_t params)//extract a private key share from an ID and master share{    mpz_t y;    int i;    byte_string_t bs1, bs2;    point_t yd;    point_t d;    point_init(yd);    point_init(d);    mpz_init(y);    byte_string_split(bs1, bs2, mshare);    i = int_from_byte_string(bs1);    mympz_set_byte_string(y, bs2);    byte_string_clear(bs1);    byte_string_clear(bs2);    map_byte_string_to_point(d, id, params);    point_mul(yd, y, d, params->curve);    byte_string_set_int(bs1, i);    byte_string_set_point(bs2, yd);    byte_string_join(share, bs1, bs2);    byte_string_clear(bs1);    byte_string_clear(bs2);    point_clear(yd);    point_clear(d);    mpz_clear(y);}void IBE_extract_share(byte_string_t share,	byte_string_t mshare, const char *id, params_t params)//same as above except takes in char * instead of byte_string{    byte_string_t bsid;    byte_string_set(bsid, id);    IBE_extract_share_byte_string(share, mshare, bsid, params);    byte_string_clear(bsid);}int IBE_combine(byte_string_t key, byte_string_t *kshare, params_t params)//reconstruct a key from key shares, or a certificate from certificate shares{    int i, j;    int indexi, indexj;    point_t yP;    mpz_t num, denom;    mpz_t z;    point_t d;    byte_string_t bs1, bs2;    int *index;    index = (int *) alloca(params->sharet * sizeof(int));    for (i=0; i<params->sharet; i++) {	byte_string_split(bs1, bs2, kshare[i]);	byte_string_clear(bs2);	index[i] = int_from_byte_string(bs1);	byte_string_clear(bs1);	for (j=0; j<i; j++) {	    if (index[i] == index[j]) {		return 0;	    }	}    }    point_init(yP);    mpz_init(z);    mpz_init(num); mpz_init(denom);    point_init(d);    point_set_O(d);    for (i=0; i<params->sharet; i++) {	byte_string_split(bs1, bs2, kshare[i]);	indexi = index[i];	byte_string_clear(bs1);	point_set_byte_string(yP, bs2);	byte_string_clear(bs2);	mpz_set_ui(num, 1);	mpz_set_ui(denom, 1);	for (j=0; j<params->sharet; j++) {	    if (j != i) {		indexj = index[j];		mpz_mul(num, num, params->robustx[indexj]);		mpz_mod(num, num, params->q);		mpz_sub(z, params->robustx[indexj], params->robustx[indexi]);		mpz_mul(denom, denom, z);		mpz_mod(denom, denom, params->q);	    }	}	mpz_invert(denom, denom, params->q);	mpz_mul(z, num, denom);	mpz_mod(z, z, params->q);	point_mul(yP, z, yP, params->curve);	point_add(d, d, yP, params->curve);    }    byte_string_set_point(key, d);    point_clear(yP);    mpz_clear(z);    mpz_clear(num); mpz_clear(denom);    point_clear(d);    return 1;}void IBE_get_shared_secret_preprocess(preprocessed_key_t pk,	byte_string_t key, params_t params){    point_t Q;    point_init(Q);    point_set_byte_string(Q, key);    tate_preprocess(pk->mc, Q, params->curve);    point_clear(Q);}void IBE_get_shared_secret_postprocess(byte_string_t s,	char *id, preprocessed_key_t pk, params_t params){    point_t Qid;    fp2_t gid;    fp2_init(gid);    point_init(Qid);    map_to_point(Qid, id, params);    //calculate gid = e(Q_id, Phi(P_pub))    point_Phi(Qid, Qid, params);    tate_postprocess(gid, pk->mc, Qid, params->curve);    hash_H(s, gid, params);    fp2_clear(gid);    point_clear(Qid);}void IBE_KEM_encrypt_array(byte_string_t *s, byte_string_t U,	char **idarray, int count, params_t params){    int i;    mpz_t r;    fp2_t gidr;    point_t Qid;    point_t rP;    if (count <= 0) return;    //r is random in F_q    mpz_init(r);    mympz_randomm(r, params->q);    bm_put(bm_get_time(), "rP0");    //U = rP    point_init(rP);    //point_mul(rP, r, params->P);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品久久久久久久 | av高清久久久| 蜜臀va亚洲va欧美va天堂| 曰韩精品一区二区| 亚洲人成电影网站色mp4| 国产精品久久免费看| 亚洲国产精品二十页| 久久久久99精品国产片| 国产日本欧美一区二区| 国产精品乱码人人做人人爱 | 中文字幕日韩一区二区| 国产精品不卡在线| 亚洲一区二区中文在线| 日韩精品色哟哟| 蜜臀av一区二区| 国产专区欧美精品| 成人avav影音| 欧美日韩视频在线观看一区二区三区| 欧美伊人久久久久久久久影院 | 国产一区欧美日韩| 大白屁股一区二区视频| 一本色道a无线码一区v| 制服丝袜亚洲色图| 久久九九国产精品| 亚洲精品水蜜桃| 全国精品久久少妇| 福利电影一区二区三区| 欧洲人成人精品| 欧美成人精品二区三区99精品| 欧美激情一区在线观看| 亚洲夂夂婷婷色拍ww47| 韩国欧美国产一区| 色婷婷久久一区二区三区麻豆| 欧美一区二区视频网站| 国产精品视频免费看| 日韩电影在线一区| 99久久精品国产一区| 91精品国产美女浴室洗澡无遮挡| 久久久国产午夜精品| 亚洲国产日日夜夜| 成人一级片网址| 91.com在线观看| 亚洲欧洲精品天堂一级| 美腿丝袜亚洲色图| 欧美在线免费观看视频| 中文字幕乱码久久午夜不卡| 日韩电影网1区2区| 91黄视频在线| 国产欧美日本一区视频| 秋霞电影网一区二区| 一本到三区不卡视频| 久久精品夜夜夜夜久久| 青青草原综合久久大伊人精品优势 | 久热成人在线视频| 91九色最新地址| 亚洲国产精品成人综合色在线婷婷| 亚洲高清免费观看| 色婷婷综合久久久| 中文一区一区三区高中清不卡| 日本亚洲一区二区| 欧美日韩国产三级| 亚洲一二三区在线观看| 91麻豆高清视频| 亚洲欧洲色图综合| 成人av电影在线网| 国产精品国产精品国产专区不蜜 | 欧美在线色视频| 国产精品久久久久久久久搜平片| 激情综合色播五月| 欧美sm极限捆绑bd| 久久爱www久久做| 日韩视频国产视频| 蜜臀va亚洲va欧美va天堂| 88在线观看91蜜桃国自产| 亚洲国产cao| 欧美日韩亚洲不卡| 视频一区二区三区在线| 欧美日韩在线播放三区四区| 亚洲一级二级在线| 欧美区一区二区三区| 三级成人在线视频| 欧美一区二区三区影视| 蜜臀av一区二区在线观看| 欧美成人三级在线| 国产精品影视天天线| 国产香蕉久久精品综合网| 高清日韩电视剧大全免费| 日韩一区中文字幕| 欧美在线视频你懂得| 午夜精品在线视频一区| 日韩美女一区二区三区| 国产精品一区久久久久| 国产精品久久久久久久午夜片| 色综合久久综合网欧美综合网| 亚洲国产日产av| 欧美一卡2卡3卡4卡| 国产v综合v亚洲欧| 亚洲综合在线视频| 日韩三级电影网址| 高清国产一区二区三区| 亚洲一级不卡视频| 欧美一级搡bbbb搡bbbb| 国产成都精品91一区二区三| 亚洲免费视频成人| 欧美一区二区视频观看视频| 精品一区精品二区高清| 中文字幕在线视频一区| 欧美精品久久99久久在免费线 | 亚洲精品中文在线影院| 欧美日韩国产综合久久| 国产在线视频一区二区三区| 中文字幕一区二区三区在线播放 | 久久精品男人的天堂| 91在线国产观看| 免费在线观看日韩欧美| 亚洲欧美日韩国产中文在线| 精品久久久久久久一区二区蜜臀| 本田岬高潮一区二区三区| 日本欧美一区二区在线观看| 国产精品久久毛片a| 日韩一区二区麻豆国产| 一本到高清视频免费精品| 韩国av一区二区三区在线观看| 亚洲另类春色校园小说| 久久久久久免费| 欧美军同video69gay| 99re8在线精品视频免费播放| 美女一区二区三区在线观看| 亚洲精品国产精品乱码不99| 久久久不卡网国产精品一区| 91麻豆精品国产91久久久久久 | 性欧美大战久久久久久久久| 国产嫩草影院久久久久| 日韩区在线观看| 色综合久久精品| 国产成人午夜高潮毛片| 美女视频一区二区三区| 午夜精品久久久久久久久| 亚洲男女一区二区三区| 国产精品国产自产拍高清av| 欧美成人猛片aaaaaaa| 日韩一区二区视频在线观看| 欧美三级三级三级爽爽爽| 91香蕉视频污在线| 99久久精品国产导航| 丁香激情综合国产| 国产精品亚洲第一区在线暖暖韩国 | 欧美日韩国产另类一区| 色偷偷88欧美精品久久久| av一本久道久久综合久久鬼色| 国产成人在线免费观看| 国模少妇一区二区三区| 激情欧美一区二区| 激情综合网av| 国产一区二区导航在线播放| 激情六月婷婷久久| 国产成人av资源| av午夜精品一区二区三区| 99久久久久久| 色婷婷亚洲精品| 精品视频一区二区不卡| 欧美伦理电影网| 日韩一区二区三区视频| 久久久久久毛片| 国产精品青草综合久久久久99| 欧美激情一区二区在线| **网站欧美大片在线观看| 亚洲三级免费观看| 亚洲一区二区在线视频| 麻豆精品视频在线观看免费 | 亚洲久本草在线中文字幕| 亚洲美女视频在线| 日韩精品一二三四| 国产精品乡下勾搭老头1| caoporen国产精品视频| 在线看日韩精品电影| 欧美一区二区播放| 国产视频一区不卡| 怡红院av一区二区三区| 免费在线一区观看| 99国内精品久久| 91精品国产综合久久婷婷香蕉| 国产夜色精品一区二区av| 一区二区三区免费在线观看| 男人的j进女人的j一区| 成人久久视频在线观看| 欧美喷潮久久久xxxxx| 国产亚洲欧美日韩在线一区| 一区二区三区精品久久久| 韩国三级在线一区| 在线日韩国产精品| 久久久综合视频| 亚洲午夜免费福利视频| 国产成人综合在线播放| 欧美乱妇23p| 国产精品久久久久一区二区三区共| 亚洲精品大片www| 国产乱人伦偷精品视频免下载 | 日韩欧美国产成人一区二区| 最新日韩av在线|