您好,登錄后才能下訂單哦!
小編給大家分享一下php中文件上傳至OSS的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
刪除的時候記住不要帶域名,也不要帶'/'這個路徑符號,如全路徑是:'https://hxty.oss-cn-beijing.aliyuncs.com/data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf',則這里的path_file路徑為:'data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf'。
<?php include './aliyun-oss-php-sdk-2.4.2/autoload.php'; use OSS\OssClient; use OSS\Core\OssException; error_reporting(E_ALL); ini_set('display_errors', 1); //錯誤信息 ini_set('display_startup_errors', 1); //php啟動錯誤信息 session_start(); /** * 取小數點后兩位 * @param type $str 帶小數的數字 * @return type 返回準確截取兩位的小數 */ function num_format($str) { if (strpos($str, '.') === false) { return $str; } $retArr = explode(".", $str); $strs = substr($retArr[1], 0, 2); return $retArr[0] . "." . $strs; } function create_folders($dir) { return is_dir($dir) or ( create_folders(dirname($dir)) and mkdir(iconv("UTF-8", "GBK", $dir), 0777, true)); } $file = $_FILES['file']; $accessKeyId = '';//RAM alioss后臺能拿到 $accessKeySecret = '';//RAM alioss后臺能拿到 $endpoint = 'oss-cn-beijing.aliyuncs.com';//alioss后臺 概覽可以拿到 $bucket = 'planet-cross';//創建的組,隨便吧創建,權限正常就行 echo '<pre>'; var_dump($_SESSION); if ($file) { $filename = "/upload/image/" . date("Ymd"); if (!file_exists("." . $filename)) { create_folders("." . $filename); } //獲取后綴 $ary = explode('.', $file['name']); $su = end($ary); //文件名 $filenames = $filename . "/" . time() . rand(1, 10000) . "." . $su; move_uploaded_file($file['tmp_name'], "." . $filenames); $ossClient = new \OSS\OssClient($accessKeyId, $accessKeySecret, $endpoint); $filenames = ltrim($filenames, '/'); //去除 第一個 '/' // 開始上傳 $pic = $filenames; try { $oss = $ossClient->uploadFile($bucket, $pic, $filenames); $filenames = $oss['info']['url']; $_SESSION['file']=$filenames; echo $filenames; echo '<img src="' . $filenames . '" />'; //刪除本地文件 } catch (\OSS\Core\OssException $e) { die("Failed to upload file "); return false; } } else if(!empty($_SESSION['file'])){ try { $patch=trim(parse_url($_SESSION['file'])['path'],'/'); $ossClient = new \OSS\OssClient($accessKeyId, $accessKeySecret, $endpoint); $oss=$ossClient->deleteObject($bucket,$patch); $_SESSION['file']=null; } catch (OssException $e) { printf(__FUNCTION__ . ": FAILED\n"); printf($e->getMessage() . "\n"); return; } } /** * 刪除文件 * 可以刪除調用ajaxfile上傳的文件 * @param type $path_file 文件路徑 * 刪除的時候記住不要帶域名 也不要帶 / 這個路徑符號 */ function delfile($path_file) { if (config('config.OSS_OPEN')) { try { // 刪除的時候記住不要帶域名,也不要帶'/'這個路徑符號,如全路徑是:'https://hxty.oss-cn-beijing.aliyuncs.com/data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf',則這里的path_file路徑為:'data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf'。 $path_file=trim(parse_url($path_file)['path'],'/');//去掉域名, $ossClient = new \OSS\OssClient(config('config.OSS_KEY'), config('config.OSS_SECRET'), config('config.OSS_ENDPOINT')); $ossClient->deleteObject(config('config.OSS_BUCKET'), $path_file); } catch (OssException $e) { printf(__FUNCTION__ . ": FAILED\n"); printf($e->getMessage() . "\n"); return; } } else { $val2 = "." . $path_file; if (file_exists($val2)) { $unlinkfilename = trim($path_file, "/"); unlink($unlinkfilename); } } }
刪除的時候記住不要帶域名,也不要帶'/'這個路徑符號,如全路徑是:'https://hxty.oss-cn-beijing.aliyuncs.com/data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf',則這里的path_file路徑為:'data/pdf/contract/2021-06-16/HXSHB21061611594482340c.pdf'。
以上是“php中文件上傳至OSS的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。