php目录hash计算,php 文件进行hash运算的简单示例

这篇文章主要为大家详细介绍了php 文件进行hash运算的简单示例,具有一定的参考价值,可以用来参考一下。

对php对文件进行hash运算感兴趣的小伙伴,下面一起跟随512笔记的小编两巴掌来看看吧!

这段代码非常有用,如果你下载了一个文件,网站提供了hash结果,你可以对你下载下来的文件进行hash运算,以验证下载的文件是否正确。

/**

* php对文件进行hash运算

*

* @param

* @author 512笔记 www.512pic.com

**/

Hash (Check) Files

#ok{color:green;}

#nono{color:red;}

if(!empty($_FILES)){

if ($_FILES["file"]["error"] > 0){

switch($_FILES["file"]["error"]){

case 1:

echo "Error: The uploaded file exceeds the upload_max_filesize directive in php.ini
";

break;

case 2:

echo "Error: The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form.
";

break;

case 3:

echo "Error: The uploaded file was only partially uploaded.
";

break;

case 4:

echo "Error: No file was uploaded.
";

break;

case 6:

echo "Error: Missing a temporary folder.
";

break;

case 7:

echo "Error: Failed to write file to disk.
";

break;

case 8:

echo "Error: A PHP extension stopped the file upload.
";

break;

default:

echo "Unknown error occured.
";

}

} else {

echo 'Upload: ' . $_FILES['file']['name'] . '
';

echo 'Type: ' . $_FILES['file']['type'] . '
';

echo 'Size: ' . (round($_FILES['file']['size'] / 1024, 2)) . ' Kb
';

if(array_search($_POST['algo'], hash_algos())===false){

echo 'Unknown hashing algorithm requested.
';

} else {

echo 'Hashing Algorithm: '. $_POST['algo'] . '
';

$hash = hash_file($_POST['algo'], $_FILES['file']['tmp_name']);

echo 'Calculated hash: ' . $hash . '
';

if($_POST['exphash']!=='none' && !empty($_POST['exphash'])){

echo 'Expected hash:   ' . $_POST['exphash'] . '
';

echo ($hash==$_POST['exphash'])? 'Hash matched expected value.' : 'Hash did not match expected value.';

echo '
';

}

}

}

?>

Again

} else {

?>

Filename:

Expected hash(optional):


Choose an algorithm (This is the list of all the available algorithms in your php installation)

foreach(hash_algos() as $algo){

if($algo=='md5'){

echo "$algo
";

} else {

echo "$algo
";

}

}

?>

}

?>

/*** 来自512笔记(www.512pic.com) ***/

注:关于php 文件进行hash运算的简单示例的内容就先介绍到这里,更多相关文章的可以留意512笔记的其他信息。

关键词:hash

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值