七牛云图片处理实践之LIVE PHOTO|国内首家支持
蚌山网站建设公司创新互联,蚌山网站设计制作,有大型网站制作公司丰富经验。已为蚌山近1000家提供企业网站建设服务。企业网站搭建\成都外贸网站建设要多少钱,请找那个售后服务好的蚌山做网站的公司定做!
什么是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,安卓版依然只能查看相应的图片,而没有相应的视频播放。
七牛云存储可以方便的将网站的图片等数据镜像到七牛云存储的空间,直接从云端将数据返回给用户。这样可以大大节省网站的空间,提升网站的访问速度。真正显示一键实现WordPress博客静态文件CDN加速。下面主要介绍一下WordPress中七牛云存储插件的使用。
工具/原料
WordPress中七牛云存储的插件
方法/步骤
首先需要申请七牛云存储的账号,申请好后,点击创建空间,选择空间类型为公开空间,提交。
配置空间,点击一键加速网站。镜像源填写自己网站域名。确认加速。
接下来在WordPress后台选择添加我爱水煮鱼的“WPJAM 七牛镜像存储”插件并启用。进入插件的基本设置页面。
七牛绑定的域名:就是我们上面获取的:。
*注意:如果博客安装的是在子目录下,比如
,这里
也需要带上子目录
/blog。比如:
七牛空间名:设置为我们一开始设置的wptest
ACCESS
KEY 和SCRET
KEY:可以在七牛后台账户设置密钥页面获取。
其他设置默认即可。
我在这里写下长篇大论,只希望小白们能跟快速入门。坚持10个小时 坚持10个小时 坚持10个小时(重要的事情说三遍!!!)搭建出属于自己的个人独立博客,我将会通过 安装流程主线+优质文章 作为参考。由于我本人是一名学生(非计算机专业),喜欢尝试和不愿意人与亦云想要不一样的人生打小喜欢折腾便开始了搭建自己独立博客的道路,这路上可谓是路途凶险和艰难费了我九牛二虎之力解决,还是不够完美,但我希望他完美,希望他可以记录我的时光。作为一名技术小白,没有技术基础。看到网上教程更是玲琅满目直至眼花缭乱无从下手,讲真,我从开始接触到成功搭建花费了不低于100小时,走了很多弯路和误区, 希望通过本教程可以真心小白一个敢于尝试的机会。我会将这篇教程写仔细,会将我出现过的问题给予解决方法。(同时这也是我第二次,就在前几分钟,电脑过热,系统崩了,快写完的教程没有按Ctrl+S的情况不翼而飞了。我现在的内心是崩溃的)但是我知道坚持一会,就可以完成了。
前言
天生倔强不愿屈服的我,总受想做出一番成绩来,不愿意随波逐流。我为什么要在这个博客已经不盛行的时代去搭建属于自己的博客?可以看看我之前写的《重新认识自己》和《我为什么那么懒?》。不去折腾怎么能知道自己不行?未知的东西太多,需要我们去学习和掌握的数不尽数,唯有时刻保持这一份对新事物的好奇心并真心有心去坚持下去。
疑问
先给大家预览下我的博客目前最终版视己慎独,很多人用 wordpress,你为什么要用 github pages 来搭建?为什么要搭建一个独立博客?独立博客与微信公众平台有什么区别?
1、 无需购置服务器,目前的blog挂载在Github Pages,免服务器费的同时还能做负载均衡;github pages有300M免费空间,资料自己管理,保存可靠;学着用 github,享受 github 的便利,上面有很多大牛,眼界会开阔很多;github 是趋势,像eleme这种互联网大公司都在github上完成自己的项目;顺便看看 github 工作原理,最好的团队协作流程;你不觉得一个文科生用 github 很 geek 吗?瞬间跻身技术界。
2、独立的才是自己的。在知乎上有这样一个话题《GitHub 能作为衡量程序员能力的指标吗?》,在我看来独立博客是喜欢尝试新事物的人新一片天空,他们可以在这片天空中翱翔,他可以不太受拘束爱上些自由,他的内心因他的不羁和外表不屈,愿意潜心研究深钻其爱好,同时在这里他可以结实一大批有着共同的爱好的追梦人。对于小白,请保持记得那份好奇心,坚持尝试下去,继续折腾。
3、公众账号是对所有人开放的,简单申请即可使用,无需太多的挑战。他仅仅只是一个平台(对一般人来说)同时好好做运营也似乎不是一件简单的事情,没有足够的经历和精力是很难达到一个高度,也很难去传播你的文化价值观念。博客也只是一个平台,但是这里有你想要的,也是你的用武之地。公众账号是一个一对多的平台很难利于交流尽管现在越来越人性化,这点你的博客很轻松就可以做到。更多的区别在此不多分析。
成功方向
1、安装准备软件 Node.js、Git、GitHub DeskTop(前两个必须安装,后者可选)
2、本地搭建hexo框架、配置主题、修改参数、实现本地测试预览
3、链接GitHub、实现在线预览
4、购买域名并解析 (这里告诉大家一个方法,1元购买一个使用期限为一年.cn的域名 仅高校学生可以 )
5、日后站点的管理和运营
纸上得来终觉浅,要知此事须举行。世上无难事,就怕是懒人。以下以我的博客:blog.shijinrong.cn(shijinrong.cn是我一下行动)在windows下为例,教大家如何搭建一个独立博客。
安装流程
安装准备软件
Node.js
Git
GitHub Desktop (可选)
以上几个软件均是英文版本,请小白不要害怕,敢于面对。安装简单,在此不做详细介绍。
本地搭建hexo框架、配置主题
目录
I.Hexo简介
II.Hexo安装方法
III.Hexo配置方法
IV.Hexo主题修改
V.Hexo部署方法
I.Hexo简介
Hexo 是一个轻量的静态博客框架。通过Hexo可以快速生成一个静态博客框架,仅需要几条命令就可以完成,相当方便。
而架设Hexo的环境更简单了 不需要 lnmp/lamp/XAMPP 这些繁琐复杂的环境 仅仅需要一个简单的http服务器即可使用 或者使用互联网上免费的页面托管服务
比如本人的这个博客 就是托管于 GitHub Pages服务上
II.Hexo安装方法
参考官网中文文档,请尝试者仔细读教程和官方文档。这步很简单,正如官方网站写的那样只需要一条命令即可自动安装hexo框架。
$ npm install -g hexo-cli #使用 npm 安装 Hexo。
初始化hexo
请参考hexo官方文档,init命令中的就是文件夹aierui.github.io。初始化后,aierui.github.io里面就已经有完整的Hexo框架了,这里可以在任意地方新建立一个文件夹并命名为aierui.github.io【不要问为什么】打开该文件,点击鼠标右键你会看到一个Git bash here点击跳出git的黑窗口,输入命令$ npm install,完成后,指定文件夹的目录如下:
III.Hexo配置方法
熟悉hexo
为了让读者快速了解Hexo,我作几个简单介绍吧。当然,更多的还是需要仔细阅读文档才能了解更详细。
_config.yml 全局配置文件。要注意的是,该文件格式要求极为严格,缺少一个空格都会导致运行错误。小提示:不要用Tab缩进,两个空格符, 冒号:后面只用一个空格即可 。
themes 存放主题的文件夹
source 博客资源文件夹
source/_drafts 草稿文件夹
source/_posts 文章文件夹
themes/landscape 默认皮肤文件夹
……
官方文档中教详细。
配置hexo
做一些基础配置即可,请参考配置官方文档,这里也可以省略,因为在后面配置主题NExt是也有提到这里的配置修改。
IV.Hexo主题修改
Hexo主题非常多,可以参考丰富多彩的Hexo主题,本文选Next为主题,样式参考我的博客视己慎独。
到这里我们还是采用参考官方文档,5 分钟快速安装。在本地修改完这一连串的配置,(包括:语言设置、财产、菜单设置、侧栏设置、头像设置、作者名称、站点描述、标签云页面、分类页面、统计系统、评论系统等等)现在是需要下面的一个命令即可在本地成功预览你的博客样式。
V.Hexo部署方法
写完文章之后 就可以启动本地服务器测试了
$ hexo s #启动本地服务器测试
这个时候在浏览器中输入端口 静态的网站架设完成
当你修改好你想要的样式,包括头像,favicon图标,标题样式,第三方平台链接等等等等你心中完美的页面。那就可以继续下一个阶段了。再提示一点,大家可以hexo主题修改一步就hexo s看下变化,初次接触对参数不清楚。只有hexo s后在可以在本地浏览到效果,Ctrl+C 停止服务器。
链接GitHub、实现在线预览
目录
I.注册GitHub
II.配置和使用 Github
III.SSH Key 配置成功
IV.实现在线预览
现在已经来到第三部分了,请你在坚持一下。
I.注册GitHub
访问: 注册你的username和邮箱,邮箱十分重要,GitHub上很多通知都是通过邮箱的。注册过程比较简单,在此我不再啰嗦。界面任然是英文,请读者耐心一点。
II.配置和使用 Github
配置 SSH keys
我们如何让本地git项目与远程的github建立联系呢?用SSH keys。
检查 SSH keys的设置,首先我们需要检查你电脑上现有的ssh key:
$ cd ~/.ssh 检查本机的ssh密钥
如果提示:No such file or directory 说明你是第一次使用git。
生成新的SSH Key:
$ ssh-keygen -t rsa -C "邮件地址@youremail.com"
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/your_user_directory/.ssh/id_rsa):回车就好
注意1: 此处的邮箱地址,你可以输入自己的邮箱地址;注意2: 此处的「-C」的是大写的「C」
然后系统会要你输入密码:
Enter passphrase (empty for no passphrase):输入加密串
Enter same passphrase again:再次输入加密串
在回车中会提示你输入一个密码,这个密码会在你提交项目时使用,如果为空的话提交项目时则不用输入。这个设置是防止别人往你的项目里提交内容。
注意:输入密码的时候没有*字样的,你直接输入就可以了。
最后看到这样的界面,就成功设置ssh key了:
添加 SSH Key 到 GitHub
在本机设置SSH Key之后,需要添加到GitHub上,以完成SSH链接的设置。
1、打开本地C:\Documents and Settings\Administrator.ssh\id_rsa.pub文件。此文件里面内容为刚才生成人密钥。如果看不到这个文件,你需要设置显示隐藏文件。准确的复制这个文件的内容,才能保证设置的成功。
2、登陆github系统。点击右上角的 Account Settings—SSH Public keys — add another public keys
3、把你本地生成的密钥复制到里面(key文本框中), 点击 add key 就ok了
测试
可以输入下面的命令,看看设置是否成功,git@github.com的部分不要修改:
$ ssh -T git@github.com
如果是下面的反馈:
The authenticity of host 'github.com (207.97.227.239)' can't be established.
RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
Are you sure you want to continue connecting (yes/no)?
不要紧张,输入yes就好,然后会看到:
Hi aierui! You've successfully authenticated, but GitHub does not provide shell access.
设置用户信息
现在你已经可以通过 SSH 链接到 GitHub 了,还有一些个人信息需要完善的。
Git 会根据用户的名字和邮箱来记录提交。GitHub 也是用这些信息来做权限的处理,输入下面的代码进行个人信息的设置,把名称和邮箱替换成你自己的,名字必须是你的真名,而不是GitHub的昵称。
$ git config --global user.name "aierui"//用户名
$ git config --global user.email "imland@outlook.com"//填写自己的邮箱
III.SSH Key 配置成功
本机已成功连接到 github。若有问题,请重新设置。常见错误请参考:
GitHub Help - Generating SSH Keys 和 GitHub Help - Error Permission denied (publickey)
IV.实现在线预览
创建仓库和本地远程到GitHub仓库
首先在GitHub上创建一个仓库repository,注意仓库名称必须为aierui.github.io,也是你之前在本地建立的文件夹名称,这里由于存在这个名称的仓库,无法重名。
# 将当前的改动暂存在本地仓库
$ git add .
# 将暂存的改动提交到本地仓库,并写入本次提交的注释是”first post“
$ git commit -m "first post"
# 将远程仓库在本地添加一个引用:origin
$ git remote add origin
# 向origin推送gh-pages分支,该命令将会将本地分支gh-pages推送到github的远程仓库,并在远程仓库创建一个同名的分支。该命令后会提示输入用户名和密码。
$ git push origin gh-pages
在GitHub上将gh-pages merge 到msater上
添加部署代码
在站点的-config.yml文件新增字段
Deployment 站点部署到github要配置这里, 非常重要
deploy:
type: git 部署类型若有问题,其他类型自行google之
repository:
branch: master
plugins: -hexo-generator-feed
merge后就可以部署上去了,在Git命令黑窗口里输入
$ hexo g #生成静态网页
$ hexo d #开始部署
完成以上步骤,你算是成功了。在浏览器中输入aierui.github.io(自己对应即可)看到了你在本地搭建的博客主页一样,哇哇哇哇哇哇。开心死你了,不要忘了回来给我点赞呀~
Enjoy~
购买域名并解析
这一环节相对简单,可以参考一步步在GitHub上创建博客主页(3),
一元搞定域名(重头戏)
仅限在校的高校学生,社会人士请自行绕开,老老实实花钱购买吧
废话少说,直接上链接看我是怎么办到的一元搞定域名还送服务器,全体咆哮。我们大家一起欢呼一起咆哮吧,哈哈哈。
云+校园计划是腾讯云为在读高校生量身打造的扶持计划,旨在为高校生提供先进的技术支持、资金扶持和经验分享。同时让更多高校生了解云计算及互联网知识,为后续职业、创业发展奠定基础。
学生们请仔细研读腾讯云官方论坛领取的规则参与领取
将独立域名与 GitHub Pages 的空间绑定
DNS 设置
领取到域名后进行解析,进入到我的域名管理,添加域名,如下图设置。我这里设置了一个三级域名blog,大家可以自行忽略。设置后访问的就是blog.shijinrong.cn了,不是shijinrong.cn哟~~~~
其中A的两条记录指向的ip地址是github Pages的提供的ip
192.30.252.153
192.30.252.154
如博客不能登录,有可能是 github 更改了空间服务的 ip 地址,记得及时到在GitHub Pages查看最新的ip即可
www 指定的记录是你在 github 注册的仓库。
GitHub Pages 的设置
去到你的aierui.github.io 仓库,点击 CNAME(没有自行创建) ,再点击右下角的 铅笔 编辑,将 blog.shijinrong.cn 改成你的域名
域名绑定成功,域名解析成功,因此你在浏览中输入aierui.github.io或者现在blog.shijinrong.cn均可以访问到主页。
搭建成功快和小白自己不愿动手说拜拜吧,同时也恭喜你成为博主。记得常联系我喔~~嘻嘻
日后站点的管理和运营
如何更新博文
下载博客模板的ZIP,去到你frok的仓库地址:你的用户名/你的用户名.github.io。点击右下角的Download ZIP,你会得到一个名为「你的用户名.github.io-master.zip」的压缩包。
安装 github desktop管理你的博文
这里不再多赘述,可以看看官方文档,有使用说明。
图床
推荐使用七牛(10G空间,免费,配合Markdown使用简单)。
MarkDown
百度一大堆教程,但是我还是推荐锤子科技锤子便签做的教程。代码板块的MarkDown请读者自行学习。
有的,我最近研究了一下,写了一篇记录,如下
原文地址:
网上关于七牛云存储的教程除了官网上的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.com,表单提供了一个输入框key,用来输入你想保存的图片名称,上传到七牛之后就是这个名字。
然后一个文件选择,一个提交按钮。运行结果如下:
输入key值和选择照片即可实现照片的上传。哈哈哈有没有很简单。
三、文件下载
原理和文件上传功能相仿。
引入文件
require_once(dirname(__FILE__)."/../../qiniu/rs.php");
声明你的七牛云存储域名和两个密钥以及向下载的文件名称
$key = '00000';
$domain = 'designpartners.qiniudn.com';
$accessKey = 'IOImn35KC5p3scxbYkvNk6oIxB7zWsBRp16';
$secretKey = 's29vc9tlCvs23wCDmIbUSi4EroKj1z';
注意:1.key值即为文件名,不要加后缀
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";
传入这四个值即可生成一样url,直接访问url即可实现图片的下载。
在引入图片时直接
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)}';
注意: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.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="" 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