IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> 【微信小程序】上传图片到oss对象存储(PHP) -> 正文阅读

[PHP知识库]【微信小程序】上传图片到oss对象存储(PHP)

oss准备

第一步:先去阿里云买个oss

第二步:看oss的文档

先点这里
在这里插入图片描述
再点这里
在这里插入图片描述
想办法把SDK下载下来,下面是SDK的目录结构
在这里插入图片描述
重点要注意的就是上面的红圈里面的文件。

继续看官方文档
在这里插入图片描述
从上面的代码我们可以看出,我们还需要准备的东西有下面几样

  1. AccessKeyId
  2. AccessKeySecret
  3. EndPoint
  4. Bucket

AccessKeyID和AccessKey Secret

进入oss管理控制台
在这里插入图片描述
注意图片上的【常用入口】,一会还会用到。先点击【Access Key】,进入下一个页面。
在这里插入图片描述
这篇文章的目的是尝试使用oss,所以安全性这些先不考虑,点击继续使用AccessKey。
在这里插入图片描述
点击AccessKey Secret下面的显示,然后输入手机收到的验证码,就会显示出来了,注意,只显示一次,下次又要手机验证码了,所以要复制下来。到这一步,我们就成功获取到了自己的AccessKey ID和AccessKey Secret。

EndPoint

在这里插入图片描述
记住上图的红圈圈的内容,点击API文档,找到里面的访问域名。
在这里插入图片描述
然后找到自己的地域对应的endpoint。
在这里插入图片描述

Bucket

侧边栏找到bucket列表,然后点击创建bucket。然后填好里面的东西,各种服务看自己是否需要开通。
在这里插入图片描述
至此,我们在oss需要的东西已经准备好了。

后台PHP文件准备

先找到上一步下载的SDK文件。然后新建一个文件夹,然后把SDK文件夹中的整个src文件夹和autoload.php文件拉进新建的文件夹里面。然后新建一个test.php文件。
在这里插入图片描述

编辑test.php文件

这个文件其实就是我们所说的接口。里面的内容直接贴出来。
在这里插入图片描述
这里面要注意的两个点,一个就是PHP的超级全局变量 $_FILES ,不熟悉或者不知道的可以去菜鸟教程看看它的用法。

第二个点就是,$object 可以看到注释上写的是设置文件名称,其实这个文件名是可以包括文件夹的。通俗点讲,如果我直接命名为 test.png 那么这张图片就直接保存在bucket的根目录下了。如果我bucket里面还有个pic文件夹,我想把图片保存进pic文件夹,那么$object的值就要为 pic/test.png

到这里,后台文件也准备好了,接着到微信小程序。

微信小程序准备

微信小程序这里主要用了官方的两个API

  1. wx.chooseImage()
  2. wx.uploadFile()

新建项目

一切从简,具体思路就是,写两个按钮,一个按钮点击后,触发 wx.chooseImage()进行文件选择,另一个点击后触发 wx.uploadFile() 进行文件上传。

index.wxml

<button bindtap="ChooseImage">选择图片</button>
<button bindtap="UpLoadFiles">确认上传</button>

在这里插入图片描述

index.js

Page({
  data: {
    src: [],//存放被上传的图片在本地电脑的临时路径
  },
  ChooseImage: function () {
    var that = this;
    wx.chooseImage({
      count: 9, // 最多可以选择的图片张数,默认9
      sizeType: ['original', 'compressed'], // original 原图,compressed 压缩图,默认二者都有
      sourceType: ['album', 'camera'], // album 从相册选图,camera 使用相机,默认二者都有
      success: function (res) {
        console.log(res)
        that.setData({
          src: res.tempFilePaths
        });
      },
      fail: function () {
      }
    })
  },
  UpLoadFiles: function () {
    var images = this.data.src;
    images.forEach(function (localUrl) {
      wx.uploadFile({
        url:'http://IP/oss_test/test.php', //接口地址
        filePath: localUrl,
        name: 'img',//这里要和后台PHP文件对应
        header: {
          "Content-Type": "multipart/form-data"
        },
        success: function (res) {
          console.log('success||');
        },
        fail: function (res) {
          wx.hideToast();
          wx.showModal({
            title: '错误提示',
            content: '上传图片失败',
            showCancel: false,
            success: function (res) {}
          })
        }
      });
    });
  }
})

wx.uploadFile好像一次只能上传一个文件,所以需要用循环来进行多次请求,以达到多图片上传的目的。

到这里,这个教程已经可以结束了,剩下的就是运行了。

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章      下一篇文章      查看所有文章
加:2021-08-09 10:01:53  更:2021-08-09 10:02:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/24 16:44:33-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码