亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1424 | 回復: 0
打印 上一主題 下一主題

詭異的RSA非對稱加解密相關函數(shù) [復制鏈接]

論壇徽章:
0
跳轉到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2009-08-24 11:53 |只看該作者 |倒序瀏覽
讓我們先來看一下pem.h頭文件中的定義:

#define PEM_read_RSAPrivateKey(fp,x,cb,u) (RSA *)PEM_ASN1_read( \
        (char *(*)())d2i_RSAPrivateKey,PEM_STRING_RSA,fp,(char **)x,cb,u)
#define PEM_read_RSAPublicKey(fp,x,cb,u) (RSA *)PEM_ASN1_read( \
        (char *(*)())d2i_RSAPublicKey,PEM_STRING_RSA_PUBLIC,fp,(char **)x,cb,u)
        
#define PEM_read_bio_RSAPrivateKey(bp,x,cb,u) (RSA *)PEM_ASN1_read_bio( \
        (char *(*)())d2i_RSAPrivateKey,PEM_STRING_RSA,bp,(char **)x,cb,u)
#define PEM_read_bio_RSAPublicKey(bp,x,cb,u) (RSA *)PEM_ASN1_read_bio( \
        (char *(*)())d2i_RSAPublicKey,PEM_STRING_RSA_PUBLIC,bp,(char **)x,cb,u)

對應的很工整是不是,你生成一個私鑰,然后用它生成一個公鑰。
openssl genrsa -out private.pem 1024
openssl rsa -in priv.pem -pubout -out public.pem
用任何一種方法打開私鑰,讀取私鑰信息,得到RSA,查看RSA,ok,沒有問題,一切都還看起來比較正常。
然后用任何一種方法打開公鑰,讀取公鑰信息,問題出現(xiàn)了:RSA對象為空,你失敗了。

通過openssl的手冊和幫助,你會發(fā)現(xiàn)兩個函數(shù):
PEM_read_bio_RSA_PUBKEY()
PEM_read_RSA_PUBKEY()
他們才是你要找的對應的,而上面兩個函數(shù)是從任何.h里面找不到的,但是他們的確是真實存在的符號連接,在對應的.o文件中用objdump可以查看到他們的符號,很詭異!
現(xiàn)象描述完了,還未探其究竟。



本文來自ChinaUnix博客,如果查看原文請點:http://blog.chinaunix.net/u/1574/showart_2035483.html
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP