laravel实现阿里云oss文件上传

coding

1、定义路由

// 阿里云文件储存

Route::group(['prefix'=>'aliyun'], function(){

Route::get('sign', 'AliyunController@sign');

});

2、编写 controller 层

/**

* 返回OSS的签名验证

* @return JSON 签名信息

*/

publicfunction sign(Request $request)

{

//初始化一下必要的请求数据

$id = 'xxx'; //AccessKeyId

$key = 'xxx'; //AccessKeySecret

$host = '//xxx.oss-cn-shenzhen.aliyuncs.com'; //OSS库地址

$cdn_host = "//img.xxx.com"; //真实的访问地址

$dir = 'test/'; //上传目录设置

$callbackUrl = url('upload/callback'); //上传回调的地址

//上传回调的参数,callbackUrl地址,callbackBody回调接收的参数,callbackBodyType通过POST调用的回调函数,所以要设置这个头

$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); //转换成json格式

$base64_callback_body = base64_encode($callback_string); //要返回的回调函数参数信息

//设置过期时间

$now = time();

$expire = 60 * 60 * 2; //设置该policy超时时间是 2小时. 即这个policy过了这个有效时间,将不能访问,这里可以根据自己的token过期时间来设置

$end = $now + $expire;

$expiration = $this->gmt_iso8601($end); //进行时间格式的转换

//处理上传限制条件

//最大文件大小.用户可以自己设置

$condition = array(0 => 'content-length-range', 1 => 0, 2 => 1048576000);

$conditions[] = $condition; //设定文件大小

//表示用户上传的数据,必须是以$dir开始, 不然上传会失败,这一步不是必须项,只是为了安全起见,防止用户通过policy上传到别人的目录

$start = array(0 => 'starts-with', 1 => '$key', 2 => $dir);

$conditions[] = $start; //必须以设定的目录开头,防止上传错误

$arr = array('expiration' => $expiration, 'conditions' => $conditions);

$policy = json_encode($arr);

$base64_policy = base64_encode($policy); //要返回的上传限制参数

//签名信息

$string_to_sign = $base64_policy;

$signature = base64_encode(hash_hmac('sha1', $string_to_sign, $key, true)); //要返回的签名信息

//设置返回信息

$response = array(

'accessid' => $id, //accessid

'host' => $host, //上传地址

'cdn_host' => $cdn_host, //真实的访问地址

'policy' => $base64_policy, //上传文件限制

'signature' => $signature, //签名信息

'expire' => $end, //失效时间

'callback' => $base64_callback_body, //上传回调参数

'dir' => $dir//上传的目录

);

return response()->json([

'code' => 0,

'msg' => 'success',

'data' => $response

]);

}

//格式化时间,格式为2020-07-07T23:48:43Z

publicfunction gmt_iso8601($time)

{

$dtStr = date("c", $time);

$pos = strpos($dtStr, '+');

$expiration = substr($dtStr, 0, $pos);

return$expiration . "Z";

}

3、查看接口返回 

4、前端界面及操作编写,这里采用的是 vue

<template>

<div class="test" style="padding:100px 0px 1000px 0px;">

<div>

<input type="file" id="file" name="file" />

<a @click="upload()" href="javascript:;">上传</a>

</div>

</div>

</template>

<script>

export default {

data(){

return {

}

},

mounted() {

this.getOssToken();

},

methods: {

//获取上传通行证

getOssToken(){

var _self = this;

this.axios.get('/aliyun/sign').then((res)=>{

var data = res.data;

if(data.code==0){

_self.aliyunOssToken = data.data;

}else{

_self.$message.warning(data.msg);

}

});

},

upload(){

var _self = this;

var getSuffix = function (fileName) {

var pos = fileName.lastIndexOf(".");

var suffix = '';

if (pos != -1) {

suffix = fileName.substring(pos);

}

return suffix;

}

var file = $("#file").val();

if (file.length == 0) {

alert("请选择文件");

}

var oFileName = file.lastIndexOf('\\');

var oFileName = file.substr(oFileName+1);

var fileName = oFileName.lastIndexOf('.');

var fileName = oFileName.substr(0,fileName);

console.log(fileName);

var filename = new Date().getTime() + getSuffix(file);

var formData = new FormData();

//注意formData里append添加的键的大小写

formData.append('key', _self.aliyunOssToken.dir + filename); //存储在oss的文件路径

formData.append('OSSAccessKeyId', _self.aliyunOssToken.accessid); //accessKeyId

formData.append('policy', _self.aliyunOssToken.policy); //policy

formData.append('Signature', _self.aliyunOssToken.signature); //签名

formData.append("file", $("#file")[0].files[0]);

formData.append('success_action_status', 200); //成功后返回的操作码

var url = _self.aliyunOssToken.host;

var fileUrl = _self.aliyunOssToken.cdn_host +'/'+ _self.aliyunOssToken.dir + filename;

$.ajax({

url: url,

type: 'POST',

data: formData,

// async: false,

cache: false,

contentType: false,

processData: false,

success: function (data) {

console.log(fileUrl);

console.log(data);

},

error: function (data) {

console.log(data);

}

});

}

}

}

</script>

5、点击上传按钮,浏览器控制台输出链接,访问该链接,即可看到该图片

以上是 laravel实现阿里云oss文件上传 的全部内容, 来源链接: utcz.com/z/509089.html

回到顶部