Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >uni-app 图片上传实战

uni-app 图片上传实战

作者头像
达达前端
发布于 2019-10-14 08:16:27
发布于 2019-10-14 08:16:27
5.7K00
代码可运行
举报
文章被收录于专栏:达达前端达达前端
运行总次数:0
代码可运行

uni.uploadFile() 将本地资源上传到开发者服务器 客户端发起一个post请求 content-type

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
multipart/form-data

通过uni.chooseImage获取一个本地资源的临时文件路径后 将本地资源上传到指定服务器

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
url String 是 开发者服务器 url 

files Aarry 否 需要上传的文件列表

filePath String 是 要上传文件资源的路径

name String 是 文件对应的key

header Object 否 HTTP 请求 Header, header 中不能设置 Referer 

uploadTask 对象的方法列表

onProgressUpdate callback 监听上传进度变化

abort 中断上传任务

onProgressUpdate 返回参数说明 实战页面

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<progress :percent="percent" stroke-width="10"></progress>

<button type="primary" :loading="loading" :disabled="disabled" @click="upload">选择照片</button>
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
data:{
  percent:0,
  loading:false,
  disabled:false
 },
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
upload : function(){
   _self = this;
   uni.chooseImage({
    count: 1,
    sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
    sourceType: ['album'], //从相册选择
    success: function (res) {
     const tempFilePaths = res.tempFilePaths;
     const uploadTask = uni.uploadFile({
      url : 'https://demo.hcoder.net/index.php?c=uperTest',
      filePath: tempFilePaths[0],
      name: 'file',
      formData: {
       'user': 'test'
      },
      success: function (uploadFileRes) {
       console.log(uploadFileRes.data);
      }
     });
 
     uploadTask.onProgressUpdate(function (res) {
      _self.percent = res.progress;
      console.log('上传进度' + res.progress);
      console.log('已经上传的数据长度' + res.totalBytesSent);
      console.log('预期需要上传的数据总长度' + res.totalBytesExpectedToSend);
     });
    },
    error : function(e){
     console.log(e);
    }
   });
  }
 },

php

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?php
class uperTestController extends witController{
    public function index(){
        if(!empty($_FILES['file'])){
            //获取扩展名
            $exename  = $this->getExeName($_FILES['file']['name']);
            if($exename != 'png' && $exename != 'jpg' && $exename != 'gif'){
                exit('不允许的扩展名');
            }
            $imageSavePath = uniqid().'.'.$exename;
            if(move_uploaded_file($_FILES['file']['tmp_name'], $imageSavePath)){
                echo $imageSavePath;
            }
        }
    }
    
    public function getExeName($fileName){
        $pathinfo      = pathinfo($fileName);
        return strtolower($pathinfo['extension']);
    }
}

uni.chooseImage(OBJECT) 从本地相册选择图片或使用相机拍照 文件的临时路径,在应用本次启动期间可以正常使用,如需持久保存,需在主动调用 uni.saveFile,在应用下次启动时才能访问得到。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
tempFilePaths 
StringArray 图片的本地文件路径列表

tempFiles 
ObjectArray 图片的本地文件列表,每一项是一个 File 对象

File 对象结构如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
path String 本地文件路径
size Number 本地文件大小,单位:B
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
uni.chooseImage({
 count: 6, // 默认9
 sizeType: ['original', 'compressed'], // 原图,压缩图
 sourceType: ['album'], // 从相册选择
 success: function(res) {
  console.log(JSON.stringify(res.tempFilePaths));
    }
});
uni.previewImage();

预览图片

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
current 当前显示图片的链接

urls 需要预览的图片链接列表
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
uni.chooseImage({
 count: 6,
 sizeType: ['original','compressed'],
 sourceType: ['album'],
 success: function(res) {
  // 预览图片
    uni.previewImage({
     urls: res.tempFilePaths
    });
 }

uni.getImageInfo() 获取图片信息

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
orientation 参数说明

枚举值 说明

up 默认
down 180度旋转
left 逆时针旋转90度
right 顺时针旋转90度

up-mirrored 同up,但水平翻转
down-mirrored 同down,但水平翻转
left-mirrored 同left,但垂直翻转
right-mirrored 同right,但垂直翻转
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
uni.chooseImage({
    count: 1,
    sourceType: ['album'],
    success: function (res) {
        uni.getImageInfo({
            src: res.tempFilePaths[0],
            success: function (image) {
                console.log(image.width);
                console.log(image.height);
            }
        });
    }
});

uni.saveImageToPhotosAlbum(OBJECT)

保存图片到系统相册

filePath 图片文件路径

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
uni.chooseImage({
    count: 1,
    sourceType: ['camera'],
    success: function (res) {
        uni.saveImageToPhotosAlbum({
            filePath: res.tempFilePaths[0],
            success: function () {
                console.log('save success');
            }
        });
    }
});
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019.10.13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
图片上传区 -组件封装
1.效果 2.代码 <template> <view> <view class="uni-common-mt"> <view class="uni-uploader" v-if="imageListAreaShow"> <view class="uni-uploader-head"> <view class="uni-uploader-title">点击可预览选好的图片</vi
名字是乱打的
2022/11/06
6110
图片上传区  -组件封装
uni-app图片转换base64,看起来很难,实际一点也不简单?
提示:如果你用的是Vue 3的uni-app,从uni-app插件市场安装插件的时候会提示你可能有兼容问题,不用管。忽略就行。
大风写全栈
2024/11/15
1.1K0
uni-app图片转换base64,看起来很难,实际一点也不简单?
微信小程序上传图片代码:最新可用(后端代码+前端代码)
德宏大魔王
2023/08/08
3.3K0
微信小程序上传图片代码:最新可用(后端代码+前端代码)
小程序图片上传功能
 简单画一个页面,使用按钮调小程序默认的upload(page, path)方法,默认支持单次上传一张图片,可修改
用户10175992
2023/10/17
5170
小程序图片上传功能
国庆,庆祝头像快速生成技能你get到了吗?
使用python要如何制作呢?我们继续来看。我们需要准备好两张图片,一张是国旗,一张是头像
大家一起学编程
2021/10/12
6490
小程序的图片上传wx.uploadFile及后台PHP接收文件并存储到服务器[通俗易懂]
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/150010.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/05
2.4K0
uni-app实图片和视频上传
使用uni-app实现点击上传,既可以上传视频,有可以上传图片,图片预览,删除图片和视频功能,最终效果如下。uni-app里面没有提供同时上传视频和图片这个插件,只能靠自己手写,
小周sir
2019/10/21
7.6K0
微信小程序-图片上传功能的实现
程序媛夏天
2024/01/18
6410
微信小程序-图片上传功能的实现
微信小程序云存储(文件上传到云端)
  我们直到,云开发控制台更多的是对项目中的初始文件的操作管理,例如项目的Logo图片可以通过云开发控制台提起上传到云端。项目在执行的过程中也会涉及文件的操作,例如用户上传图片的操作,这时就需要用到云开发存储API。
别团等shy哥发育
2023/02/25
7.2K0
微信小程序云存储(文件上传到云端)
vue之图片上传组件封装
代码已上传至github github代码地址:https://github.com/Miofly/mio.git
用户10106350
2022/10/28
5760
微信小程序开发之多图片上传+服务端接收
  业务需求,这次需要做一个小程序同时选中三张图片一起上传到服务端,后端使用的.NET WEBAPI接收数据保存。
追逐时光者
2019/08/28
2.3K0
微信小程序开发之多图片上传+服务端接收
微信小程序上传图片
//添加图片 joinPicture: function (e) { var index = e.currentTarget.dataset.index; var evalList = this.data.evalList; var that = this; var imgNumber = evalList[index].tempFilePaths; if (imgNumber.length >= 3) { wx.showModal({
达达前端
2022/04/29
1.8K0
「小程序JAVA实战」小程序头像图片上传(中)(44)
PS:这次试用itools的方式在手机也演示了如何进行图片的选择和上传。wx的插件做的很棒,直接引用不会存在各种问题。稳~
IT架构圈
2019/07/08
9170
「小程序JAVA实战」小程序头像图片上传(中)(44)
uni-app实战教程-----H5移动app以及小程序(五)---再次开发前端
将index.vue中的goTest() 复制到 apiuse中并改成delImg 如下
代码哈士奇
2021/02/04
7800
uni-app实战教程-----H5移动app以及小程序(五)---再次开发前端
uniapp上传图片至服务器,获得在线图片链接预览(实战)
功能需求: 前端选择本地文件,将选择好的文件显示在界面上进行预览,可同时选择四张进行预览。
王小婷
2020/08/11
10.7K2
uniapp上传图片至服务器,获得在线图片链接预览(实战)
小程序上传wx.uploadFile - 小程序请假-请求
UploadTask wx.uploadFile(Object object) 将本地资源上传到服务器。客户端发起一个 HTTPS POST 请求,其中 content-type 为 multipart/form-data。使用前请注意阅读相关说明。
达达前端
2022/04/29
1.6K0
小程序上传wx.uploadFile - 小程序请假-请求
【uniapp小程序】uploadFile文件上传
上节中我们讲到小程序的request请求,掌握了基本的网络请求方式,这节我们通过小程序的uploadFile接口能力完成对小程序上传操作(uni.uploadFile,后端php接口),通过这一节你可以学习到php的上传接口的写法,以及如何配合前端完成一个小程序上传操作
德宏大魔王
2023/08/08
3.4K0
【uniapp小程序】uploadFile文件上传
uni-app实战之社区交友APP(5)搜索和发布页开发
本文先介绍了搜索页的开发,包括页面的搭建(搜索框、搜索历史和搜索结果)和搜索逻辑的优化; 再重点介绍了发布页的开发:自定义导航栏的实现,文本输入框的实现,底部操作条图标和按钮的实现,图品上传和删除的实现以及编辑保存草稿的实现。
cutercorley
2021/02/02
2.9K0
uni-app实战之社区交友APP(5)搜索和发布页开发
Django实战-小程序端图片上传
Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。
小团子
2019/09/03
2.5K0
Django实战-小程序端图片上传
uniapp,小程序上传图片
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/149352.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/04
1.2K0
推荐阅读
相关推荐
图片上传区 -组件封装
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档