superagent版本:3.8.3

样例代码:

var process = require('process');
var superagent = require('superagent');
var http = require('http');
var fs = require('fs');
var readline = require('readline'); var picUrl = "http://192.168.1.125:9080/acps-mgm/login/changeValidateCode";
var postUrl = "http://192.168.1.125:9080/acps-mgm/login/login";
var testUrl = "http://192.168.1.125:9080/acps-mgm/merchant/view/235162";
var username = "username";
var password = "e99a18c428cb38d5f260853678922e03"; // "abc123"加密后
var initCookie = "JSESSIONID=00000twI_3HQFk__rHfRohzQJiU:-1"; var options = {
hostname: "192.168.1.125",
port: 9080,
path: "/acps-mgm/login/changeValidateCode",
method: "GET",
headers: {
'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
'Accept-Encoding': 'gzip, deflate',
'Accept-Language': 'zh-CN,zh;q=0.9',
'Cache-Control': 'max-age=0',
'Connection': 'keep-alive',
'Cookie': initCookie,
'Host': '192.168.1.125:9080',
'Upgrade-Insecure-Requests': '1',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36'
}
}
console.log('111');
var reqForPic = http.request(options, function (res) {
console.log("ReqForPic: status = " + res.statesCode);
console.log('ReqForPic: headers = ' + JSON.stringify(res.headers)); var picCookie = res.headers['set-cookie'][0].split(';')[0];
console.log("pic cookie: " + picCookie);
res.setEncoding('binary');
var content = "";
res.on('data', data => content += data)
.on('end', function () {
fs.writeFileSync(__dirname + '/valiCode.jpg', content, 'binary');
console.log('成功下载验证码');
var rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
rl.question("请输入验证码?", answer => {
var valiCode = answer;
rl.close();
console.log("输入的验证码是:" + valiCode); // post部分
superagent.post(postUrl)
.type("form")
.set("Accept", "application/json, text/javascript, */*; q=0.01")
.set("Accept-Encoding", "gzip, deflate")
.set("Accept-Language", "zh-CN,zh;q=0.9")
.set("Connection", "keep-alive")
.set("Content-Length", "72")
.set("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8")
.set("Cookie", picCookie)
.set("Host", "192.168.1.125:9080")
.set("Origin", "http://192.168.1.125:9080")
.set("Referer", "http://192.168.1.125:9080/acps-mgm/login.html")
.set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36")
.set("X-Requested-With", "XMLHttpRequest")
.send({
password: password,
username: username,
vailCode: valiCode
})
.end( function (err, res) { if (err) {
console.log("出错:" + err);
} else {
console.log(res.text); superagent.get(testUrl)
.set("Accept", "*/*")
.set("Accept-Encoding", "gzip, deflate")
.set("Accept-Language", "zh-CN,zh;q=0.9")
.set("Connection", "keep-alive")
.set("Cookie", picCookie)
.set("Host", "192.168.1.125:9080")
.set("Referer", "http://192.168.1.125:9080/acps-mgm/")
.set("User-Agent", "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.140 Safari/537.36")
.end( (err2, res2)=> {
if (err2) {
console.log("出错2:" + err2);
} else {
console.log(res2.text);
}
} );
} } ); });
});
}); reqForPic.on('error', err => console.log("请求验证码的时候发生错误:" + err.message)); reqForPic.end();

node.js使用superagent实现模拟登陆功能(包含下载验证码功能)的更多相关文章

  1. Node.js创建服务器和模拟客户端请求

    1. 何为服务器 服务器是某种长期运行,等待请求资源的应用程序 2. 常见Web应用架构 3. 如何创建web服务器 Web服务器是使用HTTP协议,等待客户端连接后请求资源的驻守应用程序:HTTP协 ...

  2. node.js 使用 superagent 与 cheerio 完成简单爬虫

    目标 建立一个 lesson3 项目,在其中编写代码. 当在浏览器中访问 http://localhost:3000/ 时,输出 CNode(https://cnodejs.org/ ) 社区首页的所 ...

  3. Vue2.0+Node.js+MongoDB全栈打造商城系统 免费下载

    <ignore_js_op> 课程目录||--第01章 课程介绍|    01-01 课程-导学.mp4|    01-02 前端框架回顾.mp4|    01-03 vue概况以及核心思 ...

  4. Node.js使用superagent模拟GET/POST请求样例

    示例代码: var superagent = require('superagent'); superagent.get("http://localhost:8091/user/all?re ...

  5. Node.js 博客实例(五)编辑与删除功能

    原教程 https://github.com/nswbmw/N-blog/wiki/_pages的第五章,因为版本号等的原因,在原教程基础上稍加修改就可以实现. 如今给博客加入编辑文章与删除文章的功能 ...

  6. node.js 使用 net 模块模拟 websocket 握手,进行数据传递。

    websocket 是一种让浏览器与服务器之间建立持久的连接,并能进行双向数据传输的一种协议. websocket 属性应用层协议,基于tcp传输协议,并复用http的握手通道. 一.如何进行webs ...

  7. 原创:用node.js搭建本地服务模拟接口访问实现数据模拟

    前端开发中,数据模拟是必要的,这样就能等后台接口写完,我们直接把接口请求的url地址从本地数据模拟url换成后台真实地址就完成项目了.传参之类的都不用动. 之前网上找了很多类似于mock等感觉都不太实 ...

  8. php 模拟登陆(不带验证码)采集数据

    这里模拟表单登陆窗口 提交代码部分 1,生成session_id保存到 cookie $login_url = 'http://www.96net.com.cn/Login.php';$cookie_ ...

  9. Node.js 使用http客户端得到网站的图片下载到本地

    以下代码有些冗余,大家捡核心看就好. // 内置http模块,提供了http服务器和客户端功能 var http=require("http"); // cheerio模块,提供了 ...

随机推荐

  1. seastar笔记

    1.seastar::A.then([]{B});C:的核心思想是说我们开始了A之后就开始B,开始B之后就开始C,而不需要等A做完了再做B,B做完再做C 2.通常的return是一个需要执行的函数,例 ...

  2. Spring 整合 Quartz框架(定时任务)

    Maven 无法下载 Quartz 依赖,去官网下载 http://www.quartz-scheduler.org/downloads/ Quartz 官方手册:https://www.w3csch ...

  3. Python通过yagmail和smtplib模块发送简单邮件

    SMTP是发送邮件的协议,Python内置对SMTP的支持,可以发送纯文本邮件.HTML邮件以及带附件的邮件.python发邮件需要掌握两个模块的用法,smtplib和email,这俩模块是pytho ...

  4. Postgresql pg_dump

    pg_dump 命令详解 参数 描述 -h 指定服务器名称 -p 指定端口 -U 指定要连接的用户名 -w/--no-password 从不提示密码 -W/--password 强制pg_dump在连 ...

  5. 搭建自己的博客(二十二):通过ajax提交评论信息,并增加公式编辑功能

    编辑功能使用到了ckeditor的MathJax组件.ajax提交评论可以不用刷新浏览器. 1.变化的部分

  6. thinkphp5/php cors跨域处理

    现在做项目,很多都是前后端分离.也就是前段,后端都有自己的域名. 那么前段请求后端接口的时候,就会出现跨域问题.出现跨域的问题,主要 是浏览器的安全策略-同源策略.那么怎么解决跨域问题呢,抛出主角 C ...

  7. 一些scala的操作

    Scala获取当前目录下所有文件 import java.io.File //获取目录下的所有文件,当前项目目录输入new File(".") def getFiles1(dir: ...

  8. 命令行中生成 md5、sha1、sha256 校验和

    在测试过程中有时候需要对某个文件Hash值进行校验,如接口返回一个文件下载地址及hash值,那么除了对比平台端展示和接口下发是否一至,还有一个办法就是命令行使用相关命令 1.Window 注:我是在g ...

  9. PHP 之CI框架+GatewayWorker+AmazeUI低仿微信聊天网页版

    html5开发的仿微信网页版聊天,采用html5+css3+jquery+websocket+amazeui等技术混合架构开发,实现了微信网页版的主要功能. 一.效果图 二.前端参考代码 <!D ...

  10. 什么是vue的全家桶

    vue.js有著名的全家桶系列,包含了vue-router,vuex, vue-resource,再加上构建工具vue-cli,就是一个完整的vue项目的核心构成.