网上关于七牛云存储的教程除了官网上的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文件,自己找一对应路径,代码如下:

  1. require_once(dirname(__FILE__)."/../../qiniu/rs.php");

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

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

然后,传入你的AccessKey和SecretKey

代码如下:

  1. $accessKey = 'Imn35KC5pRX7Ov3scxbYkvNk6oIx7zWsBRp16';  //换成你自己的密钥
  2. $secretKey = 's29vc9tlCvs23wRh7QScYTuzCDmEroKj1ddssz';    //换成你自己的密钥
  3. Qiniu_SetKeys($accessKey, $secretKey);

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

  1. $bucket = 'designpartners';
  2. $putPolicy = new Qiniu_RS_PutPolicy($bucket);

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

  1. $upToken = $putPolicy->Token(null);

接下来就写一个html表单

  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值和选择照片即可实现照片的上传。哈哈哈有没有很简单。

三、文件下载

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

引入文件

  1. require_once(dirname(__FILE__)."/../../qiniu/rs.php");

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

  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换成你自己的,直接用我的不行的..因为我修改了.

  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即可实现图片的下载。

在引入图片时直接

  1. <img src = "<?php echo $privateUrl; ?>"/>

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

四、303重定向

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

  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

  1. upload/receiveInfo?upload_ret=eyJrZXkiOiAiNTU1In0=

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

  1. {"key": "555"}

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

  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的属性里加上

  1. onsubmit="return isValidateFile('file');"

加上一个js方法

  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:

  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. }

文件上传:

  1. public function uploadPic(){
  2. $upToken = $this->getUptoken();
  3. $data['upToken'] = $upToken;
  4. $this->load->view('upload',$data);
  5. }

303重定向解析:

  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. }

文件下载:

  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. }

表单:

    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>

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

  1. 关于七牛云存储,HTTPS资源上传不成功问题

    关于七牛云存储,HTTPS资源上传不成功问题 官方给出了一个解决方案,亲测可用.特此记录一下. 找到QNConfiguration.m文件.然后重写两个方法,直接上代码. + (instancetyp ...

  2. Linux下七牛云存储qrsync命令行上传同步工具

    原址:https://m.aliyun.com/yunqi/ziliao/54370 VPS数据备份是一个重要的工作,之前在文章:使用七牛云存储自动备份VPS数据分享过使用七牛云存储提供的工具QRSB ...

  3. Android开发中使用七牛云存储进行图片上传下载

    Android开发中的图片存储本来就是比较耗时耗地的事情,而使用第三方的七牛云,便可以很好的解决这些后顾之忧,最近我也是在学习七牛的SDK,将使用过程在这记录下来,方便以后使用. 先说一下七牛云的存储 ...

  4. .Net Core 图片文件上传下载

    当下.Net Core项目可是如雨后春笋一般发展起来,作为.Net大军中的一员,我热忱地拥抱了.Net Core并且积极使用其进行业务的开发,我们先介绍下.Net Core项目下实现文件上传下载接口. ...

  5. 如何利用京东云的对象存储(OSS)上传下载文件

    作者:刘冀 在公有云厂商里都有对象存储,京东云也不例外,而且也兼容S3的标准因此可以利用相关的工具去上传下载文件,本文主要记录一下利用CloudBerry Explorer for Amazon S3 ...

  6. Django_图片的上传下载显示配置

    图片上传的配置 image = models.ImageField(upload_to='org/%Y/%m',...) upload_to默认是上传到项目的'MEDIA_ROOT/org/%Y/%m ...

  7. 性能测试七:jmeter进阶之文件上传下载、定时器

    一.上传下载 上传: 1,POST请求,勾选 use …for post 2,同请求一起发送文件里,填写文件名称,参数名称 3,MIME类型: application/octet-stream(非必须 ...

  8. WP集成七牛云存储(原创)

    借助:七牛镜像存储 WordPress 插件 https://wordpress.org/plugins/wpjam-qiniu/ 安装本插件1.4.5及以上版本,请先安装并激活WPJAM BASIC ...

  9. 七牛云存储官方接口PHP版本

    PHP SDKv6 此 SDK 适用于 PHP 5.1.0 及其以上版本.基于 七牛云存储官方API 构建.使用此 SDK 构建您的网络应用程序,能让您以非常便捷地方式将数据安全地存储到七牛云存储上. ...

随机推荐

  1. Stream Byte[] 转换

    public byte[] StreamToBytes(Stream stream) { byte[] bytes = new byte[stream.Length]; stream.Read(byt ...

  2. 向Oracle中传入数组,批量执行SQL语句

    1.首先用PL/SQL创建package create or replace package excuteBatchOperate as type sqlStr_Array ) index by bi ...

  3. JavaScript中的位置坐标

    参考来源 http://www.cnblogs.com/tugenhua0707/p/4501843.html screenX.screenY:浏览器屏幕水平.垂直坐标(相对于浏览器内整个屏幕,包括地 ...

  4. golang社工库数据扫描程序

    https://github.com/xiaojiong/scanfile 演示站点: http://www.weigongkai.com/   7G数据 2s完成扫描 package scanfil ...

  5. DedeCMS V5.7 Dialog目录下配置文件XSS漏洞

    漏洞地址及证明:/include/dialog/config.php?adminDirHand="/></script><script>alert(1);< ...

  6. C#线程 在某一时间内,只有N个线程在并发执行,其余都在队列中的实现(转载)

    具体的需求是 在某一时间点,只有N个线程在并发执行,如果有多余的线程,则排队等候~ 还真是费尽心思啊~最终还是被我攻克了~ 下面我就来说说具体的实现 C#提供了Mutex与Interlocked这两个 ...

  7. HttpRuntime应用程序的运行时

    System.Web.HttpRuntime类是整个Asp.net服务器处理的入口. 这个类提供了一系列的静态属性,反映web应用程序域的设置信息,而且每个web应用程序域中存在一个System.We ...

  8. Serenity框架官方文档翻译前言(什么是Serenity平台)

    什么是Serenity平台 Serenity是一个 ASP.NET MVC / Javascript 的已经建立在开源技术上的平台 它的目标是让开发变得更容易,同时降低维护成本,避免样板式代码,减少重 ...

  9. smarty中math函数的用法

    在查看项目代码时,发现smart代码中有这样写. {if $auctionInfo.printingNum} 印数:{math equation="cid/1000" cid=$a ...

  10. lnmp一键安装包删除添加的域名

    lnmp一键安装包删除添加的域名 如果使用lnmp一键安装包/root/vhost.sh 添加的域名可以,可以删除/usr/local/nginx/conf/vhost/要删除的域名.conf 文件, ...