我是开发Web服务的初学者,我有一个带有节点js和模块的服务器,我想使用模块OAuth2-restify添加身份验证。但是,当我努力准备get request.Please的请求时,我使用node restify client for make token.有人可以给我提供一些例子。文档上说
如果在Authorization中提供了有效的令牌,则req.username是真实的,并且令牌端点完全由Restify-OAuth2管理。它为给定的客户端ID/客户端密码/用户名/密码组合生成令牌。但是我怎么得到一个代币呢??这是我测试服务宽度时的文档错误-客户端我得到这个错误{“https://github.com/domenic/restify-oauth2”:“invalid_request”,“error_description”:“必须提供一个主体”}
here is my code:
--------------------------------------Server--------------------------------
var SERVER_PORT = 8800;
var restify = require('restify');
var server = restify.createServer({
name: "Example Restify-OAuth2 Client Credentials Server",
//version: require("../../package.json").version,
formatters: {
"application/hal+json": function (req, res, body) {
return res.formatters["application/json"](req, res, body);
}
}
});
server.use(restify.authorizationParser());
server.use(restify.queryParser());
server.use(restify.bodyParser({ mapParams: false }));
var restifyOAuth2 = require("restify-oauth2");
var hooks = require("./hooks");
restifyOAuth2.cc(server, { tokenEndpoint:"/token", hooks: hooks });
//server.use(restify.acceptParser(server.acceptable));
var handlers = require('./handlers');
handlers.setHandlers(server);
server.listen(SERVER_PORT);
--------------------------------------handlers--------------------------------
module.exports = {
setHandlers: function(server)
{
var restify = require('restify');
var token=function(req,res,next) {
owner=req.body.owner;
password=req.password.owner;
if(req.username)
res.send({result:"sucess"});
}
server.get("/token",token);
}
}
-----------------------------client restify for test services--------------------------------
var restify = require('restify');
var client = restify.createJsonClient({
url: 'http://localhost:8800',
version: '*'
});
client.post('/token', { client_id: 'officialApiClient',client_secret: officialApiClient'}, function(err, req, res, obj) {
//assert.ifError(err);
//console.log('%d -> %j', res.statusCode, res.headers);
console.log('%j', obj);
});发布于 2014-02-14 20:37:44
尝试使用以下参数向您的请求添加POST body:
grant_type = client_credentials发布于 2014-12-10 09:49:48
您已经使用基本身份验证和乔迪所说的添加grant_type参数向"token“端点发送了POST请求:
POST /oauth/token
Authorization: Basic Y2xpZW50SWQ6c2VjcmV0
Content-Type: application/x-www-form-urlencoded;charset=UTF-8
grant_type=client_credentialshttps://stackoverflow.com/questions/21084314
复制相似问题