需要登录第三方服务器并获取授权用户的内容访问权限。
PhantomJS不合适。
var request = require('request');
var cheerio = require('cheerio');
var credentials = {
username: 'user',
password: 'pass'
};
request.post({
uri: 'http://mysite.ru/login',
headers: { 'content–type': 'application/x–www–form–urlencoded' },
body: require('querystring').stringify(credentials)
}, function(err, res, body){
if(err) {
callback.call(null, new Error(' Login failed'));
return;
}
request('http://mysite.ru/all', function(err, res, body) {
if(err) {
callback.call(null, new Error('Request failed'));
return;
}
var $ = cheerio.load(body);
console.log(body);
});
});
但是输出的html代码给出了相同的登录页面。
我没有要求编辑我的代码,但也许有人会指出正确的教训?最好与PostMan一起使用 - 欧姆(能够分析标准浏览器请求并在应用程序的请求中使用它们)
UPDATE !!! 解决:
var request = require('request');
var cheerio = require('cheerio');
**var request = request.defaults({jar: true})**
var credentials = {
username: 'user',
password: 'pass'
};
request.post({
uri: 'http://mysite.ru/login',
headers: { 'content-type': 'application/x-www-form-urlencoded' },
body: require('querystring').stringify(credentials),
headers: {'user-agent': 'Mozilla/5.0'}
}, function(err, res, body){
if(err) {
callback.call(null, new Error(' Login failed'));
return;
}
request('http://mysite.ru/all', function(err, res, body) {
if(err) {
callback.call(null, new Error('Request failed'));
return;
}
var $ = cheerio .load(body);
console.log(body);
});
});
答案 0 :(得分:0)
var request = require('request');
var cheerio = require('cheerio');
**var request = request.defaults({jar: true})**
var credentials = {
username: 'user',
password: 'pass'
};
request.post({
uri: 'http://mysite.ru/login',
headers: { 'content-type': 'application/x-www-form-urlencoded' },
body: require('querystring').stringify(credentials),
headers: {'user-agent': 'Mozilla/5.0'}
}, function(err, res, body){
if(err) {
callback.call(null, new Error(' Login failed'));
return;
}
request('http://mysite.ru/all', function(err, res, body) {
if(err) {
callback.call(null, new Error('Request failed'));
return;
}
var $ = cheerio.load(body);
console.log(body);
});
});