求一段能实现DH(Diffe-Hellman)算法的C++C源代码

求一段能实现DH(Diffe-Hellman)算法的C++C源代码,第1张

http://wenku.baidu.com/link?url=rCAD56c5q8_grQr1Cre1MJCin6F8cQnIYX1v6jxMlTaA8n9J6vxY9lgEo9fjxazxccKRrIAyZG8zmfRiP_shYoa9HY-ffODi9LrVnJ7wj4_

http://www.docin.com/p-5312518.html

我自己写了个DH秘钥的demo代码, 以前加密用过AES的加密,全套代码写下来太费时间又没技术含量。

如果你需要AES的加密代码可以留个邮箱给我。

public class Test1 {

public static final int P=30//公开的大家都知道的

public static final int G=9//公开的大家都知道的

public static void main(String[] args) {

A x = new A()

int one = x.getV()

//分割 A 代表A这边的系统加密  one 代表是给别人的值

B y = new B()

int two = y.getV()

//B 代表另外一边加密 two 代表是给别人的值

System.out.println(x.getKey(two))

System.out.println(y.getKey(one))

}

}

class A{

private int a//自己的私有密值,不会告诉任何人

public A() {

 Random r = new Random(200)

a=r.nextInt()

}

public int getV(){

return (Test1.G^a)%Test1.P

}

public int getKey(int v){

return (v^a)%Test1.P

}

}

class B{

private int b//自己的私有密值,不会告诉任何人

public B() {

Random r = new Random(200)

b=r.nextInt()

}

public int getV(){

return (Test1.G^b)%Test1.P

}

public int getKey(int v){

return (v^b)%Test1.P

}

}

本程序通过编译,运行正确

Code Segment

Assume CS:Code,DS:Code

CR equ 000DH

LF equ 000AH

KBBack equ 0008H

Name_Len equ 18 用户名最大长度

Pass_Len equ 8 密码最大长度

-------------------------------------

将用户名和密码定义为一个结构类型

User Struc 成绩单结构类型

User_Name db Name_Len dup(?) 用户名

Name_Lenth db ? 用户名实际长度

Pass_Word db Name_Len dup(?) 密码

Pass_Lenth db ? 密码实际长度

User EndS

-------------------------------------

功能:显示指定地址(Str_Addr)的字符串

入口:

Str_Addr=字符串地址(要求在数据段)

用法: Output Str_Addr

用法举例:Output PromptStr

Output MACRO Str_Addr

lea dx,Str_Addr

mov ah,9

int 21h

EndM

-------------------------------------

功能:取光标位置

入口:无

出口:DH=行号,DL=列号

GetCursor Proc Near

PUSH AX

PUSH BX

PUSH CX

PUSH DX

XOR BX,BX

MOV AH,3

INT 10H

MOV Cursor_Row,DH

MOV Cursor_Col,DL

POP DX

POP CX

POP BX

POP AX

RET

Cursor_Row DB ?

Cursor_Col DB ?

GetCursor EndP

-------------------------------------

功能:置光标位置

入口:Cursor_Row=行坐标Cursor_Col: 列坐标)

SetCursor Proc Near

PUSH DX

PUSH CX

PUSH BX

PUSH AX

MOV DH,Cursor_Row

MOV DL,Cursor_Col

XOR BX,BX

MOV AH,2

INT 10H

POP AX

POP BX

POP CX

POP DX

RET

SetCursor EndP

-------------------------------------

窗口上滚指定行数

Roll_Up Proc Near

xor bh,bh 显示页号

mov ah,8 读光标位置的字符和属性

int 10h

mov bh,ah 上滚窗口空行属性

mov cx,100h 左上角坐标

mov al,5

mov dx,54fh 右下角坐标

mov ah,6

int 10h

ret

Roll_Up EndP

-------------------------------------

功能:输入指定位数的用户密码,实际输入的密码字符以“*”显示,并有回空纠错功能

入口:di=密码输入缓冲区地址

出口:AL=实际输入的密码字符数

Input_PassW Proc Near

push di

mov cx,Pass_Len 密码最大长度

@@Input: call GetCursor 取光标位置

mov ah,7 从键盘接受一个字符

int 21h

cmp al,CR 回车符?

jz @@Calc_Chrs 是,结束密码输入,转去计算实际输入的密码字符数

cmp al,KBBack

jz @@KB_Back 若是回空键,重新输入

stosb 保存输入的字符

mov dl,'*'

mov ah,2

int 21h

jmp @@KBBack

@@KB_Back: dec Cursor_Col

inc cx

dec di

@@KBBack: inc Cursor_Col

call SetCursor 置光标位置

loop @@Input 接受下一个数字

@@Calc_Chrs:mov cx,di

pop di

sub cx,di

cmp cl,[si.Pass_Lenth]

jnz @@Pass_Err 密码长度不等

mov cl,[si.Pass_Lenth]

xor ch,ch

push si

lea si,[si.Pass_Word]

cld

repz cmpsb 比较密码是否正确

pop si

jcxz $+4

@@Pass_Err: clc 进位标志复位,表示密码不正确

ret

stc 进位标志置位,表示密码正确

ret

Input_PassW EndP

-------------------------------------

Again_Input Proc Near

Output Input_Again 提示:是否重新输入用户名

mov ah,1 从键盘接受一个字符

int 21h

or al,20h 转换成小写,大小写不敏感

cmp al,'y' 重新输入?

jnz $+7 不

call Roll_Up 窗口上滚指定行数

stc 进位标志置位,表示重复前面的 *** 作

ret

cmp al,'n' 不重新输入?

jnz Again_Input 不是,非有效字母,重新输入

clc 进位标志复位,表示放弃前面的 *** 作

ret

Again_Input EndP

-------------------------------------

Users equ 5 用户数

Even

User_Inform User <'richcon',7,'12345678',8>

User <'WangMing',8,'21345678',8>

User <'ZhangHongQiao',13,'13245678',8>

User <'LiYan',5,'12435678',8>

User <'XuPengYu',12,'12354678',8>

Prompt_User db 'User name: $'

Prompt_Word db 'Pass word: $'

Empty_Error db 7,CR,LF,CR,LF,'User name is empty.$'

Register_No db 7,CR,LF,CR,LF,'No register.$'

Pass_Error db 7,CR,LF,CR,LF,'Pass word error!$'

Welcome db 7,CR,LF,CR,LF,'WELCOME$',0

Input_Again db CR,LF,CR,LF,'Do you input user name again(y/n)?$'

Start: push cs

pop ds 使数据段与代码段同段

push cs

pop es 使附加段与代码段同段

Output Prompt_User 提示输入用户名

call GetCursor 取光标位置

Input_Name: call SetCursor 置光标位置

lea dx,Buffer 数据缓冲区地址

mov ah,0ah 键盘缓冲区输入

int 21h

lea si,Buffer[1] 实际输入的字符数地址

lodsb 取实际输入的字符数

test al,al 空串?

jnz Valid_Test 不是,检测输入的用户是否注册

Output Empty_Error 提示用户名为空

jmp Input_Name 重新输入用户名

Valid_Test: mov cx,Users 注册用户数

lea si,User_Inform 注册用户信息地址

Valid_Test0:cmp al,[si.Name_Lenth] 输入的用户名长度=用户名实际长度?

jnz Next_One 不相等,与下一个注册用户名比较

push cx

push si

lea si,[si.User_Name]

lea di,Buffer[2] 实际输入的用户名地址

mov cl,al

xor ch,ch

cld

repz cmpsb 比较用户名是否已注册

stc 进位标志置位,表示用户名已注册

jcxz $+3

clc 进位标志复位,表示用户名未注册

pop si

pop cx

jc Input_Pass 用户名已注册,转去输入用户密码

Next_One: add si,type User 下一个注册用户信息地址

loop Valid_Test0

Output Register_No 提示:非注册用户

call Again_Input 是否继续

jc Input_Name 进位标志置位,转去重新输入用户名

jmp Exit_Proc 不重新输入用户名,结束程序

Input_Pass: mov word ptr Cursor_Row,1

call SetCursor 置光标位置

Output Prompt_Word 提示输入密码

lea di,Buffer 密码缓冲区地址

call Input_PassW 输入密码

jc @@Welcome 密码输入正确,显示欢迎信息

Output Pass_Error 提示密码输入错误

call Again_Input 是否继续

jc Input_Pass 进位标志置位,转去重新输入密码

jmp Exit_Proc 不重新输入密码,结束程序

@@Welcome: Output Welcome 显示欢迎信息

Exit_Proc: mov ah,4ch 结束程序

int 21h

Buffer db 20 数据缓冲区

Code ENDS

END Start 编译到此结束


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11565504.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存