zoukankan      html  css  js  c++  java
  • PHP分片上传文件到又拍云对象存储

    本文参加又拍云原创技术征文活动

    注册&实名认证

    注册我就不说了,大家自行前往又拍云注册就行。

    注册之后需要实名认证,否则无法使用,但由于我已经实名认证了(当时没截图),网上也很难找到截图,我找了一张很模糊的,不过还是能看清的

    认证方式:支付宝芝麻信用有700分以上选支付宝芝麻信用认证,没有的话选人工(选人工应该要上传手持身份证的照片)
    所属行业:我的是博客,所以我选的是门户网站→博客
    网站/产品:就填你的网站名称(暂时没有就随便想一个)
    网站地址:写你自己搭建的博客域名,没有的话用csdn,博客园,新浪博客之类的博客地址,再没有的话好像也可以不写
    个人名称:写你的姓名(跟身份证要一样)
    身份证号码:如实填写,否则无法通过实名认证

    创建存储桶

    登录后,点击页面右上角的控制台,然后选择云产品→云存储
    Xnip2020-06-02_13-02-15.jpg

    点击右上角创建一个服务(在这里叫服务,其它云一般叫“存储桶”,英文“bucket”)
    -w1179

    按下图填写,其中加速按你的需求,但如果选择全球加速,价格肯定比国内加速贵;操作员如果你之前没有就需要新建并授权,因为调用api需要一个账号密码,但这个账号密码并不是你注册又拍云的那个账号密码,而是要在这里新建一个,叫“操作员”

    测试操作员账号及默认域名

    又拍云的对象存储是支持直接使用ftp登录的,这里我使用filezilla登录(其它ftp工具也类似)。

    打开filezilla,如下图所示,点击左上角的“Site Manager”图标(也可直接点击菜单FileSite Manager)进入以下界面,然后按下图填写参数

    如果ftp能连接上,也能上传文件,说明操作员账号没啥问题,连不上可能是前面忘了授权,可以点击右上角用户名→账户管理
    -w461

    然后点击操作员→管理,查看是否已经给了这个操作员权限,如果没有给,则给它加上权限,然后再试,应该就没问题了
    -w1199

    另外,我们还可以在网页上上传文件
    -w1174

    创建一个服务后,又拍云默认会给我们一个测试域名,域名结构为”https://服务名.test.upcdn.net“,其实也可以在控制台中看到,点击上图中的“配置”→选择域名管理选项卡(实际上默认就是该选项卡)→滚动到最底下即可看见送的测试域名。

    使用php分片上传文件

    REST API文档,其中并行式断点续传和串行式断点续传,就是分片上传了
    -w1016

    不过又拍云有写好的php-sdk,就不用我们自己写这个,直接传参就行。

    创建一个文件夹UploadToUpyun,在终端中进入该文件夹,使用composer安装sdk(没有composer命令请自行安装,都0202年了应该都有吧?)

    composer require upyun/sdk
    

    安装完成后,在UploadToUpyun文件夹中创建一个index.php,代码如下,注释已经写的非常清楚,填上你的参数即可正常运行,相信没有人不会

    <?php
    require 'vendor/autoload.php';
    
    use UpyunConfig;
    use UpyunUpyun;
    
    //你自己创建的服务的名称
    $serviceName = 'YOUR_SERVICE_NAME';
    //操作员账号
    $operator = 'YOUR_OPERATOR_NAME';
    //操作员密码
    $password = 'YOUR_OPERATOR_PASSWORD';
    //要上传到哪个目录下
    $directory = '/UploadToUpyun/test/';
    //要上传的文件的绝对路径(请换成你电脑上一个图片文件的路径)
    $uploadFilePath = '/Users/bruce/Downloads/Ts8CYigv.png';
    //上传文件名,为什么上传文件名要叫key而不叫filename呢?因为对象存储其实就是一个key value
    //的存储结构,你可以认为它就是个redis,key就是redis键名,value就是这个key对应的内容。
    $key = basename($uploadFilePath);
    //又拍云默认域名在:云存储→选择一个服务并点配置→配置的第一项默认就是域名管理→滚动到最后就能看到默认域名
    $defaultDomain = 'http://' . $serviceName . '.test.upcdn.net';
    
    //在对象存储中,其实并没有实际意义上的"目录"(或者叫"文件夹"),整个文件夹和最后的key一起,组成的一个整体也是key
    //举例:我要把文件存到"2020/06/02/test.jpg",那么这整个就是一个key,而内容当然就是test.jpg这张图片的二进制数据了。
    if($directory){
        //真正使用时,$directory可能是用户传过来的,在不知道用户是否写了右斜杠的情况下,统一先去掉再添加一个
        $key = rtrim($directory, '/') . '/' . $key;
    }
    
    //使用又拍云php-sdk上传文件非常方便,很new一个config对象
    $serviceConfig = new Config($serviceName, $operator, $password);
    // 15728640 = 15M,如果文件大于15M,则使用并行分块上传
    if(filesize($uploadFilePath) > 15728640){
        /* uploadType有两个值
           - BLOCK : 串行分块上传
           - BLOCK_PARALLEL : 并行分块上传
        */
        //然后可对new出的config对象的属性继续设置参数(有哪些参数可直接查看Config类: vendor/upyun/sdk/src/Upyun/Config.php)
        //设置uploadType=BLOCK_PARALLEL表示使用并行分片上传
        $serviceConfig->uploadType = 'BLOCK_PARALLEL';
    }
    $client = new Upyun($serviceConfig);
    $fp = fopen($uploadFilePath, 'rb');
    $retArr = $client->write($key, $fp);
    // var_dump($retArr);exit;
    
    /*
     * 返回的$retArr的值
     * array(6) {
          'x-upyun-content-length' =>
          string(5) "47028"
          'x-upyun-height' =>
          string(3) "473"
          'x-upyun-content-type' =>
          string(9) "image/png"
          'x-upyun-file-type' =>
          string(3) "PNG"
          'x-upyun-width' =>
          string(3) "839"
          'x-upyun-frames' =>
          string(1) "1"
        }
     */
    
    //我们随便拿一个元素来判断是否上传成功
    if(isset($retArr['x-upyun-content-length'])){
        //在实际使用中,$key可能是用户传过来的,在不知道$key是否以斜杠开头的情况下,统一先去掉再自己添加一个
        echo $defaultDomain . '/' . ltrim($key);
    }else{
        echo 'Upload failed.';
    }
    

    好了,到这里就写完了,enjoy!

  • 相关阅读:
    C# BackgroundWorker使用总结
    C#如何优雅的结束一个线程
    C#线程中安全访问控件(重用委托,避免繁复的delegate,Invoke)总结
    C#异步方法调用(四大方法详解)
    C# Winform 跨线程更新UI控件常用方法汇总
    走进异步编程的世界
    走进异步编程的世界
    走进异步编程的世界
    Unity-Redis数据存储
    untiy
  • 原文地址:https://www.cnblogs.com/xiedie/p/13030439.html
Copyright © 2011-2022 走看看