最近在做管理后天时,要上传一些app包文件,这些包大小都在几百兆内,普通上传,对服务器压力不小,而且很耗服务器资源。后来发现阿里云可以做web直传,所以,今天我就来记录下过程。
附: 阿里云web直传OSS文档
阿里云OSS直传示例(php版)
这示例文档已经说得很清楚,你唯一要做的就是下载PHP示例包,继承到自己项目根目录中,测试下示例是否能上传文件到oss,然后再想办法集成到webupload插件中。至于阿里云的appkey 和Appsecret,最好是放在后端代码中,不要放在前端,不安全,也即是后端签名直传。
代码:
源包: aliyun-oss-appserver-php-master
- 配置文件
'oss' => [
'driver' => 'oss',
'access_id' => 'xxxx',
'access_key' => 'xxxxxxxxxx',
'bucket' => 'xxxxxx',
'endpoint' => 'oss-cn-shenzhen.aliyuncs.com/', // OSS 外网节点或自定义外部域名
//'endpoint_internal' => '<internal endpoint [OSS内网节点] 如:oss-cn-shenzhen-internal.aliyuncs.com>', // v2.0.4 新增配置属性,如果为空,则默认使用 endpoint 配置(由于内网上传有点小问题未解决,请大家暂时不要使用内网节点上传,正在与阿里技术沟通中)
// 'cdnDomain' => 'http://xxxxx.xxx.com', // 如果isCName为true, getUrl会判断cdnDomain是否设定来决定返回的url,如果cdnDomain未设置,则使用endpoint来生成url,否则使用cdn
'ssl' => false ,// true to use 'https://' and false to use 'http://'. default is false,
// 'isCName' => true ,// 是否使用自定义域名,true: 则Storage.url()会使用自定义的cdn或域名生成文件url, false: 则使用外部节点生成url
'debug' => env("APP_DEBUG",false),
'juta_apk' => env("JUTA_APK","upload"),//apk地址
],
- 获取签名参数
把 get.php文件内容拷贝到项目控制器,或其他目录文件中,我这里是在Models层多加了一层Service层,所以我放在/app/Models/Service/UploadService.php
文件中,对应配置替换成自己阿里云的配置
public function gmtIso8601($time) {
$dtStr = date("c", $time);
$mydatetime = new \DateTime($dtStr);
$expiration = $mydatetime->format(\DateTime::ISO8601);
$pos = strpos($expiration, '+');
$expiration = substr($expiration, 0, $pos);
return $expiration."Z";
}
public function getParams($dir){
$id= config("filesystems.disks.oss.access_id"); // 请填写您的AccessKeyId。
$key= config("filesystems.disks.oss.access_key"); // 请填写您的AccessKeySecret。
// $host的格式为 bucketname.endpoint,请替换为您的真实信息。
// $host = 'http://bucket-name.oss-cn-hangzhou.aliyuncs.com';
$host = "http://".config("filesystems.disks.oss.bucket").'.'.config("filesystems.disks.oss.endpoint");
// $callbackUrl为上传回调服务器的URL,请将下面的IP和Port配置为您自己的真实URL信息。
$callbackUrl = 'http://'.$_SERVER['HTTP_HOST'].'/upload/callBack';
// $dir = 'user-dir-prefix/'; // 用户上传文件时指定的前缀。
// $dir = $dir; // 用户上传文件时指定的前缀。
$callback_param = array('callbackUrl'=>$callbackUrl,
'callbackBody'=>'filename=${object}&size=${size}&mimeType=${mimeType}&height=${imageInfo.height}&width=${imageInfo.width}',
'callbackBodyType'=>"application/x-www-form-urlencoded");
$callback_string = json_encode($callback_param);
$base64_callback_body = base64_encode($callback_string);
$now = time();
$expire = 30; //设置该policy超时时间是10s. 即这个policy过了这个有效时间,将不能访问。
$end = $now + $expire;
$expiration = $this->gmtIso8601($end);
//最大文件大小.用户可以自己设置
$condition = array(0=>'content-length-range', 1=>0, 2=>1048576000);
$conditions[] = $condition;
// 表示用户上传的数据,必须是以$dir开始,不然上传会失败,这一步不是必须项,只是为了安全起见,防止用户通过policy上传到别人的目录。
$start = array(0=>'starts-with', 1=>'$key', 2=><