Chinaunix首页 | 论坛 | 博客
  • 博客访问: 294561
  • 博文数量: 69
  • 博客积分: 2946
  • 博客等级: 少校
  • 技术积分: 800
  • 用 户 组: 普通用户
  • 注册时间: 2010-04-09 04:15
文章分类

全部博文(69)

文章存档

2013年(6)

2012年(16)

2011年(18)

2010年(29)

分类: C/C++

2011-06-15 00:53:00

1: #include 2:   3: #define MODULUS "C8FBCF21" 4: #define PUBLIC_EXPONENT RSA_F4 5: #define PRIVATE_EXPONENT "97B55D7D" 6:   7: int main() 8: { 9: int ret, flen; 10: BIGNUM *bnn, *bne, *bnd; 11: unsigned char *in = "abc"; 12: unsigned char *out; 13:   14: bnn = BN_new(); 15: bne = BN_new(); 16: bnd = BN_new(); 17: BN_hex2bn(&bnn, MODULUS); 18: BN_set_word(bne, PUBLIC_EXPONENT); 19: BN_hex2bn(&bnd, PRIVATE_EXPONENT); 20:   21: RSA *r = RSA_new(); 22: r->n = bnn; 23: r->e = bne; 24: r->d = bnd; 25: RSA_print_fp(stdout, r, 5); 26:   27: flen = RSA_size(r);// - 11; 28: out = (char *)malloc(flen); 29: bzero(out, flen); 30: //memset(out, 0, flen); 31:   32: printf("Begin encrypt... "); 33: ret = RSA_private_encrypt(flen, in, out, r, RSA_NO_PADDING); 34: if (ret < 0) 35: { 36: printf("Encrypt failed! "); 37: return 1; 38: } 39:   40: printf("Size:%d ", ret); 41: printf("ClearText:%s ", in); 42: printf("CipherText(Hex):"); 43: int i; 44: for (i=0; i 45: { 46: printf("0x%02x, ", *out); 47: out++; 48: } 49: printf(" "); 50:   51: //free(out); 52: RSA_free(r); 53: return 0; 54: }
.csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; }
1: #include 2:  3: #define MODULUS "C8FBCF21" 4: #define PUBLIC_EXPONENT RSA_F4 5: #define PRIVATE_EXPONENT "97B55D7D" 6:  7: int main() 8: { 9: int ret, flen; 10: BIGNUM *bnn, *bne, *bnd; 11: unsigned char *in = "abc"; 12: unsigned char *out; 13:  14: bnn = BN_new(); 15: bne = BN_new(); 16: bnd = BN_new(); 17: BN_hex2bn(&bnn, MODULUS); 18: BN_set_word(bne, PUBLIC_EXPONENT); 19: BN_hex2bn(&bnd, PRIVATE_EXPONENT); 20:  21: RSA *r = RSA_new(); 22: r->n = bnn; 23: r->e = bne; 24: r->d = bnd; 25: RSA_print_fp(stdout, r, 5); 26:  27: flen = RSA_size(r);// - 11; 28: out = (char *)malloc(flen); 29: bzero(out, flen); 30: //memset(out, 0, flen); 31:  32: printf("Begin encrypt... "); 33: ret = RSA_private_encrypt(flen, in, out, r, RSA_NO_PADDING); 34: if (ret < 0) 35: { 36: printf("Encrypt failed! "); 37: return 1; 38: } 39:  40: printf("Size:%d ", ret); 41: printf("ClearText:%s ", in); 42: printf("CipherText(Hex):"); 43: int i; 44: for (i=0; i 45: { 46: printf("0x%02x, ", *out); 47: out++; 48: } 49: printf(" "); 50:  51: //free(out); 52: RSA_free(r); 53: return 0; 54: }
阅读(4460) | 评论(0) | 转发(2) |
0

上一篇:没有了

下一篇:厦门大学acm1004解答

给主人留下些什么吧!~~