使用语言PHP
$bucket='XX';
$AK='XXXXXXXXXXXXXXXXXXXXXXXXXXXX';
$SK='XXXXXXXXXXXXXXXXXXXXXXXXXXXX';
functionbase64_urlSafeEncode($data)
{
$find= array('+','/');
$replace= array('-','_');
returnstr_replace($find,$replace,base64_encode($data));
}
$putPolicy=[
'insertOnly'=>1,//已新增模式增加
'scope'=>$bucket,//空间名称
'deadline'=>time()+3600,//token有效期
];
$jsonData=json_encode($putPolicy);
$encodedPutPolicy=base64_urlSafeEncode($jsonData);
$sign=hash_hmac('sha1',$encodedPutPolicy,$SK, true);
$encodedSign=base64_urlSafeEncode($sign);
$uploadToken=$AK':'$encodedSign':'$encodedPutPolicy;
var_dump($uploadToken);
利用ftp定时上传log到其他服务器的方法
利用ftp定时上传log到其他服务器 #!/bin/bash #时间的生成 Y=` date --date="-1 hour" +%Y` m=` date --date="-1 hour" +%m` d=`date --date="-1 hour" +%d` H=`date --date="-1 hour" +%H`
IPhone上传到服务器
求助:IPhone上传到服务器 我在网上看到 IPhone上传到服务器用的是PHP的web接收,地址: 我只会aspnet ,请问用ASPnet和IPhone怎么结合实现手机端的上传到服务器上 求助!!! 重点在:if (move_uploaded_file($_FILES['u
android开发以上传到七牛云存储服务器
android开发之上传到七牛云存储服务器 相信很多开发者会把存放到七牛上,我的web站点也是吧存储到七牛上,对于以为主的站点,这样可以节省很大带宽。 将上传到七牛服务器的重点就是获得上传凭证uploadToken,直接把AccessKey和Secret放到客户端太不安全,容易被反编译。所以需要在服务器端根据AccessKey和Secret动态生成一个uploadToken,
Markdown的语法简单,可以通过符号语言简单地实现,方便使用。支持Markdown语法的工具很多,其中有Typora,MacDown,有道云笔记等。各大博文网站基本支持Markdown语法的文档编写。
文档编写少不了,无图不成文。MarkDown语法中的是使用Url的方式展现,这样就要求有一个网络地址。类似的图床比如新浪图床、七牛云、腾讯云、阿里云等。
1、首先,MarkDownde的编辑工具,推荐使用: Typora
Typora — a markdown editor, markdown reader
2、打开 Typora 后,就可以开始编辑文章了!文字的编写遵循相应的语法规则。
在编辑文章的时候,它支持截图再粘贴到文本中,这个功能很好用!还支持直接拖拽到文档里,编辑文章的方式非常的轻量,简洁!
如果没有配置图床地址的话,修改下设置,将存储到指定位置(文件—偏好设置—图像中)。
如果要把写的文档发布到网络,那么文档中的就需要挨个上传,无法一键发布。为了解决这个问题,可以使用 图床功能 !
当使用了图床功能后,我们在截图或者拖拽到文档中的时候,会自动上传到图床上,这样可以方便我们后续将文章顺利发送到网上。
这里需要用到 PicGo 工具:
Releases · Molunerfinn/PicGo · GitHub
免费搭建个人图床工具PicGo,支持Windows、MacOS 和 Linux,
软件目前覆盖的图床有:七牛图床、腾讯云COS、又拍云图床、GitHub图床、SMMS图床、阿里云OSS、Imgur图床等
PicGo的配置手册 使用指南
使用PicGo搭配Github图床
Jsdeiver
验证上传选项,成功后配置就完成了。
PS:当然上传的都是公开的,所以请勿将私有的使用它来上传。
至此,便可通过 Typora 的图床配置完成,我们只要在 编辑的文档中粘贴 ,就能够自动上传到 github图床 ,可以优雅的编写文档了。然后我们把这篇文章复制到网上的各个平台的时候,就可以自动配置了,不用手动上传了。
1、Github 图床载体,创建项目,获取用户Token
2、PicGo 上传工具,将Github信息配置到PicGo中,实现上传功能
3、Typora 文档编辑工具,关联PicGo,实现文档编辑时的实时上传
有的,我最近研究了一下,写了一篇记录,如下
原文地址:>
网上关于七牛云存储的教程除了官网上的API文档,其他的资料太少了。研究了下API之后,现在已经能实现的上传和下载及上传之后的重定向。
首先本篇文章实现的功能如下:
1利用表单上传功能,用户可以点击选择文件按钮,选择本地的一个文件,同时设定上传的的名称,点击上传按钮可以上传并存储到七牛云存储。
2在点击上传时会检测文件的后缀名,限制为jpg和png格式存储。
3上传成功后跳转到自己设定的一个URL,并传回文件信息,如文件名。而不是显示七牛白花花的json显示页面。
好啦,那我们开始吧,首先我们要有一个七牛云存储账号,如果没有的就自己去申请吧。
七牛云存储传送门:>
一SDK下载
>
戳这个网址下载一下SDK吧,里面封装了文件上传下载等等的方法,我们引入之后可以直接调用。
SDK之中有一个qiniu的文件夹,这是所有的SDK实货,这个是最重要的。我们首先要把这个文件夹及里面的文件放到项目文件夹中,比如我放到这里。
大家可以看到有一个qiniu文件夹。好啦,资源支持就是这样。接下来我们要实现代码咯。
二文件的上传。
1首先把你七牛云存储的密钥照出来,点击账号设置可以看到有一个AccessKey和SecretKey,留着备用。
2上传凭证生成。
在这里我们首先要引入rsphp文件,自己找一对应路径,代码如下:
require_once(dirname(__FILE__)"///qiniu/rsphp");
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=";action 就填写 upqiniucom,表单提供了一个输入框key,用来输入你想保存的名称,上传到七牛之后就是这个名字。
然后一个文件选择,一个提交按钮。运行结果如下:
输入key值和选择照片即可实现照片的上传。哈哈哈有没有很简单。
三、文件下载
原理和文件上传功能相仿。
引入文件
require_once(dirname(__FILE__)"///qiniu/rsphp");声明你的七牛云存储域名和两个密钥以及向下载的文件名称
$key = '00000';$domain = 'designpartnersqiniudncom';
$accessKey = 'IOImn35KC5p3scxbYkvNk6oIxB7zWsBRp16';
$secretKey = 's29vc9tlCvs23wCDmIbUSi4EroKj1z';
注意:1key值即为文件名,不要加后缀
2domain即为bucket加上qiniudncom,例子中的designpartners就是我在上传时用的bucket名。
3accessKey和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重定向
在上面的方法中,我们上传成功后跳转到upqiniucom下,会显示白白的网页,显示一个json字符串,但是在实际网站开发中我们肯定 不能让用户看到这种网页,所以我们用到了303跳转。SDK中也为我们封装了这个方法。使用其实非常简单。在上传文件的代码中添加两行代码即可
$putPolicy = new Qiniu_RS_PutPolicy($bucket);$putPolicy->ReturnUrl = site_url()"/upload/receiveInfo";
$putPolicy->ReturnBody='{"key": $(key)}';
注意:1 ReturnUrl和ReturnBody必须指定,并且首字母要大写,很多人都小写开头,这样会跳转不成功。
2ReturnUrl必须是一个公网可以访问的网址,在本地测试是不可能通过的。比如你写成localhost,七牛服务器是定位不到的。
3这个ReturnUrl的链接后会跟着一个upload_ret=XXX,可以用get方法获取这个upload_ret。upload_ret的内容是base64安全编码的json形式的key值。
值的解析:比如我上传的文件名是555
upload/receiveInfoupload_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 = documentformfilevaluesubstring(documentformfilevaluelastIndexOf("") + 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/rsphp");
//远程存储空间名称
$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/rsphp");
$key = '00000';
$domain = 'designpartnersqiniudncom';
$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 = documentformfilevaluesubstring(documentformfilevaluelastIndexOf("") + 1);
if (extend == "") {
alert("请选择头像");
return false;
}
else {
if (!(extend == "jpg" || extend == "png")) {
alert("请上传后缀名为jpg或png的文件!");
return false;
}
}
return true;
}
</script>
<form method="post" action=">
错误定位在这行
$host = $zone->srcUpHosts[0];
接着把 $zone 打印了下
null值,也就是说七牛的这个sdk在这里没查找到对应的上传域名(七牛sdk中绑定的域名)
希望能帮到遇到相同问题的后来者,强调:错误定位明确了就好处理了。
上一篇文章介绍了“如何将上传到Cloudinary云平台?”
但是由于Cloudinary的服务器在国外,所以上传和读取的速度会很慢,不适合用作生产,因此有必要再介绍一下国内广受欢迎的“七牛”云平台。以及分步骤给大家介绍如何使用七牛。
各位可以使用我的邀请链接注册: >
流程:七牛云后台的对象存储功能,nodejs后台生成七牛云的token,前端利用elementUI/ice的upload组件,文件名和token作为参数请求到七牛云后台。
配置已经完成,写接口用的是express,koa同理,主要做法是先接收前端的流转换成写入本地image文件中,然后再存储到七牛云,再将本地生成的删除,需要新建一个image文件夹
以上就是关于七牛云根据AK,SK,BUCKET,生成上传凭证全部的内容,包括:七牛云根据AK,SK,BUCKET,生成上传凭证、求助,Android如何定时上传数据到服务器、用Github配置MarkDown图床等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)