十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
有的,我最近研究了一下,写了一篇记录,如下
网站建设哪家好,找创新互联公司!专注于网页设计、网站建设、微信开发、小程序制作、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了上蔡免费建站欢迎大家使用!
原文地址:
网上关于七牛云存储的教程除了官网上的API文档,其他的资料太少了。研究了下API之后,现在已经能实现图片的上传和下载及上传之后的重定向。
首先本篇文章实现的功能如下:
1.利用表单上传功能,用户可以点击选择文件按钮,选择本地的一个文件,同时设定上传的图片的名称,点击上传按钮可以上传并存储到七牛云存储。
2.在点击上传时会检测文件的后缀名,限制为jpg和png格式存储。
3.上传成功后跳转到自己设定的一个URL,并传回文件信息,如文件名。而不是显示七牛白花花的json显示页面。
好啦,那我们开始吧,首先我们要有一个七牛云存储账号,如果没有的就自己去申请吧。
七牛云存储传送门:
一.SDK下载
戳这个网址下载一下SDK吧,里面封装了文件上传下载等等的方法,我们引入之后可以直接调用。
SDK之中有一个qiniu的文件夹,这是所有的SDK实货,这个是最重要的。我们首先要把这个文件夹及里面的文件放到项目文件夹中,比如我放到这里。
大家可以看到有一个qiniu文件夹。好啦,资源支持就是这样。接下来我们要实现代码咯。
二.文件的上传。
1.首先把你七牛云存储的密钥照出来,点击账号设置可以看到有一个AccessKey和SecretKey,留着备用。
2.上传凭证生成。
在这里我们首先要引入rs.php文件,自己找一对应路径,代码如下:
require_once(dirname(__FILE__)."/../../qiniu/rs.php");
dirname()是指的绝对路径,有时相对路径会出现问题,建议在前面加上dirname方法获取绝对路径。
require_once是引入文件,表示该文件只引入一次。
然后,传入你的AccessKey和SecretKey
代码如下:
$accessKey = 'Imn35KC5pRX7Ov3scxbYkvNk6oIx7zWsBRp16'; //换成你自己的密钥
$secretKey = 's29vc9tlCvs23wRh7QScYTuzCDmEroKj1ddssz'; //换成你自己的密钥
Qiniu_SetKeys($accessKey, $secretKey);
然后建一个上传策略对象,将你的bucket 传入,bucket 就是你的空间名。
$bucket = 'designpartners';
$putPolicy = new Qiniu_RS_PutPolicy($bucket);
然后调用此方法来生成上传凭证。
$upToken = $putPolicy-Token(null);
接下来就写一个html表单
form method="post" action="" 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
action 就填写 up.qiniu点抗 ,表单提供了一个输入框key,用来输入你想保存的图片名称,上传到七牛之后就是这个名字。
然后一个文件选择,一个提交按钮。运行结果如下:
输入key值和选择照片即可实现照片的上传。哈哈哈有没有很简单。
三、文件下载
原理和文件上传功能相仿。
引入文件
require_once(dirname(__FILE__)."/../../qiniu/rs.php");
声明你的七牛云存储域名和两个密钥以及向下载的文件名称
$key = '00000';
$domain = 'designpartners.qiniudn点抗 ';
$accessKey = 'IOImn35KC5p3scxbYkvNk6oIxB7zWsBRp16';
$secretKey = 's29vc9tlCvs23wCDmIbUSi4EroKj1z';
注意:1.key值即为文件名,不要加后缀
2.domain即为bucket加上qiniudn点抗 ,例子中的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";
传入这四个值即可生成一样url,直接访问url即可实现图片的下载。
在引入图片时直接
img src = "?php echo $privateUrl; ?"/
即可引入图片咯,很简单的吧。
四、303重定向
在上面的方法中,我们上传图片成功后跳转到up.qiniu点抗 下,会显示白白的网页,显示一个json字符串,但是在实际网站开发中我们肯定 不能让用户看到这种网页,所以我们用到了303跳转。SDK中也为我们封装了这个方法。使用其实非常简单。在上传文件的代码中添加两行代码即可
$putPolicy = new Qiniu_RS_PutPolicy($bucket);
$putPolicy-ReturnUrl = site_url()."/upload/receiveInfo";
$putPolicy-ReturnBody='{"key": $(key)}';
注意:1. ReturnUrl和ReturnBody必须指定,并且首字母要大写,很多人都小写开头,这样会跳转不成功。
2.ReturnUrl必须是一个公网可以访问的网址,在本地测试是不可能通过的。比如你写成localhost,七牛服务器是定位不到的。
3.这个ReturnUrl的链接后会跟着一个?upload_ret=XXX,可以用get方法获取这个upload_ret。upload_ret的内容是base64安全编码的json形式的key值。
值的解析:比如我上传的文件名是555
upload/receiveInfo?upload_ret=eyJrZXkiOiAiNTU1In0=
网址后缀如上所示,把那个upload_ret复制下来,用base64解码可以出现如下结果:
{"key": "555"}
所以,我们要获取555这个值的代码如下,即解析代码如下:
$upload_ret = $_GET['upload_ret'];
$json_ret = base64_decode($upload_ret);
$result=json_decode($json_ret);
echo "key".$result-key;
好啦,获取到这个key值之后,你可以选择存到数据库或者进行其他的操作咯。
五、上传前文件类型的验证
我们可以用js来验证文件的后缀名,
在form的属性里加上
onsubmit="return isValidateFile('file');"
加上一个js方法
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);
}
303重定向解析:
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点抗 ';
$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="" 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
七牛云存储可以方便的将网站的图片等数据镜像到七牛云存储的空间,直接从云端将数据返回给用户。这样可以大大节省网站的空间,提升网站的访问速度。真正显示一键实现WordPress博客静态文件CDN加速。下面主要介绍一下WordPress中七牛云存储插件的使用。
工具/原料
WordPress中七牛云存储的插件
方法/步骤
首先需要申请七牛云存储的账号,申请好后,点击创建空间,选择空间类型为公开空间,提交。
配置空间,点击一键加速网站。镜像源填写自己网站域名。确认加速。
接下来在WordPress后台选择添加我爱水煮鱼的“WPJAM 七牛镜像存储”插件并启用。进入插件的基本设置页面。
七牛绑定的域名:就是我们上面获取的:。
*注意:如果博客安装的是在子目录下,比如
,这里
也需要带上子目录
/blog。比如:
七牛空间名:设置为我们一开始设置的wptest
ACCESS
KEY 和SCRET
KEY:可以在七牛后台账户设置密钥页面获取。
其他设置默认即可。
七牛云图片处理实践之LIVE PHOTO|国内首家支持
什么是Live Photo?
在当前苹果发布的iPhone6s和iPhone6s Plus手机上,支持使用相机拍摄 Live Photos 动态照片,并且还会有声音。当然对于没有 iPhone6s 的用户,只要是升级到了 iOS9 系统,虽然不能拍摄 Live Photos 照片,但可以查看他人发来的Live Photos 照片。
Live Photo 由一张 JPG 图片以及一个 45 格 MOV 影片档所组成。在播放Live Photo 时,这段 MOV 则以 15 格 / 秒的速度来播放。因为结合了图片与影片,因此一个 Live Photo 相当于一张普通图片的 2 倍大小。
Live Photo 的优势
很多人认为Live Photo和GIF没有什么区别,不过存在即是合理。Live Photo有很多的优势,它可以像图片一样相互传播,相较于短视频它体积更小,与GIF相比它的画质质量要高一些,而且音画组合的方式使得图片拥有了更多的信息。可以说,Live Photo的出现很好的解决了用户需要在视频预览中截图的问题。
Live Photo与普通照片一样,也经过严格的加密,除非是用户分享或是使用iCloud,Live Photo将只能存储在本机上。目前,苹果向第三方开发者开放了LivePhoto的API接口,现在已经有很多的社交软件开始支持LivePhoto,像Facebook,还有第三方微博客户端的墨客,美颜相机Biu等。
七牛初探Live Photo
现在各大社交应用纷纷推出支持Live Photo。在运营七牛产品过程中,我们发现越来越多的客户如社交类、分享平台、壁纸制作、漫画等有对Live Photo的需求。我们开始尝试做Live Photo的支持工作,并且已经取得进展,成为国内首个支持Live Photo功能的云服务企业。
客户的问题
Live Photo在传统意义上是由两个文件组成,一个是预览的jpg,一个是播放的视频mov。这样在数据上传的时候是两种不同的文件类型,但是在用Live Photo中无法直接分离出单个的jpg和mov文件来上传,如果直接用Live Photo上传使用,在其他设备上又无法直接分解读取,用PHAsset,目前只能得到image数据,但是video数据无法得到。
有很多用户需要在非iOS设备上查看类似Live Photo的效果,如安卓设备。但目前安卓还不支持mov的播放,虽然微博iOS版在年前就已经宣布支持Live Photo,安卓版依然只能查看相应的图片,而没有相应的视频播放。