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); }
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); }
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; }
/** * 对明文进行加密 * @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); } }
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 = '%%'; }
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))); }
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); }
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); }
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; }
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; }
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; }
/** * 对明文进行加密 * @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; } }
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); }
/** * _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}"; }
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); }
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; }
/** * @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; }
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); }
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; }
/** * {@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)); }
/** * 加密 * @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; }
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); }
/** * 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)), '+/=', '-_,'); }
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; }
/** * 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')); }
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); }
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); }
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); }