后台
public function upload()
{
//要上传文件的临时路径
$filePath = $_FILES['file']['tmp_name'];
//阿里云上传对象存储
$fileName = (new Oss())->uploadFile($filePath);
return json(['code'=>200,'msg'=>'上传成功','url'=>$fileName]);
}
封装oss
return[
"accessKeyId"=>"LTAI5tGsyR7ppvCCFWw3Ykee",
"accessKeySecret"=>"MeQyMHXrKlnUK9nbtcUo4gm2i94p9j",
"bucket"=>"zhaochongbin",
"endpoint"=>"oss-cn-hangzhou.aliyuncs.com"
];
public function uploadFile($filePath)
{
// 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://ram.console.aliyun.com 创建RAM账号。
$accessKeyId = config('oss.accessKeyId');
$accessKeySecret = config('oss.accessKeySecret');
// Endpoint以杭州为例,其它Region请按实际情况填写。
$endpoint = config('oss.endpoint');
// 存储空间名称
$bucket = config('oss.bucket');
// <yourObjectName>上传文件到OSS时需要指定包含文件后缀在内的完整路径,例如abc/efg/123.jpg
$fileName = date('Y-m-d', time()) . '/' . md5(time() . rand(1111, 9999999)) . '.png';
try {
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
$result = $ossClient->putObject($bucket, $fileName, file_get_contents($filePath));
} catch (OssException $e) {
print $e->getMessage();
}
return $result['info']['url'];
}
index.wxml
<l-textarea placeholder="说说你的想法吧..." bind:linblur="getContent"/>
<l-image-picker count="9" bind:linchange="onChangeTap" bind:linremove="removeImage"/>
<l-button bind:tap="pushDiary">发布</l-button>
index.js
Page({
/**
* 页面的初始数据
*/
data: {
urls:[]
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
},
onChangeTap(evn){
//获取最新上传的所有图片临时路径
let tempFilePaths = evn.detail.current;
//定义一个空数组,进行存放上传图片url
var urlArr = [];
for (let index = 0; index < tempFilePaths.length; index++) {
wx.uploadFile({
url: 'http://www.week.com/api/login/upload', //仅为示例,非真实的接口地址
filePath: tempFilePaths[index],
name: 'file',
success: res => {
const data = JSON.parse(res.data);
//do something
urlArr.push(data.url)
this.setData({
urls: urlArr
})
}
})
}
},
//删除图片,处理数据
removeImage(event) {
//图片数组
let urls = this.data.urls;
//js根据指定下标删除元素,第一个参数是下标,第二个参数是从这个下标移出几个元素
urls.splice(event.detail.index, 1)
this.setData({
urls
})
},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady: function () {
},
/**
* 生命周期函数--监听页面显示
*/
onShow: function () {
},
/**
* 生命周期函数--监听页面隐藏
*/
onHide: function () {
},
/**
* 生命周期函数--监听页面卸载
*/
onUnload: function () {
},
/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh: function () {
},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom: function () {
},
/**
* 用户点击右上角分享
*/
onShareAppMessage: function () {
}
})