这几天很有兴致的学习了百度云盘文件API接口的使用;初步是想做一个在线android应用,应用中的文档是存放在百度云盘的。
主要是分一下几个步骤:
1.注册百度账号
2.登录百度开发者中心
3.创建移动应用,获取对应的(API Key Secret Key)
4.开通pcs API权限
6.开发应用
注意:
开通移动应用,获取key
获取token的时候我使用的安卓获取的方式
通过我写对应api的例子我发现,其实就两种情况:一种是get方式提交数据,另外一种是post方式提交数据
1.get方式提交数据,我们用获取云盘的信息为例:
获取云盘信息前我们要知道,我们要准备好什么数据:
请求参数:
url: 标明我们要访问的网址路径 值固定问“https://pcs.baidu.com/rest/2.0/pcs/quota”
method:标明我们是请求云盘信息 值固定为“info”
acceess_token:准入标识 值是我们自己申请的
接收返回参数:
quota:云盘总容量
used:云盘使用容量
request_id:该请求的表示,没啥用
返回的一个json串如下格式:{"quota":123794882560, "used":83573494688,"request_id":2853739529}
我在做的时候你使用Gson工具将json串转换到对应的entity类中了 代码如下:
- /**
- * @param URLConnection conn通过get方式获取StringBuffer
- * @return
- */
- private StringBuffer getJsonString(URLConnection conn) {
- InputStreamReader isr = null;
- BufferedReader br = null;
- StringBuffer sb = null;
- try {
- isr = new InputStreamReader(conn.getInputStream(),"gb2312");
- br = new BufferedReader(isr);
- String line = null;
- sb = new StringBuffer();
- while ((line = br.readLine()) != null) {
- sb.append(line);
- sb.append("\r\n");
- }
- } catch (UnsupportedEncodingException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }finally{
- try {
- if(isr!=null)
- isr.close();
- } catch (IOException e) {
- System.out.println("流关闭是异常");
- e.printStackTrace();
- }
- }
- return sb;
- }
- /**
- * @return
- * @throws Exception
- * 获取云空间的信息
- */
- public CloudInfo getCloudInfo() throws Exception {
- URL u = new URL(https://pcs.baidu.com/rest/2.0/pcs/quota"?method=info&access_token=你申请的token的值";
- URLConnection conn = u.openConnection();// 打开网页链接
- // 获取用户云盘信息
- String cloudJson = this.getJsonString(conn).toString();
- // 解析成对象 下面有这个实体对象的类
- Gson gson = new Gson();
- CloudInfo cloudInfo = gson.fromJson(cloudJson, CloudInfo.class);
- System.out.println("云盘信息:"+cloudInfo);
- return cloudInfo;
- }
/**
* @param URLConnection conn通过get方式获取StringBuffer
* @return
*/
private StringBuffer getJsonString(URLConnection conn) {
InputStreamReader isr = null;
BufferedReader br = null;
StringBuffer sb = null;
try {
isr = new InputStreamReader(conn.getInputStream(),"gb2312");
br = new BufferedReader(isr);
String line = null;
sb = new StringBuffer();
while ((line = br.readLine()) != null) {
sb.append(line);
sb.append("\r\n");
}
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
if(isr!=null)
isr.close();
} catch (IOException e) {
System.out.println("流关闭是异常");
e.printStackTrace();
}
}
return sb;
}
/**
* @return
* @throws Exception
* 获取云空间的信息
*/
public CloudInfo getCloudInfo() throws Exception {
URL u = new URL(https://pcs.baidu.com/rest/2.0/pcs/quota"?method=info&access_token=你申请的token的值";
URLConnection conn = u.openConnection();// 打开网页链接
// 获取用户云盘信息
String cloudJson = this.getJsonString(conn).toString();
// 解析成对象 下面有这个实体对象的类
Gson gson = new Gson();
CloudInfo cloudInfo = gson.fromJson(cloudJson, CloudInfo.class);
System.out.println("云盘信息:"+cloudInfo);
return cloudInfo;
}
- package com.entity;
- import java.lang.reflect.Type;
- /**
- * @author ydcun 获取云空间的信息 例如:
- * {"quota":123794882560, 空间配额,单位为字节
- * "used":83573494688, 已使用空间大小 单位为字节。
- * "request_id":2853739529}
- */
- public class CloudInfo{
- private Double quota;
- private Double used;
- private Double request_id;
- /**
- * @return the quota 空间配额,单位为字节
- */
- public Double getQuota() {
- return quota;
- }
- /**
- * @param quota the quota to set 空间配额,单位为字节
- */
- public void setQuota(Double quota) {
- this.quota = quota;
- }
- /**
- * @return the used 已使用空间大小 单位为字节
- */
- public Double getused() {
- return used;
- }
- /**
- * @param used the used to set 已使用空间大小 单位为字节
- */
- public void setused(Double used) {
- this.used = used;
- }
- /**
- * @return the request_id
- */
- public Double getRequest_id() {
- return request_id;
- }
- /**
- * @param request_id the request_id to set
- */
- public void setRequest_id(Double request_id) {
- this.request_id = request_id;
- }
- @Override
- public String toString() {
- return new StringBuffer().append("空间容量:").append(this.getQuota()/1024/1024).append("M; 已用:").append(this.getused()/1024/1024).append("M; ").toString();
- }
- }
package com.entity;
import java.lang.reflect.Type;
/**
* @author ydcun 获取云空间的信息 例如:
* {"quota":123794882560, 空间配额,单位为字节
* "used":83573494688, 已使用空间大小 单位为字节。
* "request_id":2853739529}
*/
public class CloudInfo{
private Double quota;
private Double used;
private Double request_id;
/**
* @return the quota 空间配额,单位为字节
*/
public Double getQuota() {
return quota;
}
/**
* @param quota the quota to set 空间配额,单位为字节
*/
public void setQuota(Double quota) {
this.quota = quota;
}
/**
* @return the used 已使用空间大小 单位为字节
*/
public Double getused() {
return used;
}
/**
* @param used the used to set 已使用空间大小 单位为字节
*/
public void setused(Double used) {
this.used = used;
}
/**
* @return the request_id
*/
public Double getRequest_id() {
return request_id;
}
/**
* @param request_id the request_id to set
*/
public void setRequest_id(Double request_id) {
this.request_id = request_id;
}
@Override
public String toString() {
return new StringBuffer().append("空间容量:").append(this.getQuota()/1024/1024).append("M; 已用:").append(this.getused()/1024/1024).append("M; ").toString();
}
}
2.通过post方式提交 我用上传单个文件为例子:
同样我们也先了解下上传文件要参数设置:
请求参数:
url: 标明我们要访问的网址路径 值固定问“https://pcs.baidu.com/rest/2.0/pcs/file”
method:标明我们是请求云盘信息 值固定为“upload”
acceess_token:准入标识 值是我们自己申请的
path:是我们要上传到云盘的那个路径下 如/apps/myBaiduCloud/ myBaiduCloud是我们的应用名称(当你获取koten后就会自动生成以你应用名称为名的文件夹)
file:这个就是我们要上传的文件了(要求用post方式上传)
ondup:可选参数,标识当有重名的文件的时候处理方式具体见api
接收返回参数:
返回的也是json串,
path:为我们上传的文件保存的全路径
size:文件的大小有多少字节
ctime/mtime:文件的创建修改时间
其他参数介绍点小标题去api中查看
{
"path" : "/apps/album/README.md"
"size" : 372121,
"ctime" : 1234567890,
"mtime" : 1234567890,
"md5" : "cb123afcc12453543ef",
"fs_id" : 12345,
"request_id":4043312669
}
- /**
- * @param path 云盘存放路径
- * @param name 要上传的文件
- * @return
- * @throws Exception
- */
- public FileBase uploadFile(String path,File file) throws Exception{
- //模拟文件
- String fileName="README.md";
- file = new File(fileName);
- path="%2fapps%2fmybaidu%2f"; // 我用的是url编码过源码为:-> "/apps/mybaidu/
- /"
- //将需要url传值的参数和url组装起来
- String u ="https://pcs.baidu.com/rest/2.0/pcs/file?path="+path+file.getName()+"&method=upload&access_token=你自己申请的token值";
- PostMethod filePost = new PostMethod(u);
- //post提交的参数
- Part[] parts = {new FilePart(fileName,file)};
- //设置多媒体参数,作用类似form表单中的enctype="multipart/form-data"
- filePost.setRequestEntity(new MultipartRequestEntity(parts, filePost.getParams()));
- HttpClient clients = new HttpClient();
- //响应代码
- int status = clients.executeMethod(filePost);
- System.out.println("成功上传"+path+fileName);
- BufferedReader buReader = new BufferedReader(new InputStreamReader(filePost.getResponseBodyAsStream(),"utf-8"));
- StringBuffer sb = new StringBuffer();
- String line;
- while((line=buReader.readLine())!=null){
- sb.append(line);
- }
- buReader.close();
- // 解析成对象
- Gson gson = new Gson();
- FileBase cloudInfo = gson.fromJson(sb.toString(), FileBase.class);
- return cloudInfo;
- }
/**
* @param path 云盘存放路径
* @param name 要上传的文件
* @return
* @throws Exception
*/
public FileBase uploadFile(String path,File file) throws Exception{
//模拟文件
String fileName="README.md";
file = new File(fileName);
path="%2fapps%2fmybaidu%2f"; // 我用的是url编码过源码为:-> "/apps/mybaidu/
/"
//将需要url传值的参数和url组装起来
String u ="https://pcs.baidu.com/rest/2.0/pcs/file?path="+path+file.getName()+"&method=upload&access_token=你自己申请的token值";
PostMethod filePost = new PostMethod(u);
//post提交的参数
Part[] parts = {new FilePart(fileName,file)};
//设置多媒体参数,作用类似form表单中的enctype="multipart/form-data"
filePost.setRequestEntity(new MultipartRequestEntity(parts, filePost.getParams()));
HttpClient clients = new HttpClient();
//响应代码
int status = clients.executeMethod(filePost);
System.out.println("成功上传"+path+fileName);
BufferedReader buReader = new BufferedReader(new InputStreamReader(filePost.getResponseBodyAsStream(),"utf-8"));
StringBuffer sb = new StringBuffer();
String line;
while((line=buReader.readLine())!=null){
sb.append(line);
}
buReader.close();
// 解析成对象
Gson gson = new Gson();
FileBase cloudInfo = gson.fromJson(sb.toString(), FileBase.class);
return cloudInfo;
}
上面代码成功后我们就会在/apps/mybaidu/目录下找到README.md文件
上面代码执行还要倒入对应的jar包:下载
commons-codec-1.3.jar
commons-httpclient-3.0.jar
commons-logging.jar
gson-2.2.1.jar
jsoup-1.6.3.jar
其他的api怎么用百度给了一个很好的演示平台:
好了剩下的就大家自己去模式吧!
用什么问题联系我我们一起探讨----ydcun