本文整理借鑒自 https://lvwenhan.com/laravel/420.html
對小公司而言,使用阿里雲oss比直接買硬盤要划算的多,不管從存儲性價比上還是從網速負載上。最近因為公司的項目有比較大的圖片存儲訪問需求,所以決定使用阿里雲的oss。
在研究了一下以后,擺着不自己造輪子的原則,決定使用AliyunOss,國人laravel高手JohnLui封裝的一個阿里雲oss的操作庫。
AliyunOSS 是阿里雲 OSS 官方 SDK 的 Composer 封裝,支持任何 PHP 項目,包括 Laravel、Symfony、TinyLara 等等。Github 地址:https://github.com/johnlui/AliyunOSS
安裝
將以下內容增加到 composer.json:
require: {
"johnlui/aliyun-oss": "*"
}
然后運行 `composer update。
使用(以 Laravel 為例)
構建 Service 文件
新建 `app/services/OSS.php`,內容可參考:OSSExample.php:
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/9/6
* Time: 10:14
*/
namespace App\Services;
use JohnLui\AliyunOSS\AliyunOSS;
use Config;
class OSS {
private $ossClient;
public function __construct($isInternal = false)
{
$serverAddress = $isInternal ? Config::get('oss.ossServerInternal') : Config::get('oss.ossServer');
$this->ossClient = AliyunOSS::boot(
$serverAddress,
Config::get('oss.AccessKeyId'),
Config::get('oss.AccessKeySecret')
);
}
// 默認上傳文件使用內網,免流量費
public static function upload($ossKey, $filePath, $isInternal = true)
{
$oss = new OSS($isInternal);
$oss->ossClient->setBucket('你的Bucket名字');
$oss->ossClient->uploadFile($ossKey, $filePath);
}
/**
* 直接把變量內容上傳到oss
* @param $osskey
* @param $content
*/
public static function uploadContent($osskey,$content)
{
$oss = new OSS(true); // 上傳文件使用內網,免流量費
$oss->ossClient->setBucket('你的Bucket名字');
$oss->ossClient->uploadContent($osskey,$content);
}
/**
* 刪除存儲在oss中的文件
*
* @param string $ossKey 存儲的key(文件路徑和文件名)
* @return
*/
public static function deleteObject($ossKey)
{
$oss = new OSS(true); // 上傳文件使用內網,免流量費
return $oss->ossClient->deleteObject('你的Bucket名字', $ossKey);
}
/**
* 復制存儲在阿里雲OSS中的Object
*
* @param string $sourceBuckt 復制的源Bucket
* @param string $sourceKey - 復制的的源Object的Key
* @param string $destBucket - 復制的目的Bucket
* @param string $destKey - 復制的目的Object的Key
* @return Models\CopyObjectResult
*/
public function copyObject($sourceBuckt, $sourceKey, $destBucket, $destKey)
{
$oss = new OSS(true); // 上傳文件使用內網,免流量費
return $oss->ossClient->copyObject($sourceBuckt, $sourceKey, $destBucket, $destKey);
}
/**
* 移動存儲在阿里雲OSS中的Object
*
* @param string $sourceBuckt 復制的源Bucket
* @param string $sourceKey - 復制的的源Object的Key
* @param string $destBucket - 復制的目的Bucket
* @param string $destKey - 復制的目的Object的Key
* @return Models\CopyObjectResult
*/
public function moveObject($sourceBuckt, $sourceKey, $destBucket, $destKey)
{
$oss = new OSS(true); // 上傳文件使用內網,免流量費
return $oss->ossClient->moveObject($sourceBuckt, $sourceKey, $destBucket, $destKey);
}
public static function getUrl($ossKey)
{
$oss = new OSS();
$oss->ossClient->setBucket('你的Bucket名字');
return $oss->ossClient->getUrl($ossKey, new \DateTime("+1 day"));
}
public static function createBucket($bucketName)
{
$oss = new OSS();
return $oss->ossClient->createBucket($bucketName);
}
public static function getAllObjectKey($bucketName)
{
$oss = new OSS();
return $oss->ossClient->getAllObjectKey($bucketName);
}
/**
* 獲取指定Object的元信息
*
* @param string $bucketName 源Bucket名稱
* @param string $key 存儲的key(文件路徑和文件名)
* @return object 元信息
*/
public static function getObjectMeta($bucketName, $osskey)
{
$oss = new OSS();
return $oss->ossClient->getObjectMeta($bucketName, $osskey);
}
}
增加相關配置
在 app/config/oss.php 中增加以下配置:
<?php
/**
* Created by PhpStorm.
* User: Administrator
* Date: 2016/9/6
* Time: 10:17
*/
return [
'useInternal' => false,//是否使用OSS內網傳輸來省流量
'ossServer' => '服務器外網地址', //青島為 http://oss-cn-qingdao.aliyuncs.com
'ossServerInternal' => '服務器內網地址', //青島為 http://oss-cn-qingdao-internal.aliyuncs.com
'AccessKeyId' => '阿里雲給的AccessKeyId',
'AccessKeySecret' => '阿里雲給的AccessKeySecret',
];
使用
use App\Services\OSS;
OSS::upload('文件名', '本地路徑'); // 上傳一個文件
echo OSS::getUrl('某個文件的名稱'); // 打印出某個文件的外網鏈接
OSS::createBucket('一個字符串'); // 新增一個 Bucket。注意,Bucket 名稱具有全局唯一性,也就是說跟其他人的 Bucket 名稱也不能相同。
OSS::getAllObjectKey('某個 Bucket 名稱'); // 獲取該 Bucket 中所有文件的文件名,返回 Array。
常見問題:
① Undefined index: host
解決方案:https://github.com/johnlui/AliyunOSS/issues/9
② The specified bucket is not valid.
錯誤原因:你們的內外地址肯定是給了http://****.oss-cn-beijing.aliyuncs.com 這里的*是指bucket名字, 然后你們調用方法的時候有傳入了一個bucket的名字, 然后它給你們拼接起來 就變成了http://bucketName.bucketName.oss-cn..........com
解決方案:在配置文件里面ALIOSS_SERVER=http://oss-cn-beijing.aliyuncs.com 比如這個外網地址前面不要加上 bucket名字
項目存在的不足:
目前調用SDK沒有一個狀態值返回,所以不知道上傳是否會存在BUG,過段時間盡量Fork並修改一下。
個人建議:
盡量使用laravel自帶的job和queue來完成upload操作。
