update
This commit is contained in:
124
addons/alioss/Alioss.php
Normal file
124
addons/alioss/Alioss.php
Normal file
@@ -0,0 +1,124 @@
|
||||
<?php
|
||||
|
||||
namespace addons\alioss;
|
||||
|
||||
use OSS\Core\OssException;
|
||||
use OSS\OssClient;
|
||||
use think\Addons;
|
||||
use think\App;
|
||||
use think\Config;
|
||||
use think\Loader;
|
||||
|
||||
/**
|
||||
* 阿里云OSS上传插件
|
||||
*/
|
||||
class Alioss extends Addons
|
||||
{
|
||||
|
||||
/**
|
||||
* 插件安装方法
|
||||
* @return bool
|
||||
*/
|
||||
public function install()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 插件卸载方法
|
||||
* @return bool
|
||||
*/
|
||||
public function uninstall()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加命名空间
|
||||
*/
|
||||
public function appInit()
|
||||
{
|
||||
if (!class_exists("\OSS\OssClient")) {
|
||||
//添加支付包的命名空间
|
||||
Loader::addNamespace('OSS', ADDON_PATH . 'alioss' . DS . 'library' . DS . 'OSS' . DS);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 判断是否来源于API上传
|
||||
*/
|
||||
public function moduleInit($request)
|
||||
{
|
||||
$config = $this->getConfig();
|
||||
$module = strtolower($request->module());
|
||||
if ($module == 'api' && ($config['apiupload'] ?? 0) &&
|
||||
strtolower($request->controller()) == 'common' &&
|
||||
strtolower($request->action()) == 'upload') {
|
||||
request()->param('isApi', true);
|
||||
App::invokeMethod(["\\addons\\alioss\\controller\\Index", "upload"], ['isApi' => true]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 加载配置
|
||||
*/
|
||||
public function uploadConfigInit(&$upload)
|
||||
{
|
||||
$config = $this->getConfig();
|
||||
$module = request()->module();
|
||||
$module = $module ? strtolower($module) : 'index';
|
||||
|
||||
$data = ['deadline' => time() + $config['expire']];
|
||||
$signature = hash_hmac('sha1', json_encode($data), $config['accessKeySecret'], true);
|
||||
|
||||
$token = '';
|
||||
|
||||
$noNeedLogin = array_filter(explode(',', $config['noneedlogin'] ?? ''));
|
||||
if (in_array($module, $noNeedLogin) || ($module == 'admin' && \app\admin\library\Auth::instance()->id) || ($module != 'admin' && \app\common\library\Auth::instance()->id)) {
|
||||
$token = $config['accessKeyId'] . ':' . base64_encode($signature) . ':' . base64_encode(json_encode($data));
|
||||
}
|
||||
$multipart = [
|
||||
'aliosstoken' => $token
|
||||
];
|
||||
$config['uploadurl'] = 'https://' . $config['bucket'] . '.' . $config['endpoint'];
|
||||
$upload = array_merge($upload, [
|
||||
'cdnurl' => $config['cdnurl'],
|
||||
'uploadurl' => $config['uploadmode'] == 'client' ? $config['uploadurl'] : addon_url('alioss/index/upload', [], false, true),
|
||||
'uploadmode' => $config['uploadmode'],
|
||||
'bucket' => $config['bucket'],
|
||||
'maxsize' => $config['maxsize'],
|
||||
'mimetype' => $config['mimetype'],
|
||||
'savekey' => $config['savekey'],
|
||||
'chunking' => (bool)($config['chunking'] ?? $upload['chunking']),
|
||||
'chunksize' => (int)($config['chunksize'] ?? $upload['chunksize']),
|
||||
'multipart' => $multipart,
|
||||
'storage' => $this->getName(),
|
||||
'multiple' => $config['multiple'] ? true : false,
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 附件删除后
|
||||
*/
|
||||
public function uploadDelete($attachment)
|
||||
{
|
||||
$config = $this->getConfig();
|
||||
if ($attachment['storage'] == 'alioss' && isset($config['syncdelete']) && $config['syncdelete']) {
|
||||
try {
|
||||
$ossClient = new OssClient($config['accessKeyId'], $config['accessKeySecret'], $config['endpoint']);
|
||||
$ossClient->deleteObject($config['bucket'], ltrim($attachment->url, '/'));
|
||||
} catch (OssException $e) {
|
||||
return false;
|
||||
}
|
||||
//如果是服务端中转,还需要删除本地文件
|
||||
//if ($config['uploadmode'] == 'server') {
|
||||
// $filePath = ROOT_PATH . 'public' . str_replace('/', DS, $attachment->url);
|
||||
// if ($filePath) {
|
||||
// @unlink($filePath);
|
||||
// }
|
||||
//}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user