nodejs版的有道云API

nodejs版的有道云API

月光魔力鸭

2018-09-12 10:10 阅读 1019 喜欢 0 有道云 API nodejs

因为自己的记录笔记的应用是有道云,又想着把有道云跟自己的小网站联通起来,所以查找了有道云的API,然后实现了nodejs版本的sdk.

目前实现的比较简单,很多实现都没有进行优化,可能会有些BUG⊙﹏⊙‖∣,主要是提供给大家可以相互借鉴

安装

npm i ydnote

使用

//获取token
var YNote = require('ydnote');

var youdao = new YNote({
    //申请的client id
    clientId : '',
    //申请的client secret
    clientSecret : '',
    //应用回调地址
    oauthUrl : ''
});
//获得有道授权登录地址
console.log(youdao.getOAuthUrl());
//然后根据授权地址回调后返回的code,获得token
youdao.getToken('75875d373ab5e9e8b46f32301169bc19').then(function(token){
    console.log(token);
}).catch(function(e){
    console.log(e.status);
    console.log(e.message);
})

函数使用

再获得token后,将token保存,然后在调用函数的时候即可传token获取相关的信息。

获取用户信息

youdao.getUserInfo(token).then(function(userInfo){
    console.log('获得用户信息:'+userInfo.user)
}).catch(function(e){
    console.log(e.status);
    console.log(e.message);
})

获得所有的笔记本信息

youdao.getAllNotebook(token).then(function( bookList ){
    console.log(`笔记本个数有:${bookList.length}`);
}).catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text)
})

获得笔记本内的所有笔记信息

youdao.getNoteOfBook(token,'/513BEFD144B84F28923AE83B09BB3DF2').then(function( noteList ){
    console.log(`笔记个数有:${noteList.length}`);
}).catch(function(e){
    console.log(e.status);
    console.log(e.message);
})

创建笔记本和删除

youdao.createNotebook(token,'API创建笔记本').then(function(rsObj){
    console.log('笔记本创建成功:'+rsObj.path);
    return youdao.deleteNotebook(token,rsObj.path);
}).then(function(){
    console.log('笔记本删除成功')//删除无返回值
}).catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

创建笔记

youdao.createNote(token,{
    content : '<html><body><p style="color:red">笔记创建测试</p></body></html>',
    // content : 'aaa',
    title : '测试'
}).then(function(rsObj){
    console.log(rsObj);//返回保存后的路径和相关信息
})
.catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

获取笔记信息

youdao.getNote(token,notePath)
.then(function(rsObj){
  console.log(rsObj);//获得笔记的详细信息
})
.catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

修改笔记

youdao.updateNote(token,{
  path : rsObj.path,//笔记的path
  content : '修改'
})
.then(function(rsObj){
    console.log(rsObj);//该函数无返回值
})
.catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

移动笔记

youdao.moveNote(token,rsObj.path,'/513BEFD144B84F28923AE83B09BB3DF2')
.then(function(rsObj){
    console.log(rsObj);//返回移动后的路径
})
.catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

删除笔记

youdao.deleteNote(token,rsObj.path)
.then(function(rsObj){
    console.log(rsObj);//删除无返回值
})
.catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

分享笔记

youdao.publishNote(token,rsObj.path);
.then(function(rsObj){
    console.log(rsObj);//返回分享后生成的URL
})
.catch(function(e){
    console.log(e.status);
    console.log(e.message);
    console.log(e.response.text);
})

文件上传

youdao.upload(token,__dirname+'/test.js')
.then(function(rsObj){
    console.log(rsObj);//返回上传后的路径
})
.catch(function(e){
    console.log(e);
})

下载文件

youdao.download(token,'https://note.youdao.com/yws/open/resource/download/20114/140BC634A1D9455DAC1E0BFBBD7894C5','/home/test.js')
.then(function(rs){
    console.log(rs);//下载完成
})
.catch(function(e){
    console.log(e);
})

以上是目前有道云笔记OpenApi 提供的功能,能做的还是比较少的,勉强能使用。

github地址

如果本文章有帮助到你..麻烦给个小星星啦~ 土豪,请随意..

转载请注明出处: https://chrunlee.cn/article/youdaonote-api-nodejs.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
最近在折腾的时候又想写less了,但是换框架了,成了thinkjs,考虑到开发阶段一直编译编译less的情况..最终根据middleware的特点实现了一个超级简单的less中间件。
在使用puppeteer 跳转窗口的时候,发现waitForNavigator 并不起作用,最后找到通过browser 获得page 并继续操作。
想做微信/支付宝支付很久了..奈何需要的资质太多,只能慢慢申请,等待,审核..终于下来了。
我们项目一直在使用puppeteer 生成pdf ,整体的思路是没有问题的,而且在开发环境运行了好久了,但是部署后总会有各种各样的报错。各种so文件找不到等等 。
关于js的编译和压缩,之前做过一个小工具了,主要就是自己项目成员大都没有这部分的技能,导致发布的时候总需要去编译压缩下.. 最终做了个命令行小工具.. 问题不在这里,前一阵子做压缩的时候发现压缩后竟然是undefined.最终才发现是es6的语法问题。
在通过axios读取页面的时候,经常会碰到gbk的编码,如果不进行转化的话,在获取信息或读取上都会很麻烦。
最近家里正在装修,实在是不知道怎么做,之前看好好住APP上有不少设计的图,部分还挺好看。。就去看了下有没有WEB端,结果还真有,就有了下文,我抓了几万张图片,然后根据关键字进行分类,从里面找心仪的设计。
分享一个自动抓取静态站资源的小工具,可以在抓取某个静态站点的时候方便很多,尤其是如果页面比较多的话,会很难受,而且会自动将资源进行归类,如果一个页面一个页面的保存的话,那就比较费劲了。