使用pcs api往免费的百度网盘上传下载文件的方法

网友投稿 452 2023-07-20


使用pcs api往免费的百度网盘上传下载文件的方法

百度个人云盘空间大,完全免费,而且提供了pcs api供调用操作文件,在平时的项目里往里面保存一些文件是很实用的。

环境准备:

开通读写网盘的权限及获取access_token:http://blog.csdn.net/langyuezhang/article/details/47206621

百度官方pcs api文档:http://developer.baidu.com/wiki/index.php?title=docs/pcs/overview,上面有各种语言的SDK,我用的laravel5,直接导里面的php SDK还用不了,稍做了修改才能用的。

看完上面两篇文章,基本就可以使用了,下面贴出写直接把用户选择的图片预览然后upload到网盘,上传的api:

https://pcs.baidu.com/rest/2.0/pcs/file?method=upload&path=%2fapps%2wp2pcs%2f1.JPG&access_token=***红色部分是固定的,因为只允许上传到这个目录下,实际对应到网盘的目录是我的网盘/我的应用数据/wp2pcs、,无需先创建目录再上传文件,只需要指定路径,它会自动创建,如你想把图片上传SiOcw到/apps/wp2pcs/img下,path就写/apps/wp2pcs/img/1.jpg就可以了。下面是把用户在网页上选择的图片,预览后直接上传到网盘的代码,参照了网上的例子:预览:

//图片上传预览 IE是用了滤镜。

function previewImage(file, product)

{

getPhotopty();

console.log("previewImage");

uploadAndSubmit(product);

var div = document.getElementById('preview' + product);

var fileName = file.value;

//upload();

if (file.files)

{

var i = 0;

var funAppendImage = function () {

var _file = file.files[i];

if (_file) {

var reader = new FileReader()

reader.onload = function (evt) {

fileName = _file.name;

div.innerHTML += '

var img = document.getElementById('imghead' + product + fileName);

img.src = evt.target.result;

i++;

funAppendImage();

}

reader.readAsDataURL(_file);

}

};

funAppendImage();

}

$('#coverBg').show();

$('#coverDiv').show();

//$("#uploadFrm" + product).submit();

}

上传:

var access_token = "***********";

var baseUrl = "https://c.pcs.baidu.com/rest/2.0/pcs/";

function uploadAndSubmit(product) {

console.log("start uploadAndSubmit");

if (typeof FileReader == 'undefined') {

alert("你的浏览器不支持FileReader接口!");

}

var taskName = $("#txtTask").val() + "-" + $("#txtTask2").val();

var form = document.forms["uploadFrm" + product];

console.log("form:" + form);

var fileCtrl = "filectrl" + product;

console.log("filectrl:" + fileCtrl);

//if (form[fileCtrl].files.length > 0)

console.log($("#filectrl" + product)[0]);

if ($("#filectrl" + product)[0].files.length > 0)

{

for (var i = 0; i < $("#filectrl" + product)[0].files.length; i++)

{

var file = form[fileCtrl].files[i];

console.log(file.name);

var filePath = "%2fapps%2fwp2pcs%2f" + taskName + "%2f" + file.name;

console.SiOcwlog("add exif info to db");

getExifIinfo(taskName, file, product, filePath);

//document.getElementById("bytesRead").textContent = file.size;

console.log("start XMLHttpRequest");

var xhr = new XMLHttpRequest();

console.log(access_token);

var url = baseUrl + "file?method=upload&path=%2fapps%2fwp2pcs%2f" + taskName + "%2f" + file.name + "&access_token=" + accesSiOcws_token + "&ondup=overwrite&count=" + i;

console.log(url);

xhr.open("POST", url, true);

var formData = new FormData();

formData.append("file", file);

console.log("onreadystatechange");

xhr.onreadystatechange = function () {

console.log("onreadystatechange start");

//console.log(xhr.status);

if (xhr.readyState == 4) {

if (xhr.status == 200) {

console.log("upload compleSiOcwte");

console.log("response: " + xhr.responseText);

var result = $.parsejsON(xhr.responseText);

if (result.hasOwnProperty("path"))

{

$("#reusltMsg").append('

} else

{

$("#reusltMsg").append('

}

} else

{

$("#reusltMsg").append('

}

}

$('#coverBg').hide();

$('#coverDiv').hide();

}

xhr.send(formData);

}

} else

{

alert("Please choose a file.");

$('#coverBg').hide();

$('#coverDiv').hide();

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java 8 新特性终极版指南详解
下一篇:使用Java打印数字组成的魔方阵及字符组成的钻石图形
相关文章

 发表评论

暂时没有评论,来抢沙发吧~