authing.js
Authing 的 JavaScript SDK 支持 Angular.js, React.js, Vue.js 以及 Node.js.我们提供了完全一致的接口.
点击体验
安装
data:image/s3,"s3://crabby-images/4a2b2/4a2b2707aa6f73f9224e689b8b3a173d27715322" alt="codecov"
NPM
当构建大规模应用时,我们推荐使用 npm
进行安装, 它可以与一些模块打包工具很好地配合使用,如 Webpack
, Browserify。
# latest stable
$ npm install authing-js-sdk --save
初始化
先从 Authing 控制台 中获取 Client ID。
为保证 secret 安全,在服务端的初始化和客户端的初始化有所不同。
服务端
服务端可直接传入 clientId
和 secret
。
const auth = new Authing({
clientId: 'your_client_id',
secret: 'your_client_secret'
});
auth.then((authing) => {
});
客户端
客户端需传入三个参数
示例
const auth = new Authing({
clientId: 'your_client_id',
timestamp: Math.round(new Date() / 1000),
nonce: Math.ceil(Math.random() * Math.pow(10, 6)),
});
auth.then((authing) => {
});
使用方法
Authing SDK 的所有 API 都支持 Promise。
const Authing = require('authing-js-sdk');
const auth = new Authing({
clientId: 'your_client_id',
secret: 'your_app_secret'
});
auth.then(function(authing) {
authing.login({
email: 'test@testmail.com',
password: 'testpassword'
}).then(function(user) {
console.log(user);
}).catch(function(error) {
console.log(error);
});
}).catch(function(error) {
console.log(error);
});
如果你使用 ES6+
推荐用 await
处理异步,示例如下:
import Authing from 'authing-js-sdk';
const main = async () => {
let auth;
try{
auth = await new Authing({
clientId: 'your_client_id',
secret: 'your_app_secret'
});
}catch(error) {
console.log('Authing 验证失败:', error);
}
if(auth) {
let user;
try {
user = await auth.login({
email: 'test@testmail.com',
password: 'testpassword'
});
}catch(error) {
console.log('登录失败:', error);
}
if(user) {
console.log('login success');
}else {
console.log('login failed');
}
}
}
main();
API
全部 API 请参考:用户接口。
小程序扫码登录
小程序扫码登录指使用 Authing 小程序 身份管家
执行微信登录。
示例:小程序扫码登录
data:image/s3,"s3://crabby-images/e19e3/e19e3f621f74582b6bf50e50cf8a0ec0a3811c82" alt="扫码 demo"
基础用法
使用 startWXAppScaning
方法:
const Authing = require('authing-js-sdk');
const auth = new Authing({
clientId: 'your_client_id',
timestamp: Math.round(new Date() / 1000),
nonce: Math.ceil(Math.random() * Math.pow(10, 6)),
});
auth.then(function(authing) {
authing.startWXAppScaning({
mount: 'qrcode-node',
});
})
扫码完成后会自动跳到用户配置的URL上。
参数说明
authing.startWXAppScaning({
mount: 'qrcode-node',
redirect: true,
onSuccess: function(res) {},
onError: function(error) {},
onIntervalStarting: function(intervalNum) {},
onQRCodeLoad: function(qRcode) {},
onQRCodeShow: function(qRcode) {},
interval: 1500,
tips: '搜索小程序 <strong>身份管家</strong> 扫码登录',
});
了解更多,请查看:使用小程序扫码登录
自定义请求链接
Authing
构造函数包含一个名为 host
对象,可接收自定义的请求链接(适合私有部署 Authing 的用户使用),使用方法如下:
const auth = new Authing({
clientId: 'xxxx',
secret: 'xxxxxx',
host: {
user: 'https://users.authing.cn/graphql',
oauth: 'https://oauth.authing.cn/graphql'
}
});
host
对象中 user
和 oauth
的默认值是 Authing 官方的请求链接:
Node.js其他生态中间件
- express-middleware
- vue-authing
当在浏览器使用时,我们会将用户 token 以 '_authing_token' 字段存在 localStorage 中,后面都会从 localStorage 中读取并进行验证。
了解更多报错的详情,请查看错误代码。
获取 Client ID 和 Client Secret,请点击这里。