Пример #1
0
 static function encrypt($str, $key)
 {
     $size = mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_CBC);
     $str = self::pkcs5Pad($str, $size);
     $bin = mcrypt_cbc(MCRYPT_DES, $key, $str, MCRYPT_ENCRYPT, $key);
     return bin2hex($bin);
 }
Пример #2
0
function decrypt($str, $key)
{
    $str = mcrypt_decrypt(MCRYPT_DES, $key, base64_decode($str), MCRYPT_MODE_ECB);
    $block = mcrypt_get_block_size('des', 'ecb');
    $pad = ord($str[($len = strlen($str)) - 1]);
    return substr($str, 0, strlen($str) - $pad);
}
Пример #3
0
 private function PaddingPKCS7($data)
 {
     $block_size = mcrypt_get_block_size('tripledes', 'cbc');
     $padding_char = $block_size - strlen($data) % $block_size;
     $data .= str_repeat(chr($padding_char), $padding_char);
     return $data;
 }
Пример #4
0
 /**
  * 对明文进行加密
  * @param string $text 需要加密的明文
  * @return string 加密后的密文
  */
 public function encrypt($text, $appid)
 {
     try {
         //获得16位随机字符串,填充到明文之前
         $random = $this->getRandomStr();
         $text = $random . pack("N", strlen($text)) . $text . $appid;
         // 网络字节序
         $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
         $module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
         $iv = substr($this->key, 0, 16);
         //使用自定义的填充方式对明文进行补位填充
         $pkc_encoder = new PKCS7Encoder();
         $text = $pkc_encoder->encode($text);
         mcrypt_generic_init($module, $this->key, $iv);
         //加密
         $encrypted = mcrypt_generic($module, $text);
         mcrypt_generic_deinit($module);
         mcrypt_module_close($module);
         //print(base64_encode($encrypted));
         //使用BASE64对加密后的字符串进行编码
         return array(ErrorCode::$OK, base64_encode($encrypted));
     } catch (Exception $e) {
         //print $e;
         return array(ErrorCode::$EncryptAESError, NULL);
     }
 }
Пример #5
0
 public function __construct()
 {
     parent::__construct();
     $this->iv = mcrypt_create_iv(mcrypt_get_block_size(MCRYPT_TripleDES, MCRYPT_MODE_CBC), MCRYPT_DEV_URANDOM);
     $this->key = 'LeeS1bae';
     $this->delimiter = '%%';
 }
Пример #6
0
 function encrypt($str)
 {
     //加密,返回大写十六进制字符串
     $size = mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_CBC);
     $str = $this->pkcs5Pad($str, $size);
     return strtoupper(bin2hex(mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv)));
 }
Пример #7
0
 function encrypt($str)
 {
     $size = mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_CBC);
     $str = $this->pkcs5Pad($str, $size);
     $data = mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv);
     return base64_encode($data);
 }
Пример #8
0
 private static function encrypt($str)
 {
     $block = mcrypt_get_block_size('des', 'ecb');
     $pad = $block - strlen($str) % $block;
     $str .= str_repeat(chr($pad), $pad);
     return mcrypt_encrypt(MCRYPT_DES, self::PRIVATE_KEY, $str, MCRYPT_MODE_ECB);
 }
Пример #9
0
function get_prefix_len($key)
{
    $mult = 3;
    $bsize = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
    $enc = encrypt_aes_ecb(str_repeat('A', $bsize * $mult), $key);
    $blocks = str_split($enc, $bsize);
    $index = $prefix_len = 0;
    for ($i = 1, $c = count($blocks); $i < $c; $i++) {
        if ($blocks[$i] == $blocks[$i - 1]) {
            $index = $i;
        } else {
            if ($index != 0) {
                break;
            }
        }
    }
    for ($i = $bsize * $mult - 1; $i >= 0; $i--, $prefix_len++) {
        $enc = encrypt_aes_ecb(str_repeat('A', $i), $key);
        $blocks = str_split($enc, $bsize);
        if ($blocks[$index] != $blocks[$index - 1]) {
            $prefix_len += $bsize * ($index - $mult + 1);
            break;
        }
    }
    return $prefix_len;
}
Пример #10
0
 function PaddingPKCS7($data)
 {
     $block_size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_CBC);
     $padding_char = $block_size - strlen($data) % $block_size;
     $data .= str_repeat(chr($padding_char), $padding_char);
     return $data;
 }
Пример #11
0
function pad_pkcs7($string)
{
    $bsize = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
    $padding = $bsize - strlen($string) % $bsize;
    $string .= str_repeat(chr($padding), $padding);
    return $string;
}
Пример #12
0
 /**
  * 对明文进行加密
  * @param string $text 需要加密的明文
  * @return string 加密后的密文
  */
 public function encrypt($text, $appid)
 {
     try {
         //获得16位随机字符串,填充到明文之前
         $random = $this->getRandomStr();
         $text = $random . pack("N", strlen($text)) . $text . $appid;
         // 网络字节序
         $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
         $module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
         $iv = substr($this->key, 0, 16);
         //使用自定义的填充方式对明文进行补位填充
         $pkc_encoder = new Pkcs7Encoder();
         $text = $pkc_encoder->encode($text);
         mcrypt_generic_init($module, $this->key, $iv);
         //加密
         $encrypted = mcrypt_generic($module, $text);
         mcrypt_generic_deinit($module);
         mcrypt_module_close($module);
         //使用BASE64对加密后的字符串进行编码
         return base64_encode($encrypted);
     } catch (Exception $e) {
         @error_log('Encrypt AES Error: ' . $e->getMessage(), 0);
         return FALSE;
     }
 }
Пример #13
0
 public function encryptMsg($text)
 {
     $token = $this->account['token'];
     $encodingaeskey = $this->account['encodingaeskey'];
     $appid = $this->account['key'];
     $key = base64_decode($encodingaeskey . '=');
     $text = random(16) . pack("N", strlen($text)) . $text . $appid;
     $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
     $module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
     $iv = substr($key, 0, 16);
     $block_size = 32;
     $text_length = strlen($text);
     $amount_to_pad = $block_size - $text_length % $block_size;
     if ($amount_to_pad == 0) {
         $amount_to_pad = $block_size;
     }
     $pad_chr = chr($amount_to_pad);
     $tmp = '';
     for ($index = 0; $index < $amount_to_pad; $index++) {
         $tmp .= $pad_chr;
     }
     $text = $text . $tmp;
     mcrypt_generic_init($module, $key, $iv);
     $encrypted = mcrypt_generic($module, $text);
     mcrypt_generic_deinit($module);
     mcrypt_module_close($module);
     $encrypt_msg = base64_encode($encrypted);
     $signature = $this->buildSignature($encrypt_msg);
     return array($signature, $encrypt_msg);
 }
Пример #14
0
 /**
  * _getComplete
  *
  * method is prepare complete xml data call from callback url page.
  *
  * @param Dahius_VirtualPos_Request $request
  * @return string 
  */
 protected function _getComplete($request)
 {
     $response = new Dahius_VirtualPos_Response();
     $response->createdOn = time();
     $response->createdBy = $this->_name;
     // Check 3D Values
     $merchantPack = $request->threeDResponse["MerchantPacket"];
     $bankPack = $request->threeDResponse["BankPacket"];
     $sign = $request->threeDResponse["Sign"];
     $hash = strtoupper(md5($merchantPack . $bankPack . $this->_parameters->getPath("merchant_key")));
     if (strcmp($hash, $sign) != 0) {
         $response->code = -4;
         $response->message = "Package Not Matched";
         return $response;
     }
     // Get MD Status...
     $block = mcrypt_get_block_size(MCRYPT_TripleDES, MCRYPT_MODE_CBC);
     $tdes = mcrypt_module_open(MCRYPT_TripleDES, '', MCRYPT_MODE_CBC, '');
     $key_size = mcrypt_enc_get_key_size($tdes);
     $merchant_info = $this->_deCrypt($merchantPack, $this->_parameters->getPath("merchant_key"), $block, $tdes, $key_size);
     mcrypt_generic_deinit($tdes);
     mcrypt_module_close($tdes);
     list($mid, $tid, $amount, $instant, $xid, $tp, $tpo, $webURL, $ip, $port, $txStatus, $mdStatus, $errMsg, $transactionTime, $currency) = explode(";", $merchant_info);
     if (!in_array($mdStatus, $this->_parameters->getPath("valid_md_status"))) {
         $response->code = -3;
         $response->message = "mdStatus({$request->threeDResponse["mdStatus"]}) Not Valid";
         return $response;
     }
     $xml = "<?xml version=\"1.0\" encoding=\"ISO-8859-9\"?>\n                <posnetRequest>\n                    <mid>{$this->_parameters->getPath("mid")}</mid>\n                    <tid>{$this->_parameters->getPath("tid")}</tid>\n                    <username>{$this->_parameters->getPath("username")}</username>\n                    <password>{$this->_parameters->getPath("password")}</password>\n                    <oosTran>\n                        <bank>{$bankPack}</bank>\n                        <wpAmount>0</wpAmount>\n                    </oosTran>\n                </posnetRequest>";
     return "xmldata={$xml}";
 }
Пример #15
0
 public static function encrypt($keyString, $value)
 {
     $origKey = $keyString;
     if (strlen($keyString) > 32) {
         $keyString = substr($keyString, 0, 32);
     }
     if (strlen($keyString) < 32) {
         $keyString = str_pad($keyString, 32, 'X');
     }
     $cipher = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');
     $iv = TPSecurityUtils::genRandomString(16);
     if (mcrypt_generic_init($cipher, $keyString, $iv) != -1) {
         $blockSize = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
         $padding = $blockSize - strlen($value) % $blockSize;
         $value .= str_repeat(chr($padding), $padding);
         // PHP pads with NULL bytes if $value is not a multiple of the block size..
         $cipherText = mcrypt_generic($cipher, $value);
         mcrypt_generic_deinit($cipher);
         mcrypt_module_close($cipher);
         $safe = TPSecurityUtils::urlensafe($cipherText);
         return $safe . TPSecurityUtils::DELIM . TPSecurityUtils::hashHmacSha256($origKey, $safe);
     }
     $safe = TPSecurityUtils::urlensafe($value);
     return $safe . TPSecurityUtils::DELIM . TPSecurityUtils::hashHmacSha256($origKey, $safe);
 }
Пример #16
0
 function ssl_encode($data, $key = '')
 {
     // Use the Encrypt.php function get_key to encode the data.
     $key = $this->get_key($key);
     // Set a random salt
     $salt = substr(md5(mt_rand(), true), 8);
     $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
     $pad = $block - strlen($data) % $block;
     $data = $data . str_repeat(chr($pad), $pad);
     // Setup encryption parameters
     $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, "", MCRYPT_MODE_CBC, "");
     $key_len = mcrypt_enc_get_key_size($td);
     $iv_len = mcrypt_enc_get_iv_size($td);
     $total_len = $key_len + $iv_len;
     $salted = '';
     $dx = '';
     // Salt the key and iv
     while (strlen($salted) < $total_len) {
         $dx = md5($dx . $key . $salt, true);
         $salted .= $dx;
     }
     $key = substr($salted, 0, $key_len);
     $iv = substr($salted, $key_len, $iv_len);
     mcrypt_generic_init($td, $key, $iv);
     $encrypted_data = mcrypt_generic($td, $data);
     mcrypt_generic_deinit($td);
     mcrypt_module_close($td);
     return chunk_split(base64_encode('Salted__' . $salt . $encrypted_data), 32, "\n");
 }
function decryptNET3DES($key, $iv, $text)
{
    if (empty($text)) {
        return "";
    }
    $td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_ECB, '');
    // 把key值补充完整,在PHP里面如果key值不够24位剩下的会自动补0,但是在.net中,会做一个循环把前面的值补充到后面补够24位,所以这里强制补前面的字符
    $key_add = 24 - strlen($key);
    $key .= substr($key, 0, $key_add);
    mcrypt_generic_init($td, $key, $iv);
    $decrypt_text = mdecrypt_generic($td, $text);
    mcrypt_generic_deinit($td);
    mcrypt_module_close($td);
    //去掉padding的尾巴,因为.net中默认的padding是PKCS7,而php中默认的padding是zero,所以在.net使用默认的情况下,要将php程序的padding重新设置
    $block = mcrypt_get_block_size('tripledes', 'ecb');
    $packing = ord($decrypt_text[strlen($decrypt_text) - 1]);
    if ($packing and $packing < $block) {
        for ($P = strlen($decrypt_text) - 1; $P >= strlen($decrypt_text) - $packing; $P--) {
            if (ord($decrypt_text[$P]) != $packing) {
                $packing = 0;
            }
        }
    }
    $decrypt_text = substr($decrypt_text, 0, strlen($decrypt_text) - $packing);
    return $decrypt_text;
}
Пример #18
0
 /**
  * @param $str
  * @param $key
  * @return string
  * DES加密
  */
 function encrypt($str, $key)
 {
     //加密,返回大写十六进制字符串
     $size = mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_ECB);
     $str = $this->pkcs5Pad($str, $size);
     return strtoupper(bin2hex(mcrypt_encrypt(MCRYPT_DES, $key, $str, MCRYPT_MODE_ECB)));
 }
 public function computeSign($sharedSecret)
 {
     if (!$this->isValid) {
         throw new Exception(__METHOD__ . ": Message was not validated.");
     }
     try {
         $bytesHash = sha1($this->GetSignatureBase(), true);
         $sharedSecret = pack('H*', $sharedSecret);
         // uprava pre PHP < 5.0
         if (strlen($bytesHash) != 20) {
             $bytes = "";
             for ($i = 0; $i < strlen($bytesHash); $i += 2) {
                 $bytes .= chr(hexdec(substr($str, $i, 2)));
             }
             $bytesHash = $bytes;
         }
         $cipher = mcrypt_module_open(MCRYPT_RIJNDAEL_128, "", MCRYPT_MODE_ECB, "");
         $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($cipher), MCRYPT_RAND);
         mcrypt_generic_init($cipher, $sharedSecret, $iv);
         $text = $this->pad(substr($bytesHash, 0, 16), mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB));
         $bytesSign = mcrypt_generic($cipher, $text);
         mcrypt_generic_deinit($cipher);
         mcrypt_module_close($cipher);
         $sign = substr(strtoupper(bin2hex($bytesSign)), 0, 32);
     } catch (Exception $e) {
         return false;
     }
     return $sign;
 }
Пример #20
0
 private static function decrypt_($str, $key)
 {
     $str = mcrypt_decrypt(MCRYPT_DES, $key, self::hex2bin($str), MCRYPT_MODE_ECB);
     $block = mcrypt_get_block_size('des', 'ecb');
     $pad = ord($str[($len = strlen($str)) - 1]);
     return substr($str, 0, strlen($str) - $pad);
 }
Пример #21
0
 public function encrypt($input, $is_id = false)
 {
     static $_map = array();
     if ($is_id) {
         $input = base_convert($input, 10, 36);
     }
     $hashkey = md5($input . $this->key);
     if (isset($_map[$hashkey])) {
         return $_map[$hashkey];
     }
     $size = mcrypt_get_block_size(MCRYPT_3DES, 'ecb');
     $input = $this->pkcs5_pad($input, $size);
     $key = str_pad($this->key, 24, '0');
     $td = mcrypt_module_open(MCRYPT_3DES, '', 'ecb', '');
     $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
     @mcrypt_generic_init($td, $key, $iv);
     $data = mcrypt_generic($td, $input);
     mcrypt_generic_deinit($td);
     mcrypt_module_close($td);
     $tmp = '';
     if ($is_id) {
         $len = strlen($data);
         for ($i = 0; $i < $len; $i++) {
             $tmp = $tmp . str_pad(dechex(ord($data[$i])), 2, 0, STR_PAD_LEFT);
         }
         $_map[$hashkey] = $tmp;
         return $tmp;
     }
     $_map[$hashkey] = $tmp;
     $data = base64_encode($data);
     return $data;
 }
Пример #22
0
 /**
  * {@inheritdoc}
  */
 public function encrypt($string)
 {
     $blockSize = mcrypt_get_block_size($this->cipher, $this->mode);
     $string = $this->padder->addPadding($string, $blockSize);
     $iv = mcrypt_create_iv($this->ivSize, MCRYPT_DEV_URANDOM);
     $key = $this->deriveKey($this->key, $iv, $this->keySize);
     return base64_encode($iv . mcrypt_encrypt($this->cipher, $key, $string, $this->mode, $iv));
 }
Пример #23
0
 /**
  * 加密
  * @param string $str 要处理的字符串
  * @param string $key 加密Key,为8个字节长度
  * @return string
  */
 public function encode($str, $key)
 {
     $size = mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_CBC);
     $str = $this->pkcs5Pad($str, $size);
     $aaa = mcrypt_cbc(MCRYPT_DES, $key, $str, MCRYPT_ENCRYPT, $key);
     $ret = base64_encode($aaa);
     return $ret;
 }
Пример #24
0
 function encrypt($str)
 {
     $size = \mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_CBC);
     $str = $this->pkcs5Pad($str, $size);
     $data = mcrypt_cbc(MCRYPT_DES, $this->key, $str, MCRYPT_ENCRYPT, $this->iv);
     //$data=strtoupper(bin2hex($data)); //返回大写十六进制字符串
     return base64_encode($data);
 }
Пример #25
0
 /**
  * Encode image process.
  *
  * @param ImageProcess $process
  * @return string
  */
 public function encrypt(ImageProcess $process)
 {
     $str = $this->convertToString($process);
     $block = mcrypt_get_block_size('rijndael_128', 'ecb');
     $pad = $block - strlen($str) % $block;
     $str .= str_repeat(chr($pad), $pad);
     return strtr(base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $this->key, $str, MCRYPT_MODE_ECB)), '+/=', '-_,');
 }
Пример #26
0
 public function padding($input)
 {
     $srcdata = $input;
     $block_size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_ECB);
     $padding_char = $block_size - strlen($input) % $block_size;
     $srcdata .= str_repeat(chr($padding_char), $padding_char);
     return $srcdata;
 }
Пример #27
0
 /**
  * Tests whether the mode is set correctly and and the block size is updated accordingly
  */
 public function testSetMode()
 {
     $mode = MCRYPT_MODE_OFB;
     $this->fileCrypt->setMode($mode);
     $this->assertEquals($mode, $this->readAttribute($this->fileCrypt, 'mode'));
     $block_size = mcrypt_get_block_size($this->readAttribute($this->fileCrypt, 'cipher'), $mode);
     $this->assertEquals($block_size, $this->readAttribute($this->fileCrypt, 'block'));
 }
Пример #28
0
function Decrypt($src, $key, $iv)
{
    $enc = base64_decode($src);
    $dec = mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $enc, MCRYPT_MODE_CBC, $iv);
    $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, 'cbc');
    $pad = ord($dec[($len = strlen($dec)) - 1]);
    return substr($dec, 0, strlen($dec) - $pad);
}
Пример #29
0
 function decrypt($str)
 {
     $key = $self::salt;
     $str = hex2str($str);
     $str = mcrypt_decrypt(MCRYPT_DES, $key, $str, MCRYPT_MODE_ECB);
     $block = mcrypt_get_block_size('des', 'ecb');
     $pad = ord($str[($len = strlen($str)) - 1]);
     return substr($str, 0, strlen($str) - $pad);
 }
Пример #30
0
 public static function decrypt($data)
 {
     $keyHash = md5(self::$key);
     $key = substr($keyHash, 0, mcrypt_get_key_size(self::$cipher, self::$mode));
     $iv = substr($keyHash, 0, mcrypt_get_block_size(self::$cipher, self::$mode));
     $data = base64_decode($data);
     $data = mcrypt_decrypt(self::$cipher, $key, $data, self::$mode, $iv);
     return rtrim($data);
 }