计算机安全学第四次实践作业

作业内容一:

用Python或Sage实现RSA算法的加密、解密、签名/验证签名

from random import randint

#gcd函数求最大公因子
def gcd(a,b):  
    if a%b == 0:  
        return b  
    else :  
        return gcd(b,a%b)
    
def is_prime(a):
    for i in range(2,a):
        if (a % i) == 0:
            return False
    return True

#扩展欧几里得算法
def extendedGCD(a, b):
    # a*xi + b*yi = ri
    if b == 0:
        return 1, 0, a
    x, y, r = extendedGCD(b, a%b)
    """
    gcd(a, b) = a*xi + b*yi
    gcd(b, a %  b) = b*xi+1 + (a - [a/b]*b)*yi+1
    gcd(a, b) = gcd(b, a %  b)   =>   a*xi + b*yi = a*yi+1 + b*(xi+1 - [a/b]*yi+1)
    xi = yi+1
    yi = xi+1 - [a/b]*yi+1
    """
    tmp = x
    x = y
    y = tmp - (a//b) * y
    return x, y, r

#选择素数p,q
def select_prime(halflength):
    while True:
        n = randint(0, 1 << int(halflength))
        if is_prime(n):
            return n

#构造公钥和秘钥
def createkeys(length):
    while True:
        p=select_prime(length//2)
        q=select_prime(length//2)
        if p!=q:
            break
    print("p=",p,"q=",q)
    n=p*q
    Euler_n=(p-1)*(q-1)
    while True:
        e = randint(0, 1 << int(length//2))
        x, y ,q = extendedGCD(e, Euler_n)
        if q == 1:
            break
    x,y,r=extendedGCD(Euler_n, e)
    if y < 0:
        d=Euler_n+y
    else:
        d=y
    return n,e,d

#明文加密
def encrypt(m,e,n):
    C=powmod(m,e,n)
    return C

#密文解密
def decrypt(c,d,n):
    M=powmod(c,d,n)
    return M

#幂模运算
def powmod(mn,ed,n):
    ret = 1
    mn = mn % n
    while ed > 0:
        if ed & 1:
            ret = (ret * mn) % n
        mn = (mn * mn) % n
        ed >>= 1
    return ret

#加解密
n,e,d=createkeys(1024) #16测试
M1=randint(0, 1 << 256) #8测试
C=encrypt(M1, e, n)
M2=decrypt(C, d, n)
print("e=",e,"d=",d,"n=",n)
print("原明文为:",M1)
print("加密后:",C)
print("解密后:",M2)
if M1==M2:
    print("M1=M2,RSA加解密成功")
else:
    print("RSA加解密不成功")
    
#签名和验证签名
sign=1 << 6
ensign=encrypt(sign, d, n)
verify=decrypt(ensign, e, n)
print("签名为:",sign)
print("签名加密:",ensign)
print("验证签名:",verify)
if sign==verify:
    print("RSA签名和验证签名成功")
else:
    print("RSA签名和验证签名不成功")

因为如果keys和明文太大的话我的系统很久都没跑出来,所以我把
n,e,d=createkeys(1024) #16测试
M1=randint(0, 1 << 256) #8测试
的1024和256分别改成16和8进行测试,以下是结果:


第四次实践作业1.PNG

作业内容二:

用Python或Sage实现DH秘钥交换协议

from random import randint

#随机产生一个素数
def prime():
    while True:
        q=randint(2,100)
        for i in range(2,q):
            if (q % i) == 0:
                break
        return q
    
#获得素数q的本原根a
def generator(q):
    generator=[]
    for a in range(2,q):
        for power in range(1,q):
            if (a ** power) % q == 1:
                break
        if power==q-1:
            generator.append(a)
    return generator
    
#计算Y
def getY(a,x,q):
    Y=(a**x)%q
    return Y
 
#计算K,获得密钥
def getK(Y,X,q):
    K=(Y**X)%q
    return K

#DH秘钥交换
q=prime()
generator=generator(q)
a=generator[-1]
print("q=",q,"a=",a)

XA=randint(1,q)
XB=randint(1,q)
print("XA=",XA,"XB=",XB)
YA=getY(a, XA, q)
YB=getY(a, XB, q)
print("YA=",YA,"YB=",YB)
KA=getK(YB, XA, q)
KB=getK(YA, XB, q)
print("KA=",KA,"KB=",KB)
if KA==KB:
    print("AB交换密钥成功")

运行结果:


第四次实践作业2.PNG
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,997评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,603评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,359评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,309评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,346评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,258评论 1 300
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,122评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,970评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,403评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,596评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,769评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,464评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,075评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,705评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,848评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,831评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,678评论 2 354

推荐阅读更多精彩内容