当前位置: 首页>>代码示例>>PHP>>正文


PHP hash_hmac_file函数代码示例

本文整理汇总了PHP中hash_hmac_file函数的典型用法代码示例。如果您正苦于以下问题:PHP hash_hmac_file函数的具体用法?PHP hash_hmac_file怎么用?PHP hash_hmac_file使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。


在下文中一共展示了hash_hmac_file函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: encrypt

 /**
  * Encrypts the data
  * @param string $data file name
  * @return string
  * @throws \InvalidArgumentException
  * @see hash_hmac_file()
  */
 public function encrypt($data)
 {
     if (!is_string($data)) {
         throw new \InvalidArgumentException('data');
     }
     return hash_hmac_file($this->getAlgorithm(), $data, $this->getKey(), $this->getRawOutput());
 }
开发者ID:nyclagniappe,项目名称:phpjazz,代码行数:14,代码来源:File.php

示例2: fromFile

 public static function fromFile($filename, $key = null, $algorithm = 'sha256')
 {
     if ($key === null) {
         return md5_file($filename);
     } else {
         return hash_hmac_file($algorithm, $filename, $key);
     }
 }
开发者ID:filsh,项目名称:yii2-platform,代码行数:8,代码来源:Checksum.php

示例3: testHashStream

 public function testHashStream()
 {
     $h = new HashHMAC(new Hash('md5'), self::KEY, 64);
     $expect = hash_hmac_file('md5', __FILE__, self::KEY);
     $f = fopen(__FILE__, 'r');
     $actual = $h->updateStream($f)->sum();
     $this->assertEquals($expect, $actual);
 }
开发者ID:Ronmi,项目名称:fruit-cryptokit,代码行数:8,代码来源:HashHMACTest.php

示例4: DeleteUpload

function DeleteUpload($path, $userid)
{
    if (!file_exists($path . '.hash')) {
        return;
    }
    $hash = file_get_contents($path . '.hash');
    if ($hash === hash_hmac_file('sha256', $path, $userid . SALT)) {
        @unlink($path);
        @unlink($path . '.hash');
    }
}
开发者ID:Servault,项目名称:Blargboard,代码行数:11,代码来源:upload.php

示例5: video_tag

 public static function video_tag($source, array $attributes = NULL)
 {
     if (strpos('//', $source) === FALSE && isset($source[0]) && $source[0] !== '/') {
         $version = '';
         $format = 'mp4';
         if (preg_match('#^(?<source>.+)\\.(?<format>\\w+)$#', $source, $matches)) {
             $source = $matches['source'];
             $format = $matches['format'];
         }
         if (Kohana::$config->load('assets.versionizable') === TRUE) {
             $file_name = Assets::get_file($source, $format);
             if ($file_name && is_file($file_name)) {
                 $version = '-' . hash_hmac_file('md5', $file_name, Kohana::$config->load('assets.versionizable.hmac_password'));
             }
         }
         $source = '/assets/' . $source . $version . '.' . $format;
         $mime = File::mime_by_ext($format);
     } else {
         $mime = File::mime($source);
     }
     return '<video' . HTML::attributes($attributes) . '><source src="' . $source . '" type="' . $mime . '" /><a href="' . $source . '">' . $source . '</a></video>';
 }
开发者ID:alshabalin,项目名称:kohana-advanced-assets,代码行数:22,代码来源:Assets.php

示例6: newFile

 /**
  *   newFile
  *   
  *   handle uploading of new file, file goes to files/[userid]/[hash of filecontent+filename]
  *   
  *   @param  id_cnt		int		content id with which the file is linked 
  *   @param  id_usr      int     user id for the user whose pic to modify
  *   @param  uploadedFile array  has info of file, if left empty will use $_FILES 
  *   @return success boolean was the procedure succesful?
  */
 public function newFile($id_cnt, $id_usr, $uploadedFile = "")
 {
     if ($uploadedFile == "") {
         $uploadedFile = $_FILES['content_file_upload'];
     }
     $hash = hash_hmac_file('sha1', $uploadedFile['tmp_name'], $id_cnt . $uploadedFile['name']);
     $dir = "files/" . $id_usr . "/";
     if (!file_exists($dir)) {
         mkdir($dir, 0777, true);
     }
     if (!file_exists($dir) || file_exists($dir . $hash)) {
         return false;
     }
     move_uploaded_file($uploadedFile['tmp_name'], $dir . $hash);
     $file = $this->createRow();
     $file->id_cnt_fil = $id_cnt;
     $file->id_usr_fil = $id_usr;
     $file->filetype_fil = $uploadedFile['type'];
     $file->filename_fil = $uploadedFile['name'];
     $file->hash_fil = $hash;
     $file->created_fil = new Zend_Db_Expr('NOW()');
     $file->modified_fil = new Zend_Db_Expr('NOW()');
     $file->save();
 }
开发者ID:jiiarra,项目名称:site,代码行数:34,代码来源:Files.php

示例7: upload_gambar_hash

 public function upload_gambar_hash($file, $folder, $type, $filesave, $key)
 {
     $today = date("Y-m-d_H:i:s");
     $folder_resize = $folder;
     if (!file_exists($folder)) {
         mkdir($folder, 0777);
     }
     if ($type == 1) {
         $allowed = array('image/pjpeg', 'image/jpeg', 'image/jpeg', 'image/JPG', 'image/X-PNG', 'image/PNG', 'image/png', 'image/x-png');
     } else {
         if ($type == 2) {
             $allowed = array('application/msword', 'application/pdf', 'application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
         }
     }
     $c = $_FILES[$file]['type'];
     //echo("Masuk $c");
     $filename = $_FILES[$file]['name'];
     $name = explode('.', $filename);
     //echo in_array($_FILES[$file]['type'], $allowed);
     if (in_array($_FILES[$file]['type'], $allowed)) {
         echo "..";
         //Where the file must be uploaded to
         if ($folder) {
             $folder .= '/';
         }
         //Add a '/' at the end of the folder
         $uploadfile = $folder . $today . "-" . $filename;
         $result = "{$uploadfile}  ..";
         //Move the file from the stored location to the new location
         if (move_uploaded_file($_FILES[$file]['tmp_name'], $uploadfile)) {
             chmod("{$uploadfile}", 0777);
             $file1 = $_FILES[$file]['name'];
             //echo "masukkk 12313";
             $sha512 = $uploadfile . "-sha512";
             //echo "$sha512";
             $handle = fopen($sha512, 'w') or die('Cannot open file:  ' . $my_file);
             $data = hash_hmac_file('sha512', $uploadfile, $key);
             fwrite($handle, $data);
             /* if ($type != 2)
                     resize("$file1", 300, 300, $folder_resize, "");
                */
             $result .= "harusnya masuk {$uploadfile} ....";
         } else {
             if (!$_FILES[$file_id]['size']) {
                 //Check if the file is made
                 unlink($uploadfile);
                 //Delete the Empty file
                 $file_name = '';
                 $result .= "Empty file found - please use a valid file.";
                 //Show the error message
             } else {
                 chmod($uploadfile, 0777);
                 //Make it universally writable.
             }
         }
     }
     return array('result' => $result, "hash" => $data, "filename" => $today . "-" . $filename);
 }
开发者ID:datadigicore,项目名称:admin_cat,代码行数:58,代码来源:utilityCode.php

示例8: hash

<?php

/* Prototype  : string hash_hmac_file ( string algo, string filename, string key [, bool raw_output] )
 * Description: Generate a keyed hash value using the HMAC method and the contents of a given file
 * Source code: ext/hash/hash.c
 * Alias to functions: 
*/
echo "*** Testing hash() : error conditions ***\n";
$file = dirname(__FILE__) . "hash_file.txt";
$key = 'secret';
echo "\n-- Testing hash_hmac_file() function with less than expected no. of arguments --\n";
var_dump(hash_hmac_file());
var_dump(hash_hmac_file('crc32'));
var_dump(hash_hmac_file('crc32', $file));
echo "\n-- Testing hash_hmac_file() function with more than expected no. of arguments --\n";
$extra_arg = 10;
hash_hmac_file('crc32', $file, $key, TRUE, $extra_arg);
echo "\n-- Testing hash_hmac_file() function with invalid hash algorithm --\n";
hash_hmac_file('foo', $file, $key, TRUE);
?>
===Done===
开发者ID:badlamer,项目名称:hhvm,代码行数:21,代码来源:hash_hmac_file_error.php

示例9: HandlePicture

function HandlePicture($field, $type, &$usepic)
{
    global $userid;
    if ($type == 0) {
        $extensions = array(".png", ".jpg", ".jpeg", ".gif");
        $maxDim = 200;
        $maxSize = 600 * 1024;
        $errorname = __('avatar');
    } else {
        if ($type == 1) {
            $extensions = array(".png", ".gif");
            $maxDim = 16;
            $maxSize = 100 * 1024;
            $errorname = __('minipic');
        }
    }
    $fileName = $_FILES[$field]['name'];
    $fileSize = $_FILES[$field]['size'];
    $tempFile = $_FILES[$field]['tmp_name'];
    list($width, $height, $fileType) = getimagesize($tempFile);
    if ($type == 0 && ($width > 300 || $height > 300)) {
        return __("That avatar is definitely too big. The avatar field is meant for an avatar, not a wallpaper.");
    }
    $extension = strtolower(strrchr($fileName, "."));
    if (!in_array($extension, $extensions)) {
        return format(__("Invalid extension used for {0}. Allowed: {1}"), $errorname, join($extensions, ", "));
    }
    if ($fileSize > $maxSize && !$allowOversize) {
        return format(__("File size for {0} is too high. The limit is {1} bytes, the uploaded image is {2} bytes."), $errorname, $maxSize, $fileSize) . "</li>";
    }
    $ext = '.blarg';
    switch ($fileType) {
        case 1:
            $sourceImage = imagecreatefromgif($tempFile);
            $ext = '.gif';
            break;
        case 2:
            $sourceImage = imagecreatefromjpeg($tempFile);
            $ext = '.jpg';
            break;
        case 3:
            $sourceImage = imagecreatefrompng($tempFile);
            $ext = '.png';
            break;
    }
    $randomcrap = '_' . time();
    $targetFile = false;
    $oversize = $width > $maxDim || $height > $maxDim;
    if ($type == 0) {
        $targetFile = 'avatars/' . $userid . $randomcrap . $ext;
        if (!$oversize) {
            //Just copy it over.
            copy($tempFile, DATA_DIR . $targetFile);
        } else {
            //Resample that mother!
            $ratio = $width / $height;
            if ($ratio > 1) {
                $targetImage = imagecreatetruecolor($maxDim, floor($maxDim / $ratio));
                imagecopyresampled($targetImage, $sourceImage, 0, 0, 0, 0, $maxDim, $maxDim / $ratio, $width, $height);
            } else {
                $targetImage = imagecreatetruecolor(floor($maxDim * $ratio), $maxDim);
                imagecopyresampled($targetImage, $sourceImage, 0, 0, 0, 0, $maxDim * $ratio, $maxDim, $width, $height);
            }
            imagepng($targetImage, DATA_DIR . $targetFile);
            imagedestroy($targetImage);
        }
    } elseif ($type == 1) {
        $targetFile = 'minipics/' . $userid . $randomcrap . $ext;
        if ($oversize) {
            //Don't allow minipics over $maxDim for anypony.
            return format(__("Dimensions of {0} must be at most {1} by {1} pixels."), $errorname, $maxDim);
        } else {
            copy($tempFile, DATA_DIR . $targetFile);
        }
    }
    // file created to verify that the avatar was created here
    file_put_contents(DATA_DIR . $targetFile . '.internal', hash_hmac_file('sha256', DATA_DIR . $targetFile, $userid . SALT));
    $usepic = '$root/' . $targetFile;
    return true;
}
开发者ID:Servault,项目名称:Blargboard,代码行数:80,代码来源:editprofile.php

示例10: die

<?php

require 'lib/common.php';
if (!$loguser['root']) {
    die('no');
}
$needfix = Query("SELECT id,picture,minipic FROM {users} WHERE picture='#INTERNAL#' OR minipic='#INTERNAL#'");
while ($user = Fetch($needfix)) {
    if ($user['picture'] == '#INTERNAL#') {
        $filename = 'avatars/' . $user['id'];
        Query("UPDATE {users} SET picture={0} WHERE id={1}", '$root/' . $filename, $user['id']);
        file_put_contents(DATA_DIR . $filename . '.internal', hash_hmac_file('sha256', DATA_DIR . $filename, $user['id'] . SALT));
    }
    if ($user['minipic'] == '#INTERNAL#') {
        $filename = 'minipics/' . $user['id'];
        Query("UPDATE {users} SET minipic={0} WHERE id={1}", '$root/' . $filename, $user['id']);
        file_put_contents(DATA_DIR . $filename . '.internal', hash_hmac_file('sha256', DATA_DIR . $filename, $user['id'] . SALT));
    }
}
?>
fixed
开发者ID:RoadrunnerWMC,项目名称:Blargboard-1.1,代码行数:21,代码来源:fixavatars.php

示例11: getFileHmac

 /**
  * @test
  * @dataProvider fileDigestProvider
  */
 public function getFileHmac($path, $valid)
 {
     $file = new FileInfoExtra($path);
     $key = "fileinfoextra_secret";
     $invalid_key = "invalid_secret";
     if ($valid) {
         $this->assertEquals(hash_hmac_file('md5', $path, $key), $file->getFileHmac('md5', $key));
         $this->assertNotEquals(hash_hmac_file('md5', $path, $invalid_key), $file->getFileHmac('md5', $key));
         $this->assertEquals(hash_hmac_file('sha1', $path, $key), $file->getFileHmac(HashAlgorithm::SHA1, $key));
         $this->assertEquals(hash_hmac_file('haval160,4', $path, $key), $file->getFileHmac(HashAlgorithm::HAVAL160_4, $key));
         $this->assertNotEquals(hash_hmac_file("sha1", $path, $key, true), $file->getFileHmac(HashAlgorithm::SHA1, $key));
         $this->assertEquals(hash_hmac_file("sha1", $path, $key, true), $file->getFileHmac(HashAlgorithm::SHA1, $key, true));
     } else {
         $this->assertFalse($file->getFileHmac('md5', $key));
         $this->assertFalse($file->getFileHmac(HashAlgorithm::SHA1, $key));
     }
 }
开发者ID:kumatch,项目名称:fs-fileinfoextra,代码行数:21,代码来源:FileInfoExtraTest.php

示例12: getFileHmac

 /**
  * @param string $algo
  * @param string $key
  * @param bool $raw_output
  * @return string|bool
  */
 public function getFileHmac($algo, $key, $raw_output = false)
 {
     if (!$this->exists()) {
         return false;
     }
     if ($this->isDir()) {
         return false;
     }
     return hash_hmac_file($algo, $this->getPathname(), $key, $raw_output);
 }
开发者ID:kumatch,项目名称:fs-fileinfoextra,代码行数:16,代码来源:FileInfoExtra.php

示例13: FL_Hash_HMAC_file

 /**
  * static funtion
  * FL_Hash_HMAC_file
  * 
  * @params (strring) hashMethod
  * @params (string)  FileName
  * @params (string)  key
  * @params (boolean) binaer
  * return hex or digit (binär)
  */
 public static function FL_Hash_HMAC_file($hashMethod, $FileName, $key, $binaer = false)
 {
     // data obligatory
     if (!$data) {
         return false;
     }
     // key obligatory
     if (!$key) {
         return false;
     }
     // hash method must in lower chars
     $hashMethod = (string) strtolower($hashMethod);
     // check if hash method in array
     // alternate throw Exception
     if (!in_array($hashMethod, self::$hashAlgo)) {
         return false;
     }
     // if file exists
     if (file_exists($FileName)) {
         // Returns a string containing the calculated message digest as lowercase hexits
         // unless raw_output is set to true in which case the raw binary representation
         // of the message digest is returned.
         return hash_hmac_file($hashMethod, $FileName, $key, $binaer);
     }
     return false;
 }
开发者ID:DevSKolb,项目名称:FLOWLite,代码行数:36,代码来源:Encrypt.php

示例14: createFileHash

 /**
  * {@inheritdoc}
  */
 public function createFileHash($filePath)
 {
     return hash_hmac_file($this->algorithm, $filePath, $this->key);
 }
开发者ID:symcloud,项目名称:distributed-storage,代码行数:7,代码来源:Factory.php

示例15: execute_pandoc_remote

 protected function execute_pandoc_remote($input, $from, $to)
 {
     $transaction_id = base64_encode($this->security->get_random_bytes(32));
     $url = $this->db_config->get('file_conversion', 'remote_server_url');
     $token = $this->db_config->get('file_conversion', 'remote_server_token');
     $hmac_key = base64_decode($this->db_config->get('file_conversion', 'hmac_key'));
     $digest = hash_hmac_file('sha256', $input, $hmac_key);
     $finfo = new finfo(FILEINFO_MIME);
     $cfile = new CURLFile($input, $finfo->file($input), 'to_convert');
     $post_data = array('to_convert' => $cfile, 'type' => $from, 'covert_to' => $to, 'digest' => $digest, 'token' => $token, 'transaction_id' => $transaction_id);
     //Request the file
     $curl = curl_init();
     curl_setopt($curl, CURLOPT_POST, true);
     curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data);
     curl_setopt($curl, CURLOPT_URL, $url . 'execute_conversion');
     curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
     $file_data = curl_exec($curl);
     $httpcode = curl_getinfo($curl, CURLINFO_HTTP_CODE);
     curl_close($curl);
     $output = APPPATH . 'tmp/' . uniqid() . $this->extension_array[$to];
     if ($httpcode === 200) {
         $fp = fopen($output, 'w');
         fwrite($fp, $file_data);
         fclose($fp);
     } else {
         return false;
     }
     unlink($input);
     if (!file_exists($output)) {
         return false;
     }
     //Request HMAC for message authentication
     $post_data = array('token' => $token, 'transaction_id' => $transaction_id);
     $curl = curl_init();
     curl_setopt($curl, CURLOPT_POST, true);
     curl_setopt($curl, CURLOPT_POSTFIELDS, $post_data);
     curl_setopt($curl, CURLOPT_URL, $url . 'get_digest');
     curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
     $response_digest = curl_exec($curl);
     curl_close($curl);
     $digest = hash_hmac_file('sha256', $output, $hmac_key);
     return $response_digest === $digest ? $output : false;
 }
开发者ID:borisper1,项目名称:vesi-cms-ng,代码行数:43,代码来源:File_conversion.php


注:本文中的hash_hmac_file函数示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。