七牛云存儲接口調(diào)用

2018-11-21 21:32 更新

3.5.1 擴(kuò)展類庫:七牛云存儲接口調(diào)用

此擴(kuò)展可用于將圖片上傳到七牛云存儲,或者七牛提供的其他功能。

3.5.2 安裝和配置

(1)擴(kuò)展包下載

 PhalApi-Library 擴(kuò)展庫中下載獲取 Qiniu 七牛擴(kuò)展包,如使用:

git clone https://git.oschina.net/dogstar/PhalApi-Library.git

然后把 Qiniu 目錄復(fù)制到 ./PhalApi/Library/ 下,即:

cp ./PhalApi-Library/Qiniu/ ./PhalApi/Library/ -R

到此安裝完畢!接下是插件的配置。

(2)擴(kuò)展包配置

我們需要在 ./Config/app.php 配置文件中追加以下配置:

    /**
     * 七牛相關(guān)配置
     */
    'Qiniu' =>  array(
        //統(tǒng)一的key
        'accessKey' => '*****',
        'secretKey' => '****',
        //自定義配置的空間
        'space_bucket' => '自定義配置的空間',
        'space_host' => 'http://XXXXX.qiniudn.com',
    ),

你也可以不使用配置文件,直接在初始化注冊DI()->qiniu時指定配置。

3.5.3 入門使用

(1)入口注冊

//$ vim ./Public/init.php

$loader->addDirs('Library');

// 其他代碼....

DI()->qiniu = new Qiniu_Lite();

根據(jù)上面所說的,你可以也可以指定配置。

//$ vim ./Public/init.php

$loader->addDirs('Library');

// 其他代碼....

$qiniuConfig = array( /* 格式參照配置文件 *);
DI()->qiniu = new Qiniu_Lite($qiniuConfig);

3.5.4 示例:圖片上傳

先簡單寫個測試文件:

// vim ./Public/test_qiniu.html 

<html>
    <form method="POST" action="/demo/?service=CDN.uploadFile" enctype="multipart/form-data">
        <input type="file" name="file">
        <input type="submit">
    </form>
</html>

效果如下(通常是提供給客戶端上傳的):
p

(1)文件上傳接口

然后,我們需要編寫文件上傳接口:

<?php
/**
 * CDN云端接口
 *
 * @author: dogstar 2015-03-17
 */

class Api_CDN extends PhalApi_Api
{
    const CODE_MISS_UPLOAD_FILE = 1;
    const CODE_FAIL_TO_UPLOAD_FILE = 2;
    const CODE_FAIL_TO_UPDATE = 3;

    public function uploadFile()
    {
        $rs = array('code' => self::CODE_FAIL_TO_UPLOAD_FILE, 'url' => '', 'msg' => T('fail to upload file'));

        if (!isset($_FILES['file'])) {
            $rs['code'] = self::CODE_MISS_UPLOAD_FILE;
            $rs['msg'] = T('miss upload file');
            return $rs;
        }

        if ($_FILES["file"]["error"] > 0) {
            $rs['code'] = self::CODE_FAIL_TO_UPLOAD_FILE;
            $rs['msg'] = T('failed to upload file with error: {error}', array('error' => $_FILES['file']['error']));
            DI()->logger->debug('failed to upload file with error: ' . $_FILES['file']['error']);
            return $rs;
        }

        $url = DI()->qiniu->uploadFile($_FILES['file']['tmp_name']);
        if (!empty($url)) {
            $rs['code'] = 0;
            $rs['url'] = $url;
            $rs['msg'] = '';
        }
        @unlink($_FILES['file']['tmp_name']);

        return $rs;
    }
}

(2)運行一下:

缺少上傳文件時:

{"ret":200,"data":{"code":1,"url":"","msg":"miss upload file"},"msg":""}

上傳失敗時:

{"ret":200,"data":{"code":2,"url":"","msg":"fail to upload file"},"msg":""}

可以看到對應(yīng)的日志(如果不想看到此日志,可通過在初始化日志服務(wù)時去掉調(diào)試日志):

2015-03-18 00:07:02|DEBUG|failed to upload file to qiniu|{"Err":"bad token","Reqid":"u1EAAG73DB3PVMwT","Details":"","Code":401}

上傳成功時:

{"ret":200,"data":{"code":0,"url":"圖片鏈接","msg":""},"msg":""}

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號