php - Blowfish 解密/ ActionScript 3 (AS3Crypto)

标签 php flash encryption blowfish as3crypto

我尝试使用 Blowfish (CBC) 技术对从 PHP 到 Flash 的文本进行加密/解密。 经过几个小时的调查和研究,我了解到 AS3Crypto 可以用于解密 Blowfish(CBC 模式)。 在一个简单的示例中,我使用 Mcrypt(PHP 库)来加密文本:

const CYPHER = 'blowfish';
const MODE   = 'cbc';
const KEY    = '12345';
    public function encrypt($plaintext)
{
    $td = mcrypt_module_open(self::CYPHER, '', self::MODE, '');
    $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
    mcrypt_generic_init($td, self::KEY, $iv);
    $crypttext = mcrypt_generic($td, $plaintext);
    mcrypt_generic_deinit($td);
    return $iv.$crypttext;
}

然后,我可以通过使用 Base64 编码来传输输出。 例如,如果我们的原始文本为(不带引号)“stackoverflow”, key 为“123456”,则输出将为(base64):

MUXl8mBS9OsvxTbLAiCrRAMp851L8vVD0

目前为止没有任何问题。 现在,当我将这段编码文本转移到 flash 时,我可以毫无问题地获取它。 您可以尝试转到http://crypto.hurlant.com/demo/CryptoDemo.swf,然后选择“ key ”选项卡,然后选择加密为“Blowfish”,模式为“CBC”,填充为“无”并勾选“在密文前添加IV”选项。之后,您可以使用 key 成功解密上面的文本,并再次获取“stackoverflow”文本。

所以,到目前为止我知道可以从 Mcrypt 转换为 AS3Crypt,然后我尝试在 flash 中使用 AS3Crypto 库(您可以从:http://code.google.com/p/as3crypto/ 获取它)。

我制作了一个新的 ActionScript 文件,其中包含以下内容来测试加密是否相同(由于主要问题,我无法弄清楚如何解密它):

package
{
    import com.hurlant.crypto.Crypto;
    import com.hurlant.util.Hex;    
    import com.hurlant.crypto.hash.HMAC;
    import com.hurlant.crypto.hash.IHash;
    import com.hurlant.crypto.hash.MD5;
    import com.hurlant.crypto.hash.SHA1;
    import com.hurlant.crypto.hash.SHA224;
    import com.hurlant.crypto.hash.SHA256;
    import com.hurlant.crypto.prng.ARC4;
    import com.hurlant.crypto.symmetric.AESKey;
    import com.hurlant.crypto.symmetric.BlowFishKey;
    import com.hurlant.crypto.symmetric.CBCMode;
    import com.hurlant.crypto.symmetric.CFB8Mode;
    import com.hurlant.crypto.symmetric.CFBMode;
    import com.hurlant.crypto.symmetric.CTRMode;
    import com.hurlant.crypto.symmetric.DESKey;
    import com.hurlant.crypto.symmetric.ECBMode;
    import com.hurlant.crypto.symmetric.ICipher;
    import com.hurlant.crypto.symmetric.IMode;
    import com.hurlant.crypto.symmetric.IPad;
    import com.hurlant.crypto.symmetric.ISymmetricKey;
    import com.hurlant.crypto.symmetric.IVMode;
    import com.hurlant.crypto.symmetric.NullPad;
    import com.hurlant.crypto.symmetric.OFBMode;
    import com.hurlant.crypto.symmetric.PKCS5;
    import com.hurlant.crypto.symmetric.SimpleIVMode;
    import com.hurlant.crypto.symmetric.TripleDESKey;
    import com.hurlant.crypto.symmetric.XTeaKey;
    import flash.utils.ByteArray;
    import com.hurlant.crypto.rsa.RSAKey;
    import com.hurlant.util.Base64;

 public class BlowFish
 {
 /**
 * Encrypts a string.
 * @param text  The text string to encrypt.
 * @param key  A cipher key to encrypt the text with.
 */


 /**
 * Decrypts an encrypted string.
 * @param text  The text string to decrypt.
 * @param key  The key used while originally encrypting the text.
 */
  static public function encrypt( s :String, k :String ) :String 
 {

    var key  :ByteArray = Hex.toArray(k);
            var data :ByteArray = Hex.toArray(Hex.fromString(s));

            var pad    :IPad = new NullPad();
            var cipher :ICipher = Crypto.getCipher("blowfish-cbc", key, pad);

            pad.setBlockSize(cipher.getBlockSize());
            cipher.encrypt(data);

            var result :String = Hex.fromArray(data);

            var ivmode :IVMode = cipher as IVMode;
            var iv     :String = Hex.fromArray(ivmode.IV);

            return  Base64.encodeByteArray(Hex.toArray(Hex.fromArray(ivmode.IV) + Hex.fromArray(data)));

 }

 }
}

我使用以下代码来获取结果:

import BlowFish;
var $key:String = "123456";
var $encryption:String = BlowFish.encrypt("stackoverflow", $key);

trace( $encryption );

问题是我无法将以下输出匹配在一起。 我对actionscript一无所知,所以你显然会发现其中有很多错误。

我将非常感谢任何解释和解决方案,并举例说明如何使用 AS3Crypto 成功解密闪存中的加密文本。

谢谢。

最佳答案

希望这对您有帮助:

public static function encryptString(encString : String = "") : String
{
    var kdata : ByteArray = Hex.toArray(Hex.fromString(k))
    var _method : String  = "simple-blowfish-ecb";
    var pad : IPad        = new NullPad;
    var crypt : ICipher   = Crypto.getCipher(_method, kdata, pad);
    var data : ByteArray  = Hex.toArray(Hex.fromString(encString));
    pad.setBlockSize(crypt.getBlockSize());
    crypt.encrypt(data);
    encString = Base64.encodeByteArray(data);
    return encString;
}

关于php - Blowfish 解密/ ActionScript 3 (AS3Crypto),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9750637/

相关文章:

android - 如何让 Eclipse 识别 Android 项目中的加密算法

javascript - 使用 PHP 和 AJAX 获取页面名称而不是页码

php - 排序 MongoDB 结果

javascript - 在多个 if 中启用 javascript?

javascript - 如何在 google.visualization 图表中使用 javascript 数组元素

apache-flex - 强制编译时链接 SWC 中的所有类

flash - 如何在AS3中修改运动跟踪

html - 变形验证码的想法

c# - 我应该如何/应该使用 RSA 加密可变大小的数据 (RSACryptoServiceProvider)

postgresql - 如何使用 PostgreSQL 加密密码?