PHP使用七牛云存储之图片的上传、下载、303重定向教程,CI框架实例
来源:互联网 发布:虹云网络 编辑:程序博客网 时间:2024/06/06 00:00
网上关于七牛云存储的教程除了官网上的API文档,其他的资料太少了。研究了下API之后,现在已经能实现图片的上传和下载及上传之后的重定向。
首先本篇文章实现的功能如下:
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文件,自己找一对应路径,代码如下:
- require_once(dirname(__FILE__)."/../../qiniu/rs.php");
require_once是引入文件,表示该文件只引入一次。
然后,传入你的AccessKey和SecretKey
代码如下:
- $accessKey = 'Imn35KC5pRX7Ov3scxbYkvNk6oIx7zWsBRp16'; //换成你自己的密钥
- $secretKey = 's29vc9tlCvs23wRh7QScYTuzCDmEroKj1ddssz'; //换成你自己的密钥
- Qiniu_SetKeys($accessKey, $secretKey);
- $bucket = 'designpartners';
- $putPolicy = new Qiniu_RS_PutPolicy($bucket);
- $upToken = $putPolicy->Token(null);
- <form method="post" action="http://up.qiniu.com" name = "form" enctype="multipart/form-data">
- <ul>
- <input type="hidden" id="token" name="token" value=<?php echo $upToken?>>
- <li>
- <label for="key">key:</label>
- <input name="key" value="">
- </li>
- <li>
- <label for="bucket">照片:</label>
- <input name="file" type="file" />
- </li>
- <li>
- <input type="submit" value="提交" >
- </li>
- </ul>
- </form>
然后一个文件选择,一个提交按钮。运行结果如下:
输入key值和选择照片即可实现照片的上传。哈哈哈有没有很简单。
三、文件下载
原理和文件上传功能相仿。
引入文件
- require_once(dirname(__FILE__)."/../../qiniu/rs.php");
- $key = '00000';
- $domain = 'designpartners.qiniudn.com';
- $accessKey = 'IOImn35KC5p3scxbYkvNk6oIxB7zWsBRp16';
- $secretKey = 's29vc9tlCvs23wCDmIbUSi4EroKj1z';
2.domain即为bucket加上qiniudn.com,例子中的designpartners就是我在上传图片时用的bucket名。
3.accessKey和secretKey换成你自己的,直接用我的不行的..因为我修改了.
- Qiniu_SetKeys($accessKey, $secretKey);
- $baseUrl = Qiniu_RS_MakeBaseUrl($domain, $key);
- $getPolicy = new Qiniu_RS_GetPolicy();
- $privateUrl = $getPolicy->MakeRequest($baseUrl, null);
- echo $privateUrl . "\n";
在引入图片时直接
- <img src = "<?php echo $privateUrl; ?>"/>
四、303重定向
在上面的方法中,我们上传图片成功后跳转到up.qiniu.com下,会显示白白的网页,显示一个json字符串,但是在实际网站开发中我们肯定不能让用户看到这种网页,所以我们用到了303跳转。SDK中也为我们封装了这个方法。使用其实非常简单。在上传文件的代码中添加两行代码即可
- $putPolicy = new Qiniu_RS_PutPolicy($bucket);
- $putPolicy->ReturnUrl = site_url()."/upload/receiveInfo";
- $putPolicy->ReturnBody='{"key": $(key)}';
2.ReturnUrl必须是一个公网可以访问的网址,在本地测试是不可能通过的。比如你写成localhost,七牛服务器是定位不到的。
3.这个ReturnUrl的链接后会跟着一个?upload_ret=XXX,可以用get方法获取这个upload_ret。upload_ret的内容是base64安全编码的json形式的key值。
值的解析:比如我上传的文件名是555
- upload/receiveInfo?upload_ret=eyJrZXkiOiAiNTU1In0=
- {"key": "555"}
- $upload_ret = $_GET['upload_ret'];
- $json_ret = base64_decode($upload_ret);
- $result=json_decode($json_ret);
- echo "key".$result->key;
五、上传前文件类型的验证
我们可以用js来验证文件的后缀名,
在form的属性里加上
- onsubmit="return isValidateFile('file');"
- <script>
- function isValidateFile(obj) {
- var extend = document.form.file.value.substring(document.form.file.value.lastIndexOf(".") + 1);
- if (extend == "") {
- alert("请选择头像");
- return false;
- }
- else {
- if (!(extend == "jpg" || extend == "png")) {
- alert("请上传后缀名为jpg或png的文件!");
- return false;
- }
- }
- return true;
- }
- </script>
即可验证它的类型是否合法。
附:CI代码实现:
获取Uptoken:
- function getUptoken(){
- require_once(dirname(__FILE__)."/../../qiniu/rs.php");
- //远程存储空间名称
- $bucket = 'designpartners';
- $accessKey = 'IOImn35KCRX7Ov3scvNk6oIxB7zWsBRp16';
- $secretKey = 's29vc9tlCvs23wRhTuzCDmIbUSi4EroKj1z';
- Qiniu_SetKeys($accessKey, $secretKey);
- $putPolicy = new Qiniu_RS_PutPolicy($bucket);
- echo site_url();
- $putPolicy->ReturnUrl = site_url()."/upload/receiveInfo";
- $putPolicy->ReturnBody='{"key": $(key)}';
- $upToken = $putPolicy->Token(null);
- return $upToken;
- }
- public function uploadPic(){
- $upToken = $this->getUptoken();
- $data['upToken'] = $upToken;
- $this->load->view('upload',$data);
- }
- public function receiveInfo(){
- $upload_ret = $_GET['upload_ret'];
- $json_ret = base64_decode($upload_ret);
- $result=json_decode($json_ret);
- echo "key".$result->key;
- }
- public function downloadPic(){
- require_once(dirname(__FILE__)."/../../qiniu/rs.php");
- $key = '00000';
- $domain = 'designpartners.qiniudn.com';
- $accessKey = 'IOImn35KC57Ov3scxbYkvNk6oIxB7zWsBRp16';
- $secretKey = 's29vc9tlCvsh7QScYTuzCDmIbUSi4EroKj1z';
- Qiniu_SetKeys($accessKey, $secretKey);
- $baseUrl = Qiniu_RS_MakeBaseUrl($domain, $key);
- $getPolicy = new Qiniu_RS_GetPolicy();
- $privateUrl = $getPolicy->MakeRequest($baseUrl, null);
- echo "====> getPolicy result: \n";
- echo $privateUrl . "\n";
- }
- <script>
- function isValidateFile(obj) {
- var extend = document.form.file.value.substring(document.form.file.value.lastIndexOf(".") + 1);
- if (extend == "") {
- alert("请选择头像");
- return false;
- }
- else {
- if (!(extend == "jpg" || extend == "png")) {
- alert("请上传后缀名为jpg或png的文件!");
- return false;
- }
- }
- return true;
- }
- </script>
- <form method="post" action="http://up.qiniu.com" name = "form" enctype="multipart/form-data" onsubmit="return isValidateFile('file');">
- <ul>
- <input type="hidden" id="token" name="token" value=<?php echo $upToken?>>
- <li>
- <label for="key">key:</label>
- <input name="key" value="">
- </li>
- <li>
- <label for="bucket">照片:</label>
- <input name="file" type="file" />
- </li>
- <li>
- <input type="submit" value="提交" >
- </li>
- </ul>
- </form>
- PHP使用七牛云存储之图片的上传、下载、303重定向教程,CI框架实例
- PHP使用七牛云存储之图片的上传、下载、303重定向教程,CI框架实例
- CI框架之图片上传
- 七牛云存储之图片的上传【PHP】
- PHP CI框架批量上传图片
- ci框架中的图片上传
- ci框架配合uploadify使用图片上传bug
- php基础实例--图片上传与下载
- CI框架(十一)routes.php的使用
- PHP(3)--CI框架的使用
- CI框架之视频上传
- PHP 教程之如何使用BLOB存取图片信息实例
- php ci框架之配置
- php ci框架之controller
- php ci框架之view
- PHP框架之CI:CodeIgniter
- 使用PHP实现七牛云存储图片(文件)上传
- CI框架+Umeditor上传图片配置信息
- JPEG 原理分析及 JPEG 解码器的调试
- Sublime Text 3 常用插件以及安装方法(转)
- windows集群 未安装虚拟机连接工具 若要查看更多数据 请查看
- 编程第二十三、二十四天
- ==与equals()的区别
- PHP使用七牛云存储之图片的上传、下载、303重定向教程,CI框架实例
- 【三】、整合SpringMVC(基本配置和thymeleaf模板选择)
- 毕设论文
- UE4 如何写插件
- 编程第二十五、二十六天
- 1051. 复数乘法 (15) PAT
- 用R语言igraph库实现表自动关联
- 新闻客户端
- UICollectionView reloadData不走cellForRowAtIndexPath的问题