分享
 
 
 

在ASP中实现RsA加密与解密

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

文章有两文件组成,test.asp 测试演示文件;clsrsa.asp 实现rsa加密与解密的vbs类文件

下面是代码:

1. test.asp

<%

rem 文章标题:在asp中通过vbs类实现rsa加密与解密

%>

<%Option Explicit%>

<!--#INCLUDE FILE="clsRSA.asp"-->

<%

Dim LngKeyE

Dim LngKeyD

Dim LngKeyN

Dim StrMessage

Dim ObjRSA

If Not Request.Form = "" Then

LngKeyE = Request.Form("KeyE")

LngKeyD = Request.Form("KeyD")

LngKeyN = Request.Form("KeyN")

StrMessage = Request.Form("Message")

Set ObjRSA = New clsRSA

Select Case Request.Form("Action")

Case "Generate Keys"

Call ObjRSA.GenKey()

LngKeyE = ObjRSA.PublicKey

LngKeyD = ObjRSA.PrivateKey

LngKeyN = ObjRSA.Modulus

Case "Encrypt"

ObjRSA.PublicKey = LngKeyE

ObjRSA.Modulus = LngKeyN

StrMessage = ObjRSA.Encode(StrMessage)

Case "Decrypt"

ObjRSA.PrivateKey = LngKeyD

ObjRSA.Modulus = LngKeyN

StrMessage = ObjRSA.Decode(StrMessage)

End Select

Set ObjRSA = Nothing

End If

%>

<HTML>

<HEAD>

<TITLE>RSA Cipher Demonstration</TITLE>

</HEAD>

<BODY>

<H1>RSA Cipher Demonstration</H1>

<P>

You will first need to generate your public/privage key-pair

before you can encrypt/decrypt messages.

</P>

<FORM method="post">

<TABLE>

<TR>

<TD>Public Key</TD>

<TD><INPUT name="KeyE" value="<%=Server.HTMLEncode(LngKeyE)%>"></TD>

<TD rowspan="3">

<INPUT type="Submit" name="Action" value="Generate Keys">

</TD>

</TR>

<TR>

<TD>Private Key</TD>

<TD><INPUT name="KeyD" value="<%=Server.HTMLEncode(LngKeyD)%>"></TD>

</TR>

<TR>

<TD>Modulus</TD>

<TD><INPUT name="KeyN" value="<%=Server.HTMLEncode(LngKeyN)%>"></TD>

</TR>

<TR>

<TD colspan="3">

Test Message:<BR>

<TEXTAREA name="Message" cols="50" rows="7"><%=Server.HTMLEncode(StrMessage)%></TEXTAREA>

</TD>

</TR>

<TR>

<TD align="right" colspan="3">

<INPUT type="Submit" name="Action" value="Encrypt">

<INPUT type="Submit" name="Action" value="Decrypt">

</TD>

</TR>

</TABLE>

</FORM>

</BODY>

</HTML>

clsrsa.asp

<%

rem 实现rsa加密与解密的vbs类文件

rem 文章标题:在asp中通过vbs类实现rsa加密与解密

' RSA Encryption Class

'

' .PrivateKey

' Your personal private key. Keep this hidden.

'

' .PublicKey

' Key for others to encrypt data with.

'

' .Modulus

' Used with both public and private keys when encrypting

' and decrypting data.

'

' .GenKey()

' Creates Public/Private key set and Modulus

'

' .Crypt(pLngMessage, pLngKey)

' Encrypts/Decrypts message and returns

' as a string.

'

' .Encode(pStrMessage)

' Encrypts message and returns in double-hex format

'

' .Decode(pStrMessage)

' Decrypts message from double-hex format and returns a string

'

Class clsRSA

Public PrivateKey

Public PublicKey

Public Modulus

Public Sub GenKey()

Dim lLngPhi

Dim q

Dim p

Randomize

Do

Do

' 2 random primary numbers (0 to 1000)

Do

p = Rnd * 1000 \ 1

Loop While Not IsPrime(p)

Do

q = Rnd * 1000 \ 1

Loop While Not IsPrime(q)

' n = product of 2 primes

Modulus = p * q \ 1

' random decryptor (2 to n)

PrivateKey = Rnd * (Modulus - 2) \ 1 + 2

lLngPhi = (p - 1) * (q - 1) \ 1

PublicKey = Euler(lLngPhi, PrivateKey)

Loop While PublicKey = 0 Or PublicKey = 1

' Loop if we can't crypt/decrypt a byte

Loop While Not TestCrypt(255)

End Sub

Private Function TestCrypt(ByRef pBytData)

Dim lStrCrypted

lStrCrypted = Crypt(pBytData, PublicKey)

TestCrypt = Crypt(lStrCrypted, PrivateKey) = pBytData

End Function

Private Function Euler(ByRef pLngPHI, ByRef pLngKey)

Dim lLngR(3)

Dim lLngP(3)

Dim lLngQ(3)

Dim lLngCounter

Dim lLngResult

Euler = 0

lLngR(1) = pLngPHI: lLngR(0) = pLngKey

lLngP(1) = 0: lLngP(0) = 1

lLngQ(1) = 2: lLngQ(0) = 0

lLngCounter = -1

Do Until lLngR(0) = 0

lLngR(2) = lLngR(1): lLngR(1) = lLngR(0)

lLngP(2) = lLngP(1): lLngP(1) = lLngP(0)

lLngQ(2) = lLngQ(1): lLngQ(1) = lLngQ(0)

lLngCounter = lLngCounter + 1

lLngR(0) = lLngR(2) Mod lLngR(1)

lLngP(0) = ((lLngR(2)\lLngR(1)) * lLngP(1)) + lLngP(2)

lLngQ(0) = ((lLngR(2)\lLngR(1)) * lLngQ(1)) + lLngQ(2)

Loop

lLngResult = (pLngKey * lLngP(1)) - (pLngPHI * lLngQ(1))

If lLngResult > 0 Then

Euler = lLngP(1)

Else

Euler = Abs(lLngP(1)) + pLngPHI

End If

End Function

Public Function Crypt(pLngMessage, pLngKey)

On Error Resume Next

Dim lLngMod

Dim lLngResult

Dim lLngIndex

If pLngKey Mod 2 = 0 Then

lLngResult = 1

For lLngIndex = 1 To pLngKey / 2

lLngMod = (pLngMessage ^ 2) Mod Modulus

' Mod may error on key generation

lLngResult = (lLngMod * lLngResult) Mod Modulus

If Err Then Exit Function

Next

Else

lLngResult = pLngMessage

For lLngIndex = 1 To pLngKey / 2

lLngMod = (pLngMessage ^ 2) Mod Modulus

On Error Resume Next

' Mod may error on key generation

lLngResult = (lLngMod * lLngResult) Mod Modulus

If Err Then Exit Function

Next

End If

Crypt = lLngResult

End Function

Private Function IsPrime(ByRef pLngNumber)

Dim lLngSquare

Dim lLngIndex

IsPrime = False

If pLngNumber < 2 Then Exit Function

If pLngNumber Mod 2 = 0 Then Exit Function

lLngSquare = Sqr(pLngNumber)

For lLngIndex = 3 To lLngSquare Step 2

If pLngNumber Mod lLngIndex = 0 Then Exit Function

Next

IsPrime = True

End Function

Public Function Encode(ByVal pStrMessage)

Dim lLngIndex

Dim lLngMaxIndex

Dim lBytAscii

Dim lLngEncrypted

lLngMaxIndex = Len(pStrMessage)

If lLngMaxIndex = 0 Then Exit Function

For lLngIndex = 1 To lLngMaxIndex

lBytAscii = Asc(Mid(pStrMessage, lLngIndex, 1))

lLngEncrypted = Crypt(lBytAscii, PublicKey)

Encode = Encode & NumberToHex(lLngEncrypted, 4)

Next

End Function

Public Function Decode(ByVal pStrMessage)

Dim lBytAscii

Dim lLngIndex

Dim lLngMaxIndex

Dim lLngEncryptedData

Decode = ""

lLngMaxIndex = Len(pStrMessage)

For lLngIndex = 1 To lLngMaxIndex Step 4

lLngEncryptedData = HexToNumber(Mid(pStrMessage, lLngIndex, 4))

lBytAscii = Crypt(lLngEncryptedData, PrivateKey)

Decode = Decode & Chr(lBytAscii)

Next

End Function

Private Function NumberToHex(ByRef pLngNumber, ByRef pLngLength)

NumberToHex = Right(String(pLngLength, "0") & Hex(pLngNumber), pLngLength)

End Function

Private Function HexToNumber(ByRef pStrHex)

HexToNumber = CLng("&h" & pStrHex)

End Function

End Class

%>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有