首页 > 编程语言 > 详细

php加密算法blowfish

时间:2016-02-14 20:59:49      阅读:497      评论:0      收藏:0      [点我收藏+]

php加密算法blowfish

<?php
/**
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2016-02-14
 * Time: 20:03
 */

function newline()
{
    printf("<br>");
}

$cipher = mcrypt_module_open(MCRYPT_BLOWFISH, ‘‘, MCRYPT_MODE_ECB, ‘‘);
// The block-size of the Blowfish algorithm is 64-bits, therefore our IV
// is always 8 bytes:
$iv = ‘12345678‘;


$key256 = ‘1234567890123456ABCDEFGHIJKLMNOP‘;
$key256 = ‘closewbq‘;
$key128 = ‘closewbq‘;

printf("iv: %s\n", bin2hex($iv));
newline();
printf("key256: %s\n", bin2hex($key256));
newline();
printf("key128: %s\n", bin2hex($key128));
newline();
$cleartext = ‘The quick brown fox jumped over the lazy dog‘;
$cleartext=‘blowfish‘;
printf("clearText: %s", $cleartext);
newline();
// Do 256-bit blowfish encryption:
// The strengh of the encryption is determined by the length of the key
// passed to mcrypt_generic_init
if (mcrypt_generic_init($cipher, $key256, $iv) != -1) {
    // PHP pads with NULL bytes if $cleartext is not a multiple of the block size..
    $cipherText = mcrypt_generic($cipher, $cleartext);
    mcrypt_generic_deinit($cipher);

    // Display the result in hex.
    printf("256-bit blowfish encrypted:\n%s\n\n", bin2hex($cipherText));
    newline();
}

// 128-bit blowfish encryption:
if (mcrypt_generic_init($cipher, $key128, $iv) != -1) {
    // PHP pads with NULL bytes if $cleartext is not a multiple of the block size..
    $cipherText = mcrypt_generic($cipher, $cleartext);
    mcrypt_generic_deinit($cipher);

    // Display the result in hex.
    printf("128-bit blowfish encrypted:\n%s\n\n", bin2hex($cipherText));
}

mcrypt_module_close($cipher)
// -------
// Results
// -------
// You may use these as test vectors for testing your Blowfish implementations...
//
// iv: 3132333435363738
// key256: 313233343536373839303132333435364142434445464748494a4b4c4d4e4f50
// key128: 31323334353637383930313233343536
// clearText: The quick brown fox jumped over the lazy dog
//
// 256-bit blowfish encrypted:
// 276855ca6c0d60f7d9708210440c1072e05d078e733b34b4198d609dc2fcc2f0c30926cdef3b6d52baf6e345aa03f83e
//
// 128-bit blowfish encrypted:
// d2b5abb73208aea3790621d028afcc74d8dd65fb9ea8e666444a72523f5ecca60df79a424e2c714fa6efbafcc40bdca0

?>

iv: 3132333435363738
key256: 636c6f7365776271
key128: 636c6f7365776271
clearText: blowfish
256-bit blowfish encrypted: 6a3cbb16daef0ae0
128-bit blowfish encrypted: 6a3cbb16daef0ae0

这是以16进制输出的字符,不是base64输出的结果。

base64结果:NmEzY2JiMTZkYWVmMGFlMA==

https://www.tools4noobs.com/online_tools/decrypt/

 

iv是忽略不用的。

https://webnet77.net/cgi-bin/helpers/blowfish.pl

 

算法:blowfish-compat

php加密算法blowfish

原文:http://www.cnblogs.com/cb168/p/5189549.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!