PHP使用七牛云存储之图片的上传、下载、303重定向教程,CI框架实例

简介: 网上关于七牛云存储的教程除了官网上的API文档,其他的资料太少了。研究了下API之后,现在已经能实现图片的上传和下载及上传之后的重定向。 http://blog.csdn.net/cqcre/article/details/39718689 http://www.tuicool.com/articles/yARFVvQ   首先本篇文章实现的功能如下: 1.利用表单上传功能,用户可以点击选择文件按钮,选择本地的一个文件,同时设定上传的图片的名称,点击上传按钮可以上传并存储到七牛云存储。

网上关于七牛云存储的教程除了官网上的API文档,其他的资料太少了。研究了下API之后,现在已经能实现图片的上传和下载及上传之后的重定向。

http://blog.csdn.net/cqcre/article/details/39718689

http://www.tuicool.com/articles/yARFVvQ

 

首先本篇文章实现的功能如下:

1.利用表单上传功能,用户可以点击选择文件按钮,选择本地的一个文件,同时设定上传的图片的名称,点击上传按钮可以上传并存储到七牛云存储。

2.在点击上传时会检测文件的后缀名,限制为jpg和png格式存储。

3.上传成功后跳转到自己设定的一个URL,并传回文件信息,如文件名。而不是显示七牛白花花的json显示页面。

好啦,那我们开始吧,首先我们要有一个七牛云存储账号,如果没有的就自己去申请吧。

七牛云存储传送门:http://www.qiniu.com/

一.SDK下载

https://github.com/qiniu/php-sdk/tags

戳这个网址下载一下SDK吧,里面封装了文件上传下载等等的方法,我们引入之后可以直接调用。

SDK之中有一个qiniu的文件夹,这是所有的SDK实货,这个是最重要的。我们首先要把这个文件夹及里面的文件放到项目文件夹中,比如我放到这里。

大家可以看到有一个qiniu文件夹。好啦,资源支持就是这样。接下来我们要实现代码咯。

二.文件的上传。

1.首先把你七牛云存储的密钥照出来,点击账号设置可以看到有一个AccessKey和SecretKey,留着备用。

2.上传凭证生成。

在这里我们首先要引入rs.php文件,自己找一对应路径,代码如下:

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. require_once(dirname(__FILE__)."/../../qiniu/rs.php");  

dirname()是指的绝对路径,有时相对路径会出现问题,建议在前面加上dirname方法获取绝对路径。

 

require_once是引入文件,表示该文件只引入一次。

然后,传入你的AccessKey和SecretKey

代码如下:

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. $accessKey = 'Imn35KC5pRX7Ov3scxbYkvNk6oIx7zWsBRp16';  //换成你自己的密钥  
  2. $secretKey = 's29vc9tlCvs23wRh7QScYTuzCDmEroKj1ddssz';    //换成你自己的密钥  
  3. Qiniu_SetKeys($accessKey, $secretKey);  

然后建一个上传策略对象,将你的bucket 传入,bucket 就是你的空间名。

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. $bucket = 'designpartners';  
  2. $putPolicy = new Qiniu_RS_PutPolicy($bucket);  

然后调用此方法来生成上传凭证。

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. $upToken = $putPolicy->Token(null);  

接下来就写一个html表单

 

 

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. <form method="post" action="http://up.qiniu.com" name = "form" enctype="multipart/form-data">  
  2.     <ul>  
  3.             <input type="hidden"  id="token" name="token"  value=<?php echo $upToken?>>  
  4.         <li>  
  5.             <label for="key">key:</label>  
  6.             <input name="key" value="">  
  7.         </li>  
  8.         <li>  
  9.             <label for="bucket">照片:</label>  
  10.             <input name="file"  type="file" />  
  11.         </li>  
  12.         <li>  
  13.             <input type="submit" value="提交" >  
  14.         </li>  
  15.     </ul>  
  16. </form>  

action 就填写 up.qiniu.com,表单提供了一个输入框key,用来输入你想保存的图片名称,上传到七牛之后就是这个名字。

 

然后一个文件选择,一个提交按钮。运行结果如下:

输入key值和选择照片即可实现照片的上传。哈哈哈有没有很简单。

三、文件下载

原理和文件上传功能相仿。

引入文件

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. require_once(dirname(__FILE__)."/../../qiniu/rs.php");  

声明你的七牛云存储域名和两个密钥以及向下载的文件名称

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. $key = '00000';  
  2. $domain = 'designpartners.qiniudn.com';  
  3. $accessKey = 'IOImn35KC5p3scxbYkvNk6oIxB7zWsBRp16';  
  4. $secretKey = 's29vc9tlCvs23wCDmIbUSi4EroKj1z';  

注意:1.key值即为文件名,不要加后缀

 

            2.domain即为bucket加上qiniudn.com,例子中的designpartners就是我在上传图片时用的bucket名。

            3.accessKey和secretKey换成你自己的,直接用我的不行的..因为我修改了.

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. Qiniu_SetKeys($accessKey, $secretKey);    
  2. $baseUrl = Qiniu_RS_MakeBaseUrl($domain, $key);  
  3. $getPolicy = new Qiniu_RS_GetPolicy();  
  4. $privateUrl = $getPolicy->MakeRequest($baseUrl, null);  
  5. echo $privateUrl . "\n";  

传入这四个值即可生成一样url,直接访问url即可实现图片的下载。

 

在引入图片时直接

 

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. <img src = "<?php echo $privateUrl; ?>"/>  

即可引入图片咯,很简单的吧。

 

四、303重定向

在上面的方法中,我们上传图片成功后跳转到up.qiniu.com下,会显示白白的网页,显示一个json字符串,但是在实际网站开发中我们肯定不能让用户看到这种网页,所以我们用到了303跳转。SDK中也为我们封装了这个方法。使用其实非常简单。在上传文件的代码中添加两行代码即可

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. $putPolicy = new Qiniu_RS_PutPolicy($bucket);  
  2. $putPolicy->ReturnUrl = site_url()."/upload/receiveInfo";  
  3. $putPolicy->ReturnBody='{"key": $(key)}';  

注意:1. ReturnUrl和ReturnBody必须指定,并且首字母要大写,很多人都小写开头,这样会跳转不成功。

 

            2.ReturnUrl必须是一个公网可以访问的网址,在本地测试是不可能通过的。比如你写成localhost,七牛服务器是定位不到的。
            3.这个ReturnUrl的链接后会跟着一个?upload_ret=XXX,可以用get方法获取这个upload_ret。upload_ret的内容是base64安全编码的json形式的key值。

值的解析:比如我上传的文件名是555

 

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. upload/receiveInfo?upload_ret=eyJrZXkiOiAiNTU1In0=  

网址后缀如上所示,把那个upload_ret复制下来,用base64解码可以出现如下结果:

 

 

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. {"key": "555"}  

所以,我们要获取555这个值的代码如下,即解析代码如下:

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. $upload_ret = $_GET['upload_ret'];  
  2. $json_ret = base64_decode($upload_ret);  
  3. $result=json_decode($json_ret);  
  4. echo "key".$result->key;   

好啦,获取到这个key值之后,你可以选择存到数据库或者进行其他的操作咯。

 

五、上传前文件类型的验证

我们可以用js来验证文件的后缀名,

在form的属性里加上

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. onsubmit="return isValidateFile('file');"  

加上一个js方法

 

 

[javascript]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. <script>  
  2.     function isValidateFile(obj) {  
  3.         var extend = document.form.file.value.substring(document.form.file.value.lastIndexOf(".") + 1);  
  4.         if (extend == "") {  
  5.             alert("请选择头像");  
  6.             return false;  
  7.         }  
  8.         else {  
  9.             if (!(extend == "jpg" || extend == "png")) {  
  10.             alert("请上传后缀名为jpg或png的文件!");  
  11.             return false;  
  12.             }  
  13.         }  
  14.         return true;  
  15.     }  
  16. </script>  

 

即可验证它的类型是否合法。

附:CI代码实现:

获取Uptoken:

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. function getUptoken(){  
  2.         require_once(dirname(__FILE__)."/../../qiniu/rs.php");  
  3.         //远程存储空间名称  
  4.         $bucket = 'designpartners';  
  5.         $accessKey = 'IOImn35KCRX7Ov3scvNk6oIxB7zWsBRp16';  
  6.         $secretKey = 's29vc9tlCvs23wRhTuzCDmIbUSi4EroKj1z';  
  7.         Qiniu_SetKeys($accessKey, $secretKey);  
  8.         $putPolicy = new Qiniu_RS_PutPolicy($bucket);  
  9.         echo site_url();  
  10.         $putPolicy->ReturnUrl = site_url()."/upload/receiveInfo";  
  11.         $putPolicy->ReturnBody='{"key": $(key)}';  
  12.         $upToken = $putPolicy->Token(null);  
  13.         return $upToken;  
  14.     }  

文件上传:

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. public function uploadPic(){  
  2.           
  3.         $upToken = $this->getUptoken();  
  4.             $data['upToken'] = $upToken;  
  5.         $this->load->view('upload',$data);  
  6.           
  7.     }  

303重定向解析:

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. public function receiveInfo(){  
  2.         $upload_ret = $_GET['upload_ret'];  
  3.         $json_ret = base64_decode($upload_ret);  
  4.         $result=json_decode($json_ret);  
  5.         echo "key".$result->key;   
  6.     }  

文件下载:

 

 

[php]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
  1. public function downloadPic(){  
  2.         require_once(dirname(__FILE__)."/../../qiniu/rs.php");  
  3.         $key = '00000';  
  4.         $domain = 'designpartners.qiniudn.com';  
  5.         $accessKey = 'IOImn35KC57Ov3scxbYkvNk6oIxB7zWsBRp16';  
  6.         $secretKey = 's29vc9tlCvsh7QScYTuzCDmIbUSi4EroKj1z';  
  7.         Qiniu_SetKeys($accessKey, $secretKey);    
  8.         $baseUrl = Qiniu_RS_MakeBaseUrl($domain, $key);  
  9.         $getPolicy = new Qiniu_RS_GetPolicy();  
  10.         $privateUrl = $getPolicy->MakeRequest($baseUrl, null);  
  11.         echo "====> getPolicy result: \n";  
  12.         echo $privateUrl . "\n";  
  13.     }  

表单:

 

 

[html]  view plain copy 在CODE上查看代码片 派生到我的代码片
 
    1. <script>  
    2.     function isValidateFile(obj) {  
    3.         var extend = document.form.file.value.substring(document.form.file.value.lastIndexOf(".") + 1);  
    4.         if (extend == "") {  
    5.             alert("请选择头像");  
    6.             return false;  
    7.         }  
    8.         else {  
    9.             if (!(extend == "jpg" || extend == "png")) {  
    10.             alert("请上传后缀名为jpg或png的文件!");  
    11.             return false;  
    12.             }  
    13.         }  
    14.         return true;  
    15.     }  
    16. </script>  
    17. <form method="post" action="http://up.qiniu.com" name = "form" enctype="multipart/form-data" onsubmit="return isValidateFile('file');">  
    18.     <ul>  
    19.             <input type="hidden"  id="token" name="token"  value=<?php echo $upToken?>>  
    20.         <li>  
    21.             <label for="key">key:</label>  
    22.             <input name="key" value="">  
    23.         </li>  
    24.         <li>  
    25.             <label for="bucket">照片:</label>  
    26.             <input name="file"  type="file" />  
    27.         </li>  
    28.         <li>  
    29.             <input type="submit" value="提交" >  
    30.         </li>  
    31.     </ul>  
    32. </form>  
如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
目录
相关文章
|
2月前
|
数据采集 缓存 自然语言处理
PHP将HTML标签转化为图片
通过这个方法,PHP后端能够实现将HTML内容转化为图片的功能。这种方式虽然牵涉到一些额外的安装和配置,但能够相对灵活且稳定地解冀转换需求,适用于需要在后端动态生成图片的场景。
47 1
|
3月前
|
存储 安全 PHP
安全开发-PHP应用&文件管理模块&显示上传&黑白名单类型过滤&访问控制&文件管理模块&包含&上传&遍历&写入&删除&下载&安全
安全开发-PHP应用&文件管理模块&显示上传&黑白名单类型过滤&访问控制&文件管理模块&包含&上传&遍历&写入&删除&下载&安全
|
3月前
|
PHP
php 生成二维码图片
php 生成二维码图片
18 0
|
4月前
|
运维 Kubernetes PHP
构建高效自动化运维体系:基于容器技术的CI/CD实践深入理解PHP中的命名空间
【5月更文挑战第27天】在现代软件交付过程中,持续集成(CI)与持续部署(CD)已成为提升开发效率、保障产品质量的重要手段。本文旨在探讨如何利用容器技术实现CI/CD的自动化流程,从而构建一个高效的自动化运维体系。通过分析容器技术的核心优势和CI/CD流程的关键要素,我们提出了一种结合Docker、Kubernetes等工具的实践方案,并详细阐述了从代码提交到最终部署的全过程自动化实现方法。 【5月更文挑战第27天】在现代PHP开发中,命名空间是一个不可或缺的功能,它解决了代码库增长时可能出现的类名和函数名冲突问题。本文将深入探讨PHP命名空间的核心概念、实现原理及其在实际项目中的应用,帮助
|
4月前
|
安全 PHP
【PHP开发专栏】PHP文件上传与下载实现
【4月更文挑战第30天】本文介绍了在PHP中实现文件上传和下载的详细步骤。文件上传通过`$_FILES`全局数组处理,包括设置HTML表单、PHP脚本处理上传及安全性考虑。文件下载则可使用`readfile()`、`fpassthru()`或`file_get_contents()`函数,同时关注安全问题,如防止目录遍历漏洞。文中还提供了一个简单的图片分享网站案例,演示了上传和下载功能的集成。
80 1
|
4月前
|
PHP 数据库
DIY私人图床:使用CFimagehost源码自建无需数据库支持的PHP图片托管服务-2
DIY私人图床:使用CFimagehost源码自建无需数据库支持的PHP图片托管服务
|
4月前
|
存储 PHP Apache
DIY私人图床:使用CFimagehost源码自建无需数据库支持的PHP图片托管服务-1
DIY私人图床:使用CFimagehost源码自建无需数据库支持的PHP图片托管服务
|
PHP
PHP获取远程图片并调整图像大小(转)
允许上传的文件类型为:  如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
1110 0
|
7天前
|
NoSQL 关系型数据库 MySQL
不是 PHP 不行了,而是 MySQL 数据库扛不住啊
【9月更文挑战第8天】这段内容讨论了MySQL在某些场景下面临的挑战及其原因,并指出这些问题不能完全归咎于MySQL本身。高并发读写压力、数据量增长以及复杂查询和事务处理都可能导致性能瓶颈。然而,应用程序设计不合理、系统架构不佳以及其他数据库选择和优化策略不足也是重要因素。综合考虑这些方面才能有效解决性能问题,而MySQL通过不断改进和优化,仍然是许多应用场景中的可靠选择。
|
19天前
|
存储 SQL 关系型数据库
PHP与MySQL交互的奥秘
【8月更文挑战第29天】在编程的世界里,PHP和MySQL就像是一对默契的舞伴,共同演绎着数据的交响曲。本文将带你探索它们之间的互动,从连接数据库到执行查询,再到处理结果,每一步都充满了节奏与和谐。我们将一起走进这段代码的旅程,感受数据流动的魅力。