tp5实现微信小程序多图片上传到服务器功能


Posted in PHP onJuly 16, 2018

最近在做一个教育类的小商城的微信小程序,用到了上传多个图片文件到服务器端,这里做一个讲解,希望对大家有所帮助。

1,小程序端:

在wxml文件中:

<!--选择图片 -->
<view class="picture">
<view class="img" wx:for="{{imgs}}" wx:for-item="item" wx:key="*this">
<image class='imgSelected' src="{{item}}" data-index="{{index}}" mode="aspectFill" bindtap="previewImg"></image>
<view class="delete-btn" data-index="{{index}}" catchtap="deleteImg">删除</view>
</view>
<view class="clickImg" bindtap="chooseImg">点击上传作业</view>
</view>
<!-- 选择图片end -->

在js文件中:

Page({
/**
 * 页面的初始数据
*/
data: {
 index: 0,
 multiIndex: [0, 0],
//传到后台的课程分类
cname:'',
 },
/**
 * 生命周期函数--监听页面加载
*/
onLoad: function (options) {
 },
/**
 * 
 * 生命周期函数--监听页面初次渲染完成
*/
onReady: function () {
 },
/**
 * 生命周期函数--监听页面显示
*/
onShow: function () {
 },
/**
 * 生命周期函数--监听页面隐藏
*/
onHide: function () {
 },
/**
 * 生命周期函数--监听页面卸载
*/
onUnload: function () {
 },
/**
 * 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh: function () {
 },
/**
 * 页面上拉触底事件的处理函数
*/
onReachBottom: function () {
 },
/**
 * 用户点击右上角分享
*/
onShareAppMessage: function () {
 },
// 上传图片操作
// 上传图片
chooseImg: function (e) {
var that = this;
if(that.data.cname==''){
 }else{
var imgs = this.data.imgs;
if (imgs.length >= 9) {
this.setData({
 lenMore: 1
 });
 setTimeout(function () {
 that.setData({
 lenMore: 0
 });
 }, 2500);
return false;
 }
 wx.chooseImage({
// count: 1, // 默认9
 sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
success: function (res) {
// 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
var tempFilePaths = res.tempFilePaths;
var imgs = that.data.imgs;
// console.log(tempFilePaths + '----');
for (var i = 0; i < tempFilePaths.length; i++) {
if (imgs.length >= 9) {
 that.setData({
 imgs: imgs
 });
return false;
 } else {
 imgs.push(tempFilePaths[i]);
 }
 }
// console.log(imgs);
 that.setData({
 imgs: imgs,
 });
//循环把图片上传到服务器
for (var i = 0; i < imgs.length; i++) {
 wx.uploadFile({
 url: url + 'Wx_SaveHomeWork',
 filePath: imgs[i],
 name: 'files',
 formData: {
 cname: that.data.cname
 },
 success: function (res) {
 console.log(res)
 }
 })
 }
 }
 });
 }
 },
// 删除图片
deleteImg: function (e) {
var imgs = this.data.imgs;
var index = e.currentTarget.dataset.index;
 imgs.splice(index, 1);
this.setData({
 imgs: imgs
 });
 },
// 预览图片
previewImg: function (e) {
//获取当前图片的下标
var index = e.currentTarget.dataset.index;
//所有图片
var imgs = this.data.imgs;
 wx.previewImage({
//当前显示图片
current: imgs[index],
//所有图片
urls: imgs
 })
 },
})

2,我们注意到我的wx.request请求中Wx_SaveHomeWork方法是后台服务器的接收图片方法,

后边我会把这个方法展示出来,

3.tp5后台controller中:

//存取学生作业信息
  public function Wx_SaveHomeWork(){
    $files=\request()->file('files');
    $cname=\request()->param('cname');
    $cid=Db::name('course')->where('cname',$cname)->value('id');
    $max_id=Db::name('homework')->max('id');
    foreach($files as $item){
// 移动到框架应用根目录/public/uploads/ 目录下
      $info = $files->rule('date')->move(ROOT_PATH . 'public' . DS . 'uploads');
      if($info){
        $saveName=str_replace("\\","/",$info->getSaveName());
        $img='/uploads/'.$saveName;
        $homework[]=['id'=>$max_id+1,'img'=>$img,'cid'=>$cid];
      }
    }
    //把数据插入到作业表中
    \db('homework')->insertAll($homework);
  }

这里说一下,max_id的作用,因为接受的是多张图片,相当于一次性要存储多条数据,所以用max_id对id进行自增,存储到数据库表,cid是我自己数据库逻辑需要用到的变量,可以不用考虑,

4.讲解的不够清楚,因为是自己写的,感受不到难点在哪里,我自己的难点是在小程序端的图片上传,用了for循环,循环上传的方法,其他的相对来说,逻辑比较简单。

总结

以上所述是小编给大家介绍的tp5实现微信小程序多图片上传到服务器功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

PHP 相关文章推荐
PHP的ASP防火墙
Oct 09 PHP
php 购物车实例(申精)
May 11 PHP
mysql数据库差异比较的PHP代码
Feb 05 PHP
PHP CURL获取cookies模拟登录的方法
Nov 04 PHP
一个严格的PHP Session会话超时时间设置方法
Jun 10 PHP
php中base_convert()进制数字转换函数实例
Nov 20 PHP
PHP静态文件生成类实例
Nov 29 PHP
Laravel 5框架学习之日期,Mutator 和 Scope
Apr 08 PHP
php简单防盗链实现方法
Jul 29 PHP
Symfony2 session用法实例分析
Feb 04 PHP
thinkphp表单上传文件并将文件路径保存到数据库中
Jul 28 PHP
PDO::beginTransaction讲解
Jan 27 PHP
PHP 爬取网页的主要方法
Jul 13 #PHP
php实现微信发红包功能
Jul 13 #PHP
Yii2框架redis基本应用示例
Jul 13 #PHP
Yii2框架实现登陆添加验证码功能示例
Jul 12 #PHP
Yii框架日志记录Logging操作示例
Jul 12 #PHP
php unlink()函数使用教程
Jul 12 #PHP
总结PHP代码规范、流程规范、git规范
Jun 18 #PHP
You might like
php+jquery编码方面的一些心得(utf-8 gb2312)
2010/10/12 PHP
php操作JSON格式数据的实现代码
2011/12/24 PHP
完美的2个php检测字符串是否是utf-8编码函数分享
2014/07/28 PHP
php中heredoc与nowdoc介绍
2014/12/25 PHP
Windows下php+mysql5.7配置教程
2017/05/16 PHP
用Javascript实现UTF8编码转换成gb2312编码
2006/12/22 Javascript
[原创]来自ImageSee官方 JavaScript图片浏览器
2008/01/16 Javascript
setTimeout和setInterval的区别你真的了解吗?
2011/03/31 Javascript
jquery右下角弹出提示框示例代码
2013/10/08 Javascript
JQuery插件iScroll实现下拉刷新,滚动翻页特效
2014/06/22 Javascript
D3.js 从P元素的创建开始(显示可加载数据)
2014/10/30 Javascript
javascript获取当前鼠标坐标的方法
2015/01/10 Javascript
简介JavaScript中的setTime()方法的使用
2015/06/11 Javascript
分享javascript计算时间差的示例代码
2020/03/19 Javascript
BootStrap表单控件之文本域textarea
2017/05/23 Javascript
js案例之鼠标跟随jquery版(实例讲解)
2017/07/21 jQuery
express框架实现基于Websocket建立的简易聊天室
2017/08/10 Javascript
小程序文字跑马灯效果
2018/12/28 Javascript
js中关于Blob对象的介绍与使用
2019/11/29 Javascript
jQuery实现数字华容道小游戏(实例代码)
2020/01/16 jQuery
js实现九宫格抽奖
2020/03/19 Javascript
在python中获取div的文本内容并和想定结果进行对比详解
2019/01/02 Python
python 多线程串行和并行的实例
2019/02/22 Python
Python数组并集交集补集代码实例
2020/02/18 Python
Python学习之os模块及用法
2020/06/03 Python
Python中有几个关键字
2020/06/04 Python
HTML5的标签的代码的简单介绍 HTML5标签的简介
2012/05/28 HTML / CSS
夏尔巴人登珠峰品牌:Sherpa Adventure Gear
2018/02/08 全球购物
美国饼干礼物和美食甜点购买网站:Cheryl’s
2020/05/28 全球购物
小学生环保倡议书
2014/05/15 职场文书
中学生关于梦想的演讲稿
2014/08/22 职场文书
做人民满意的公务员活动方案
2014/08/25 职场文书
党的群众路线教育实践活动批评与自我批评范文
2014/10/16 职场文书
师范生见习总结范文
2015/06/23 职场文书
学校证明范文
2015/06/24 职场文书
2016入党心得体会范文
2016/01/06 职场文书