Cyber Posted November 16, 2007 Posted November 16, 2007 Hi! I must encrypt a string in autoit and in php I try yo use rc4 encryption (_StringEncrypt), but I don't found corresponding function for php you know encrypt function for both language? thanks! Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
SkinnyWhiteGuy Posted November 16, 2007 Posted November 16, 2007 _StringEncrypt() is "based on" RC4, not the actual RC4 implementation. Here's one version of RC4 for you:Func rc4($key, $value) Local $S[256], $i, $j, $c, $t, $x, $y, $output Local $keyLength = BinaryLen($key), $valLength = BinaryLen($value) For $i = 0 To 255 $S[$i] = $i Next For $i = 0 To 255 $j = Mod($j + $S[$i] + Dec(StringTrimLeft(BinaryMid($key, Mod($i, $keyLength)+1, 1),2)),256) $t = $S[$i] $S[$i] = $S[$j] $S[$j] = $t Next For $i = 1 To $valLength $x = Mod($x+1,256) $y = Mod($S[$x]+$y,256) $t = $S[$x] $S[$x] = $S[$y] $S[$y] = $t $j = Mod($S[$x]+$S[$y],256) $c = BitXOR(Dec(StringTrimLeft(BinaryMid($value, $i, 1),2)), $S[$j]) $output = Binary($output) & Binary('0x' & Hex($c,2)) Next Return $output EndFuncAs for PHP, did some googling (just cause I was curious, normally don't do other people's work for them) and found this at sourceforge: RC4CryptHope that helps, didn't try it yet, but I plan on playing with it.
Cyber Posted November 26, 2007 Author Posted November 26, 2007 FANTASTIC! Thanks! I try it! Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
Cyber Posted November 26, 2007 Author Posted November 26, 2007 its ok!!! THANKS!! and for encrypt? Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
SkinnyWhiteGuy Posted November 27, 2007 Posted November 27, 2007 It's the same function. RC4 is it's own encrypt/decrypt function, just rerun the results from an operation to see it go back the way it was to begin with. The function above does return a Binary, so to print it to the screen after decrypting, you'll need to send the output through BinaryToString(), but that's just to see the string as a string.
Moderators SmOke_N Posted November 27, 2007 Moderators Posted November 27, 2007 _StringEncrypt() is "based on" RC4, not the actual RC4 implementation. Here's one version of RC4 for you: Func rc4($key, $value) Local $S[256], $i, $j, $c, $t, $x, $y, $output Local $keyLength = BinaryLen($key), $valLength = BinaryLen($value) For $i = 0 To 255 $S[$i] = $i Next For $i = 0 To 255 $j = Mod($j + $S[$i] + Dec(StringTrimLeft(BinaryMid($key, Mod($i, $keyLength)+1, 1),2)),256) $t = $S[$i] $S[$i] = $S[$j] $S[$j] = $t Next For $i = 1 To $valLength $x = Mod($x+1,256) $y = Mod($S[$x]+$y,256) $t = $S[$x] $S[$x] = $S[$y] $S[$y] = $t $j = Mod($S[$x]+$S[$y],256) $c = BitXOR(Dec(StringTrimLeft(BinaryMid($value, $i, 1),2)), $S[$j]) $output = Binary($output) & Binary('0x' & Hex($c,2)) Next Return $output EndFunc As for PHP, did some googling (just cause I was curious, normally don't do other people's work for them) and found this at sourceforge: RC4Crypt Hope that helps, didn't try it yet, but I plan on playing with it.Interesting... http://www.autoitscript.com/forum/index.ph...st&p=316133 Common sense plays a role in the basics of understanding AutoIt... If you're lacking in that, do us all a favor, and step away from the computer.
PsaltyDS Posted November 27, 2007 Posted November 27, 2007 _StringEncrypt() is "based on" RC4, not the actual RC4 implementation. Here's one version of RC4 for you: Func rc4($key, $value) Local $S[256], $i, $j, $c, $t, $x, $y, $output Local $keyLength = BinaryLen($key), $valLength = BinaryLen($value) For $i = 0 To 255 $S[$i] = $i Next For $i = 0 To 255 $j = Mod($j + $S[$i] + Dec(StringTrimLeft(BinaryMid($key, Mod($i, $keyLength)+1, 1),2)),256) $t = $S[$i] $S[$i] = $S[$j] $S[$j] = $t Next For $i = 1 To $valLength $x = Mod($x+1,256) $y = Mod($S[$x]+$y,256) $t = $S[$x] $S[$x] = $S[$y] $S[$y] = $t $j = Mod($S[$x]+$S[$y],256) $c = BitXOR(Dec(StringTrimLeft(BinaryMid($value, $i, 1),2)), $S[$j]) $output = Binary($output) & Binary('0x' & Hex($c,2)) Next Return $output EndFunc Thanks again for the nice, clean function! Valuater's AutoIt 1-2-3, Class... Is now in Session!For those who want somebody to write the script for them: RentACoder"Any technology distinguishable from magic is insufficiently advanced." -- Geek's corollary to Clarke's law
PsaltyDS Posted November 27, 2007 Posted November 27, 2007 Interesting... http://www.autoitscript.com/forum/index.ph...st&p=316133 @SmOke_N: I don't think that version works, as far as compatible functionality with other standard implementations. It does not reproduce benchmark results. This was my test script: expandcollapse popup$sString = "Now is the time for all good men to come to the aid of their country." $sKeyPhrase = "This is my key phrase." $sCrypt = _RC4EncDec($sString, $sKeyPhrase) ConsoleWrite("Debug: $sCrypt = " & $sCrypt & @LF) $sString = _RC4EncDec($sCrypt, $sKeyPhrase) ConsoleWrite("Debug: $sString = " & BinaryToString($sString) & @LF) #cs Test code vectors from Wikipedia: http://en.wikipedia.org/wiki/_RC4EncDec _RC4EncDec( "Key", "Plaintext" ) == BBF316E8D940AF0AD3 _RC4EncDec( "Wiki", "pedia" ) == 1021BF0420 _RC4EncDec( "Secret", "Attack at dawn" ) == 45A01F645FC35B383552544B9BF5 #ce ConsoleWrite('Debug: "Key"/"Plaintext" = ' & _RC4EncDec("Plaintext", "Key") & @LF) ConsoleWrite('Debug: "Wiki"/"pedia" = ' & _RC4EncDec("pedia", "Wiki") & @LF) ConsoleWrite('Debug: "Secret"/"Attack at dawn" = ' & _RC4EncDec("Attack at dawn", "Secret") & @LF) ; ------------------------------------------------------- ; Function: _RC4EncDec ; Purpose: An encryption/decryption _RC4EncDec implementation in AutoIt ; Syntax: _RC4EncDec($sData, $sKey) ; Where: $sData = value to be encrypted/decrypted ; $sKey = encrypt/decrypt key ; On success returns encrypted/decrypted version of $sData ; Author: SmOke_N on the AutoIt forums at www.autoitscript.com/forum ; Notes: The same function encrypts and decrypts $value. ; ------------------------------------------------------- Func _RC4EncDec($sData, $sKey) If $sData = '' Or $sKey = '' Then Return '' Local $aState[256], $nKeyLength = StringLen($sKey), $nDataLength = StringLen($sData) Local $sMid, $iIndex, $xCC = 0, $yCC = 0, $sResult = '', $sSwap For $iCC = 0 To 255 $aState[$iCC] = $iCC Next For $iCC = 0 To 255 $sMid = StringMid($sKey, Mod($iCC, $nKeyLength) + 1, 1) $iIndex = Mod(Asc($sMid) + $aState[$iCC] + $iIndex, 256) $sSwap = $aState[$iCC] $aState[$iCC] = $aState[$iIndex] $aState[$iIndex] = $sSwap Next For $iCC = 1 To $nDataLength $xCC = Mod($xCC + 1, 256) $yCC = Mod($aState[$xCC] + $yCC, 256) $sSwap = $aState[$xCC] $aState[$xCC] = $aState[$yCC] $aState[$yCC] = $sSwap $iIndex = Mod($aState[$xCC] + $aState[$yCC], 256) $sMid = BitXOR(Asc(StringMid($sData, $iCC, 1)), $aState[$iIndex]) $sResult &= Chr($sMid) Next Return SetError(@error, @extended, $sResult) EndFunc Output: Debug: $sCrypt = jÒÚ¸Nqâ¢I×aïºS#bT H Debug: $sString = Now is the time for all good men to come to the aid of their country. Debug: "Key"/"Plaintext" = »óèÙ@¯Ó Debug: "Wiki"/"pedia" = !¿ Debug: "Secret"/"Attack at dawn" = E d_Ã[85RTKõ Valuater's AutoIt 1-2-3, Class... Is now in Session!For those who want somebody to write the script for them: RentACoder"Any technology distinguishable from magic is insufficiently advanced." -- Geek's corollary to Clarke's law
Moderators SmOke_N Posted November 27, 2007 Moderators Posted November 27, 2007 @SmOke_N: I don't think that version works, as far as compatible functionality with other standard implementations. It does not reproduce benchmark results. This was my test script: expandcollapse popup$sString = "Now is the time for all good men to come to the aid of their country." $sKeyPhrase = "This is my key phrase." $sCrypt = _RC4EncDec($sString, $sKeyPhrase) ConsoleWrite("Debug: $sCrypt = " & $sCrypt & @LF) $sString = _RC4EncDec($sCrypt, $sKeyPhrase) ConsoleWrite("Debug: $sString = " & BinaryToString($sString) & @LF) #cs Test code vectors from Wikipedia: http://en.wikipedia.org/wiki/_RC4EncDec _RC4EncDec( "Key", "Plaintext" ) == BBF316E8D940AF0AD3 _RC4EncDec( "Wiki", "pedia" ) == 1021BF0420 _RC4EncDec( "Secret", "Attack at dawn" ) == 45A01F645FC35B383552544B9BF5 #ce ConsoleWrite('Debug: "Key"/"Plaintext" = ' & _RC4EncDec("Plaintext", "Key") & @LF) ConsoleWrite('Debug: "Wiki"/"pedia" = ' & _RC4EncDec("pedia", "Wiki") & @LF) ConsoleWrite('Debug: "Secret"/"Attack at dawn" = ' & _RC4EncDec("Attack at dawn", "Secret") & @LF) ; ------------------------------------------------------- ; Function: _RC4EncDec ; Purpose: An encryption/decryption _RC4EncDec implementation in AutoIt ; Syntax: _RC4EncDec($sData, $sKey) ; Where: $sData = value to be encrypted/decrypted ; $sKey = encrypt/decrypt key ; On success returns encrypted/decrypted version of $sData ; Author: SmOke_N on the AutoIt forums at www.autoitscript.com/forum ; Notes: The same function encrypts and decrypts $value. ; ------------------------------------------------------- Func _RC4EncDec($sData, $sKey) If $sData = '' Or $sKey = '' Then Return '' Local $aState[256], $nKeyLength = StringLen($sKey), $nDataLength = StringLen($sData) Local $sMid, $iIndex, $xCC = 0, $yCC = 0, $sResult = '', $sSwap For $iCC = 0 To 255 $aState[$iCC] = $iCC Next For $iCC = 0 To 255 $sMid = StringMid($sKey, Mod($iCC, $nKeyLength) + 1, 1) $iIndex = Mod(Asc($sMid) + $aState[$iCC] + $iIndex, 256) $sSwap = $aState[$iCC] $aState[$iCC] = $aState[$iIndex] $aState[$iIndex] = $sSwap Next For $iCC = 1 To $nDataLength $xCC = Mod($xCC + 1, 256) $yCC = Mod($aState[$xCC] + $yCC, 256) $sSwap = $aState[$xCC] $aState[$xCC] = $aState[$yCC] $aState[$yCC] = $sSwap $iIndex = Mod($aState[$xCC] + $aState[$yCC], 256) $sMid = BitXOR(Asc(StringMid($sData, $iCC, 1)), $aState[$iIndex]) $sResult &= Chr($sMid) Next Return SetError(@error, @extended, $sResult) EndFuncoÝ÷ Øë¦ë¡×y» çÍ7êÀ«Ê Common sense plays a role in the basics of understanding AutoIt... If you're lacking in that, do us all a favor, and step away from the computer.
PsaltyDS Posted November 27, 2007 Posted November 27, 2007 (edited) Ummm... mine doesn't return a binary or hex... it returns the actual string... maybe take a look at the comparison if you change it to fit the test you gave it:Very true, and it's nicely done, but that makes it a string-only function (without external conversion), which makes it inherently incompatible with other "standard" implementations of RC4. All the examples you find for PHP, Perl, etc. are binary streams. The implementation posted by SkinnyWhiteGuy deals in binaries (BinLen(), BinMid(), etc.). Making yours string-based makes it like the existing _StringEncrypt() UDF, but not "standard" RC4. Since the OP was about a standard implementation in AutoIt that would match data with a PHP implementation, SkinnyWhiteGuy's version meets the specs. Edited November 27, 2007 by PsaltyDS Valuater's AutoIt 1-2-3, Class... Is now in Session!For those who want somebody to write the script for them: RentACoder"Any technology distinguishable from magic is insufficiently advanced." -- Geek's corollary to Clarke's law
Moderators SmOke_N Posted November 27, 2007 Moderators Posted November 27, 2007 Since the OP was about a standard implementation in AutoIt that would match data with a PHP implementation, SkinnyWhiteGuy's version meets the specs. If you note, I wasn't talking to the OP... I was showing how interesting it was that he took an approach I made (that I hadn't seen until I made it) before. Common sense plays a role in the basics of understanding AutoIt... If you're lacking in that, do us all a favor, and step away from the computer.
Cyber Posted November 28, 2007 Author Posted November 28, 2007 FANTASTIC! THANKS!!! Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
Cyber Posted November 28, 2007 Author Posted November 28, 2007 why not? $sString = "Now is the time for all good men to come to the aid of their country." $sKey = "This is my key phrase." $sCrypt = rc4($sKey, $sString) $sString = rc4($sKey, $sCrypt) STRING: BinaryToString($sString) $bh = StringToBinary($sString) $reString = rc4($sKey, $bh) Why $reString <> $sString? Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
PsaltyDS Posted November 28, 2007 Posted November 28, 2007 why not? $sString = "Now is the time for all good men to come to the aid of their country." $sKey = "This is my key phrase." $sCrypt = rc4($sKey, $sString) $sString = rc4($sKey, $sCrypt) STRING: BinaryToString($sString) $bh = StringToBinary($sString) $reString = rc4($sKey, $bh) Why $reString <> $sString? Did you really put "STRING: " in your code? If not, where exactly is the problem? This seems to work fine: expandcollapse popup$sString = "Now is the time for all good men to come to the aid of their country." ; plain string $sKey = "This is my key phrase." $sCrypt = rc4($sKey, $sString) ; encrypted binary ConsoleWrite("Debug: $sCrypt = " & $sCrypt & @LF) $sString = rc4($sKey, $sCrypt) ; decrypted binary ConsoleWrite("Debug: $sString = " & $sString & @LF) $sString = BinaryToString($sString) ; plain string ConsoleWrite("Debug: $sString = " & $sString & @LF) $bh = StringToBinary($sString) ; plain binary ConsoleWrite("Debug: $bh = " & $bh & @LF) $reString = rc4($sKey, $bh) ; encrypted binary ConsoleWrite("Debug: $reString = " & $reString & @LF) $reString = rc4($sKey, $reString) ; decrypted binary ConsoleWrite("Debug: $reString = " & $reString & @LF) $reString = BinaryToString($reString) ; plain string ConsoleWrite("Debug: $reString = " & $reString & @LF) ; ------------------------------------------------------- ; Function: rc4 ; Purpose: An encryption/decryption RC4 implementation in AutoIt ; Syntax: rc4($key, $value) ; Where: $key = encrypt/decrypt key ; $value = value to be encrypted/decrypted ; On success returns encrypted/decrypted version of $value ; Author: SkinnyWhiteGuy on the AutoIt forums at www.autoitscript.com/forum ; Notes: The same function encrypts and decrypts $value. ; ------------------------------------------------------- Func rc4($key, $value) Local $S[256], $i, $j, $c, $t, $x, $y, $output Local $keyLength = BinaryLen($key), $valLength = BinaryLen($value) For $i = 0 To 255 $S[$i] = $i Next For $i = 0 To 255 $j = Mod($j + $S[$i] + Dec(StringTrimLeft(BinaryMid($key, Mod($i, $keyLength) + 1, 1), 2)), 256) $t = $S[$i] $S[$i] = $S[$j] $S[$j] = $t Next For $i = 1 To $valLength $x = Mod($x + 1, 256) $y = Mod($S[$x] + $y, 256) $t = $S[$x] $S[$x] = $S[$y] $S[$y] = $t $j = Mod($S[$x] + $S[$y], 256) $c = BitXOR(Dec(StringTrimLeft(BinaryMid($value, $i, 1), 2)), $S[$j]) $output = Binary($output) & Binary('0x' & Hex($c, 2)) Next Return $output EndFunc ;==>rc4 Valuater's AutoIt 1-2-3, Class... Is now in Session!For those who want somebody to write the script for them: RentACoder"Any technology distinguishable from magic is insufficiently advanced." -- Geek's corollary to Clarke's law
SkinnyWhiteGuy Posted November 28, 2007 Posted November 28, 2007 That is very interesting, I just took what I found on Wikipedia, and put in in AutoIt code. I had never seen your version of it before SmOke_N. If I had, I'd have saved myself some trouble and just swapped the parts in it from String() to Binary() stuff. Main reason I do that is to avoid any troubles with the end result returning something that has a Chr(0) in the middle of it, which would throw off storing/retrieving all the resulting encryption. I had that problem before with AES, so I just avoid it from now on by dealing with Binaries as much as possible. Not to mention you can pass in either a string or a binary, and it will work on either one just fine.
Cyber Posted November 29, 2007 Author Posted November 29, 2007 AUTOIT PAGE: ConsoleWrite("Debug: $sString = " & $sString & @LF) $bh = StringToBinary($sString) ; plain binary ConsoleWrite("Debug: $bh = " & $bh & @LF) $reString = rc4($sKey, $bh) ; encrypted binary ConsoleWrite("Debug: $reString = " & $reString & @LF) SEND TO PHP PAGE PHP PAGE: $reString = rc4($sKey, $reString) ; decrypted binary ConsoleWrite("Debug: $reString = " & $reString & @LF) $reString = BinaryToString($reString) ; plain string ConsoleWrite("Debug: $reString = " & $reString & @LF) correct? Why i can integrate binary in rc4 function? Thanks bear with me Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
PsaltyDS Posted November 29, 2007 Posted November 29, 2007 AUTOIT PAGE:ConsoleWrite("Debug: $sString = " & $sString & @LF)$bh = StringToBinary($sString) ; plain binaryConsoleWrite("Debug: $bh = " & $bh & @LF)$reString = rc4($sKey, $bh) ; encrypted binaryConsoleWrite("Debug: $reString = " & $reString & @LF)SEND TO PHP PAGEPHP PAGE:$reString = rc4($sKey, $reString) ; decrypted binaryConsoleWrite("Debug: $reString = " & $reString & @LF)$reString = BinaryToString($reString) ; plain stringConsoleWrite("Debug: $reString = " & $reString & @LF)correct?Why i can integrate binary in rc4 function? Thanks bear with me I'm not absolutely sure what you're asking here. But PHP probably does variable typing differently than AutoIt (where everything is a 'Variant'). When you take something in AutoIt, pass it to PHP, then get stuff from PHP back to AutoIt, there are some opportunities for variable types to get mixed. Just a guess, as I have no PHP page to test with... Valuater's AutoIt 1-2-3, Class... Is now in Session!For those who want somebody to write the script for them: RentACoder"Any technology distinguishable from magic is insufficiently advanced." -- Geek's corollary to Clarke's law
Cyber Posted November 30, 2007 Author Posted November 30, 2007 If you have time for help me http://www.colcyber.com/macro/rc4/rc4test.php?pwd=[password]&data=[string]Thanks Console Browse: Navigate on the WEB in a textual consoleMultiPing!: Show computer on the lan and/or show the local/remote task, ALL animated!KillaWin: Event executingCryptPage: Crypt your webpage and show only with key
PsaltyDS Posted November 30, 2007 Posted November 30, 2007 If you have time for help me http://www.colcyber.com/macro/rc4/rc4test.php?pwd=[password]&data=[string] Thanks I ran ?pwd=Test&data=Testing and got: Original Data : Testing Encrypted Data (using Hex Key) : edea724dc24c60 Decrypted Data (using Hex Key) : Testing Encrypted Data (using Key as is) : 2e0b3e3c2b5569 Decrypted Data (using Key as is) : Testing Now, being displayed on a web page means the encrypted binary data are being converted to strings, of course. Valuater's AutoIt 1-2-3, Class... Is now in Session!For those who want somebody to write the script for them: RentACoder"Any technology distinguishable from magic is insufficiently advanced." -- Geek's corollary to Clarke's law
LWC Posted September 9, 2010 Posted September 9, 2010 (edited) Please let me ask a question with the same subject: $secret=_StringEncrypt(1, $input, $pass)) $url="http://whatever/decrypt.php?code=" & $secret $content=BinaryToString(InetRead($url)) What do I put in decrypt.php (assuming it too knows the $pass) to decrypt the code in PHP? Yes, I can use $url="http://whatever/decrypt.php?code=" & _StringEncrypt(0, $secret, $pass) But that means transmitting the code in open space. Thanks! Edited September 9, 2010 by LWC
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now