利用phantomjs模拟QQ自动登录
之前为了抓取兴趣部落里的数据,研究了下QQ自动登录。
当时搜索了一番,发现大部分方法都已经失效了,于是准备自己开搞。
第一个想到的就是参考网上已有方案的做法,梳理登陆js的实现,通过其他语言重写。
考虑到js可能会更新,放弃了此方案。
第二个想到的是能不能直接调用QQ自己的js方法,模拟进行提交呢。
搜索一番后发现神器 ———— "phantomjs".
PhantomJS is a headless WebKit scriptable with a JavaScript API. It has fast and native support for various web standards: DOM handling, CSS selector, JSON, Canvas, and SVG.
于是开搞,代码实现如下。
var page = require('webpage').create();
var fs = require("fs");
page.settings.userAgent = 'Mozilla/5.0 (iPhone; CPU iPhone OS 8_0 like Mac OS X) AppleWebKit/600.1.3 (KHTML, like Gecko) Version/8.0 Mobile/12A4345d Safari/600.1.4';
page.open('http://ui.ptlogin2.qq.com/cgi-bin/login?pt_no_onekey=1&style=9&appid=1006102&s_url=http%3A%2F%2Fxiaoqu.qq.com%2Fmobile%2Fbarindex.html%3F_lv%3D29313%26_bid%3D128%26_wv%3D1027%26from%3Dshare_link%23bid%3D37469%26type%3D%26source%3Dindex%26scene%3Drecent%26from%3Ddongtai%26webview%3D1&low_login=0&hln_css=http%3A%2F%2Fpub.idqqimg.com%2Fqqun%2Fxiaoqu%2Fmobile%2Fimg%2Fnopack%2Flogin-logo.png', function(status){
if (status == 'success') {
page.render('index.png');
setTimeout(function() {
page.evaluate(function() {
document.getElementById('u').value = 'QQ号码';
document.getElementById('p').value = 'QQ密码';
pt.check(false);
//document.getElementById('go').click(); //pt.check()或.click()
});
setTimeout(function() {
file = fs.open("cookie.log", 'w');
file.write(JSON.stringify(page.cookies));
file.close();
phantom.exit();
}, 2000);
}, 1000);
}
});
cookie会写入到当前目录下的cookie.log文件,有了cookie接下来的事情就简单多了。使用php或js将cookie种到浏览器下即可。
优化后的qq.js代码:
/**
* QQ自动登录,用phantomjs模拟浏览器,自动登录到QQ兴趣部落
* @example 执行方式:cd /phantom && ./phantomjs qq.js QQ号 QQ密码
* phantomjs下载:http://phantomjs.org/download.html
* 安装依赖(重要,否则会报错):
* sudo yum install fontconfig freetype libfreetype.so.6 libfontconfig.so.1 libstdc++.so.6
*/
var page = require('webpage').create();
var fs = require("fs");
var args = require('system').args; page.settings.userAgent = 'Mozilla/5.0 (iPhone; CPU iPhone OS 8_0 like Mac OS X) AppleWebKit/600.1.3 (KHTML, like Gecko) Version/8.0 Mobile/12A4345d Safari/600.1.4';
page.open('http://ui.ptlogin2.qq.com/cgi-bin/login?pt_no_onekey=1&style=9&appid=1006102&s_url=http%3A%2F%2Fxiaoqu.qq.com%2Fmobile%2Fbarindex.html%3F_lv%3D29313%26_bid%3D128%26_wv%3D1027%26from%3Dshare_link%23bid%3D37469%26type%3D%26source%3Dindex%26scene%3Drecent%26from%3Ddongtai%26webview%3D1&low_login=0&hln_css=http%3A%2F%2Fpub.idqqimg.com%2Fqqun%2Fxiaoqu%2Fmobile%2Fimg%2Fnopack%2Flogin-logo.png', function(status){
if (status == 'success') {
page.render('index.png');
setTimeout(function() {
page.evaluate(function(_args) {
document.getElementById('u').value = _args[1]; //QQ号码
document.getElementById('p').value = _args[2]; //QQ密码
pt.check(false);
}, args); //要使用传参的形式将全局变量args传入到page.evaluate()
setTimeout(function() {
//将cookie转换成json格式写入到cookie.log文件
//file = fs.open("cookie.log", 'w');
//file.write(JSON.stringify(page.cookies));
//file.close(); //将cookie转换成json格式打印出来
console.log(JSON.stringify(page.cookies)); phantom.exit(); //记得退出
}, 2000);
}, 1000);
}
});
qq.js也可以使用以下代码进行自动登录:
page.open('https://ui.ptlogin2.qq.com/cgi-bin/login?style=9&appid=1006102&daid=0&s_url=http%3A%2F%2Fid.qq.com&low_login=0', function(status){
if (status == 'success') {
//page.render('index1.png'); //截屏,为了调试使用
setTimeout(function() {
page.evaluate(function(_args) {
document.getElementById('u').value = _args[1]; //QQ号码
document.getElementById('p').value = _args[2]; //QQ密码
document.getElementById('go').click(); //pt.check()或.click()
}, args); //要使用传参的形式将全局变量args传入到page.evaluate()
setTimeout(function() {
//将cookie转换成json格式写入到cookie.log文件
//file = fs.open("cookie.log", 'w');
//file.write(JSON.stringify(page.cookies));
//file.close();
//将cookie转换成json格式打印出来
console.log(JSON.stringify(page.cookies));
//page.render('index.png'); //截屏,为了调试使用
//console.log(page.content); phantom.exit(); //记得退出 }, 2000); }, 1000); } });
php调用phantomjs代码:
public function actionQqLogin() {
$ret = false;
$qq = 'QQ号';
$pwd = 'QQ密码';
$command = "cd /phantom/ && ./phantomjs qq.js {$qq} {$pwd}";
$cookie_json = @exec($command); //只返回最后一行
//echo $cookie_json.'<br/><br/>'; //test
if ($cookie_json) {
$cookie_arr = json_decode($cookie_json, true);
//print_r($cookie_arr); //test
if ($cookie_arr) {
foreach ($cookie_arr as $cookie) {
//echo $cookie['value'].' ';
//注意:不要用setcookie(),用setrawcookie()不会对cookie value进行url编码
$ret = setrawcookie($cookie['name'], $cookie['value'], $cookie['expires'], '/', $cookie['domain']);
}
}
}
if ($ret) {
echo '登录成功!';
}
//return $ret;
}


phantomjs是一个无界面浏览器,可用于网页截图和前端自动化测试,基于
webkit内核(也就是chrome使用的内核),并使用js编写业务脚本来请求、浏览和操作页面。最近前端监控需要用到phantomjs,特地研究
了一下这个组件,把其中一个大坑发出来给大家分享一下。 !!!!注意page.evaluate中的回调函数作用域链 page.evaluate中的函数是在目标网页执行的,其上下文、作用域链已经不能与phantomjs执行这个js同日而语,因此请勿在evaluate中引用phantomjs的api或你这个js文件中的全局变量,否则出了错,都很难定位。 错误示例: [javascript] view plain copy
var page = require('webpage').create();
var url = 'http://json2form.wikisoft.me//';
var globalVar = 1;
page.open(url, function (status)
{
if (status != "success")
{
console.log('FAIL to load the address');
} page.evaluate(function()
{
var x = globalVar;//引用本js的一个全局变量
page.method();//执行phantomjs的一个api
});
}); 正确引用全局变量的方法是把全局变量进行传参 [javascript] view plain copy
var express = require('express');
var router = express.Router();
var mysql = require('mysql');
var phantom = require('phantom'); /* GET home page. */
router.get('/', function (req, res, next) {
var pageContent,
paraObj = {title: 'lalala3', content: 'notenote3'}; phantom.create().then(function (ph) {
ph.createPage().then(function (page) {
page.open('http://www.baidu.com/').then(function (status) {
page.evaluate(function (_paraObj) {
var desObj = {};
desObj.title = _paraObj.title;
desObj.note = _paraObj.content;
return desObj;
}, paraObj).then(function (_desObj) {
//console.log(html);
res.render('index', {title: _desObj.title, content: _desObj.note});
page.close();
ph.exit();
});
});
});
}); }); module.exports = router;
利用phantomjs模拟QQ自动登录的更多相关文章
- Delphi制作QQ自动登录器源码
Delphi制作QQ自动登录器源码 http://www.cnblogs.com/sunsoft/archive/2011/02/25/1964967.html 以TM2009为例,检查了一下,未登 ...
- QQ自动登录Demo源码(附全套WindowsApi)
在开发过程中,偶尔会有自动化操作软件的需求,便想到用句柄实现自动化的功能,记录下知识点,以作备忘. 实现流程: 获取窗口句柄,根据定位获取input,调用windowsapi模拟鼠标点击, 输入 , ...
- 爬虫模拟cookie自动登录(人人网自动登录)
什么是cookie? 在网站中,HTTP请求时无状态的,也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是谁,cookie的出现就是为了解决这个问题,第一次登陆后服 ...
- 利用JS_SDK实现QQ第三方登录
前言 现如今,第三方登录已成为大部分网站必备的一项基础技能,引入时髦的第三方登录不仅能帮你吸引更多的用户,也让你的网站可以充分利用其他大型网站的用户资源.本次教程将让你的网站最快捷便利地引入QQ登录. ...
- 利用Jsoup模拟跳过登录爬虫获取数据
今天在学习爬虫的时候想着学习一下利用jsoup模拟登录.下面分为有验证码和无验证码的情况进行讨论. ---------------------------无验证码的情况---------------- ...
- QQ自动登录里的一些控件知识
在这个程序里面有个读取计算机指定文件的知识: private void button2_Click(object sender, EventArgs e) { openFileDialog1.Show ...
- QQ模拟自动登录实现
QQ模拟自动登录实现 本篇文章主要介绍"QQ模拟自动登录实现(带验证码)",主要涉及到java 实现QQ自动登录(带验证码)方面的内容,对于java 实现QQ自动登录(带验证码)感 ...
- mac 利用 sshpass 自动登录
mac 利用 sshpass + 配置文件 实现自动登录 使用方式 https://github.com/vipzhicheng/go 参见此项目 其实原理也就是 脚本 读取配置文件 匹配 参数或 ...
- casperjs配合phantomjs实现自动登录百度,模拟点击等等操作 - 怕虎在线www.ipahoo.com图文教程 - 怕虎在线
微信支付取消2万元保证金门槛,这是全民电商来袭!-观点-虎嗅网 微信支付取消2万元保证金门槛,这是全民电商来袭! casperjs配合phantomjs实现自动登录百度,模拟点击等等操作 - 怕虎在线 ...
随机推荐
- inand和emmc区别
简单来说:inand式sandisk公司做的一款符合emmc标准的一个emmc存储器! ----
- gulp browser-sync自动刷新插件
很久没弄gulp了,都快忘了,今天又来温习下browser-sync 自动刷新插件,在安装的时候出现以下提示: $ npm install browser-sync --save-dev> ws ...
- Codeforces Round #205 (Div. 2)
A #include <iostream> #include<cstdio> #include<cstring> #include<algorithm> ...
- 如何使用UIAutomation进行iOS 自动化测试(Part I)
转自:http://www.cnblogs.com/vowei/archive/2012/08/10/2631949.html 写在前面 研究iOS的自动化测试也有些日子了,刚开始的时候,一直苦于找不 ...
- WinScp上传和下载
不多说,贴代码,看不懂得可以留言.需要引入WinSCP public class WebWinScp { //远程上传路径 private SessionOptions sessionOptions ...
- BZOJ_1024_[SHOI2008]_生日快乐_(dfs)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1024 给出一个\(x*y\)的距形,要求平行于边切,最终切成\(n\)个面积相等的小距形,求长 ...
- css动画集合地址
CSS3 UI Lib库是由腾讯AlloyTeam前端开发团队建立,主要收集国内外友好体验和创意的界面组件Demo. 它除了使用CSS3技术外,还使用了HTML5,JS,JX,jQuery等技术,来达 ...
- 待实践三:MVC3下 路由的测试 使用 RouteDebug.dll 来测试判断路由是否符合
在需要进行测试路由是否匹配的项目中引用 RouteDebug.dll 并且在MVC的Global.asax里面加入一段代码 //下面这行代码一定是在 RegisterRoutes(Rou ...
- PhoneGap 安装体验
npm -v #显示版本,检查npm 是否正确安装. npm install express #安装express模块 npm install -g express #加上 -g 启用global安装 ...
- H264 TS/ES
ES流(Elementary Stream): 也叫基本码流,包含视频.音频或数据的连续码流. PES流(Packet Elementary Stream): 也叫打包的基本码流, 是将基 ...