当前位置:编程学习 > JAVA >>

腾讯微博模拟登录输入验证码问题

***先上代码, 大致功能是模拟登录 然后把cookie存到文件中。
***鄙人设置每登录一个帐号 休息5秒 大概10个左右 就开始要我输入验证码了。
***我将验证码存到D盘,然后查看图片 手动输入验证码 。
***但是一直会出现

1/ij2l5G6GHA555nGImjODZB1tXgo_KFAl/\x00\x00\x00\x00\x33\x78\x0e\x75
需要输入验证码
http://captcha.qq.com/getimage?uin=863506037&aid=46000101&0.11248807175794862
请输入验证码:
numk
测试结果:ptuiCB('7','0','','0','很遗憾,网络连接出现异常,请您稍后再试。(2237663584)', '0');

一直是异常,感觉上这个像是访问过快被封了,但是又有人说是cookie 或者参数传的不对,求高手帮忙看看哪里有问题??(注:不出验证码提示的时候,我程序是ok的。)


/********************* 获取验证码 ***********************/
String codeUrl="http://check.ptlogin2.qq.com/check?uin="+ uin + "&appid=46000101&ptlang=2052&r=" + Math.random();
HttpGet get = new HttpGet(codeUrl);
get.setHeader("Host", "check.ptlogin2.qq.com");
get.setHeader("Referer", "http://t.qq.com/?from=11");
get.setHeader("User-Agent","Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)");
HttpResponse response = client.execute(get);
// HttpResponse response = client.execute(proxy,get);

String entity = EntityUtils.toString(response.getEntity());
String[] checkNum = entity.substring(entity.indexOf("(") + 1,entity.lastIndexOf(")")).replace("'", "").split(",");
String checkCode = checkNum[1];
System.out.println(checkNum[0]+"/"+checkNum[1]+"/"+checkNum[2]);
if(checkNum[0].equals("1")){
System.out.println("需要输入验证码");

String str12 = "http://captcha.qq.com/getimage?uin="+uin+"&aid=46000101&0.11248807175794862";
System.out.println(str12);
URL   url   =   new   URL(str12);                         
URLConnection   uc   =   url.openConnection();                         
InputStream   is   =   uc.getInputStream();                         
File   file   =   new   File("D:/QQwocaonidaye.jpg");                         
FileOutputStream   out   =   new   FileOutputStream(file);                         
int  j =0;                         
while   ((j=is.read())!=-1) {                                 
out.write(j);                         
}                        
is.close();
System.out.println("请输入验证码:");
Scanner input = new Scanner(System.in);
checkCode = input.next();
}
String pass = "";
/******************** *加密密码 ***************************/
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName("javascript");

engine.eval("var hexcase = 1;var b64pad = \"\";var chrsz = 8;var mode = 32;function md5(A) {return hex_md5(A)}function hex_md5(A) {return binl2hex(core_md5(str2binl(A), A.length * chrsz))}"
+ "function str_md5(A) {return binl2str(core_md5(str2binl(A), A.length * chrsz))}function hex_hmac_md5(A, B) {return binl2hex(core_hmac_md5(A, B))}function b64_hmac_md5(A, B) {return binl2b64(core_hmac_md5(A, B))}"
+ "function str_hmac_md5(A, B) {return binl2str(core_hmac_md5(A, B))}"
+ "function core_md5(K, F) {K[F >> 5] |= 128 << ((F) % 32);K[(((F + 64) >>> 9) << 4) + 14] = F;var J = 1732584193;var I = -271733879;var H = -1732584194;var G = 271733878;"
+ "for (var C = 0; C < K.length; C += 16) {var E = J;var D = I;var B = H;var A = G;J = md5_ff(J, I, H, G, K[C + 0], 7, -680876936);G = md5_ff(G, J, I, H, K[C + 1], 12, -389564586);"
+ "H = md5_ff(H, G, J, I, K[C + 2], 17, 606105819);I = md5_ff(I, H, G, J, K[C + 3], 22, -1044525330);J = md5_ff(J, I, H, G, K[C + 4], 7, -176418897);G = md5_ff(G, J, I, H, K[C + 5], 12, 1200080426);H = md5_ff(H, G, J, I, K[C + 6], 17, -1473231341);"
+ "I = md5_ff(I, H, G, J, K[C + 7], 22, -45705983);J = md5_ff(J, I, H, G, K[C + 8], 7, 1770035416);G = md5_ff(G, J, I, H, K[C + 9], 12, -1958414417);H = md5_ff(H, G, J, I, K[C + 10], 17, -42063);"
+ "I = md5_ff(I, H, G, J, K[C + 11], 22, -1990404162);J = md5_ff(J, I, H, G, K[C + 12], 7, 1804603682);G = md5_ff(G, J, I, H, K[C + 13], 12, -40341101);H = md5_ff(H, G, J, I, K[C + 14], 17, -1502002290);I = md5_ff(I, H, G, J, K[C + 15], 22, 1236535329);"
+ "J = md5_gg(J, I, H, G, K[C + 1], 5, -165796510);G = md5_gg(G, J, I, H, K[C + 6], 9, -1069501632);H = md5_gg(H, G, J, I, K[C + 11], 14, 643717713);I = md5_gg(I, H, G, J, K[C + 0], 20, -373897302);"
+ "J = md5_gg(J, I, H, G, K[C + 5], 5, -701558691);G = md5_gg(G, J, I, H, K[C + 10], 9, 38016083);H = md5_gg(H, G, J, I, K[C + 15], 14, -660478335);I = md5_gg(I, H, G, J, K[C + 4], 20, -405537848);"
+ "J = md5_gg(J, I, H, G, K[C + 9], 5, 568446438);G = md5_gg(G, J, I, H, K[C + 14], 9, -1019803690);H = md5_gg(H, G, J, I, K[C + 3], 14, -187363961);I = md5_gg(I, H, G, J, K[C + 8], 20, 1163531501);"
+ "J = md5_gg(J, I, H, G, K[C + 13], 5, -1444681467);G = md5_gg(G, J, I, H, K[C + 2], 9, -51403784);H = md5_gg(H, G, J, I, K[C + 7], 14, 1735328473);I = md5_gg(I, H, G, J, K[C + 12], 20, -1926607734);"
+ "J = md5_hh(J, I, H, G, K[C + 5], 4, -378558);G = md5_hh(G, J, I, H, K[C + 8], 11, -2022574463);H = md5_hh(H, G, J, I, K[C + 11], 16, 1839030562);I = md5_hh(I, H, G, J, K[C + 14], 23, -35309556);"
+ "J = md5_hh(J, I, H, G, K[C + 1], 4, -1530992060);G = md5_hh(G, J, I, H, K[C + 4], 11, 1272893353);H = md5_hh(H, G, J, I, K[C + 7], 16, -155497632);I = md5_hh(I, H, G, J, K[C + 10], 23, -1094730640);"
+ "J = md5_hh(J, I, H, G, K[C + 13], 4, 681279174);G = md5_hh(G, J, I, H, K[C + 0], 11, -358537222);H = md5_hh(H, G, J, I, K[C + 3], 16, -722521979);I = md5_hh(I, H, G, J, K[C + 6], 23, 76029189);J = md5_hh(J, I, H, G, K[C + 9], 4, -640364487);G = md5_hh(G, J, I, H, K[C + 12], 11, -421815835);H = md5_hh(H, G, J, I, K[C + 15], 16, 530742520);"
+ "I = md5_hh(I, H, G, J, K[C + 2], 23, -995338651);J = md5_ii(J, I, H, G, K[C + 0], 6, -198630844);G = md5_ii(G, J, I, H, K[C + 7], 10, 1126891415);H = md5_ii(H, G, J, I, K[C + 14], 15, -1416354905);"
+ "I = md5_ii(I, H, G, J, K[C + 5], 21, -57434055);J = md5_ii(J, I, H, G, K[C + 12], 6, 1700485571);G = md5_ii(G, J, I, H, K[C + 3], 10, -1894986606);H = md5_ii(H, G, J, I, K[C + 10], 15, -1051523);I = md5_ii(I, H, G, J, K[C + 1], 21, -2054922799);"
+ "J = md5_ii(J, I, H, G, K[C + 8], 6, 1873313359);G = md5_ii(G, J, I, H, K[C + 15], 10, -30611744);H = md5_ii(H, G, J, I, K[C + 6], 15, -1560198380);I = md5_ii(I, H, G, J, K[C + 13], 21, 1309151649);"
+ "J = md5_ii(J, I, H, G, K[C + 4], 6, -145523070);G = md5_ii(G, J, I, H, K[C + 11], 10, -1120210379);H = md5_ii(H, G, J, I, K[C + 2], 15, 718787259);I = md5_ii(I, H, G, J, K[C + 9], 21, -343485551);"
+ "J = safe_add(J, E);I = safe_add(I, D);H = safe_add(H, B);G = safe_add(G, A)}if (mode == 16) {return Array(I, H)} else {return Array(J, I, H, G)}}function md5_cmn(F, C, B, A, E, D) {"
+ "return safe_add(bit_rol(safe_add(safe_add(C, F), safe_add(A, D)), E), B)}function md5_ff(C, B, G, F, A, E, D) {return md5_cmn((B & G) | ((~B) & F), C, B, A, E, D)}"
+ "function md5_gg(C, B, G, F, A, E, D) {return md5_cmn((B & F) | (G & (~F)), C, B, A, E, D)}function md5_hh(C, B, G, F, A, E, D) {return md5_cmn(B ^ G ^ F, C, B, A, E, D)}"
+ "function md5_ii(C, B, G, F, A, E, D) {return md5_cmn(G ^ (B | (~F)), C, B, A, E, D)}function core_hmac_md5(C, F) {var E = str2binl(C);if (E.length > 16) {E = core_md5(E, C.length * chrsz)}"
+ "var A = Array(16), D = Array(16);for (var B = 0; B < 16; B++) {A[B] = E[B] ^ 909522486;D[B] = E[B] ^ 1549556828}var G = core_md5(A.concat(str2binl(F)), 512 + F.length * chrsz);"
+ "return core_md5(D.concat(G), 512 + 128)}function safe_add(A, D) {var C = (A & 65535) + (D & 65535);var B = (A >> 16) + (D >> 16) + (C >> 16);return (B << 16) | (C & 65535)}"
+ "function bit_rol(A, B) {return (A << B) | (A >>> (32 - B))}function str2binl(D) {var C = Array();var A = (1 << chrsz) - 1;for (var B = 0; B < D.length * chrsz; B += chrsz) {"
+ "C[B >> 5] |= (D.charCodeAt(B / chrsz) & A) << (B % 32)}return C}function binl2str(C) {var D = \"\";var A = (1 << chrsz) - 1;for (var B = 0; B < C.length * 32; B += chrsz) {"
+ "D += String.fromCharCode((C[B >> 5] >>> (B % 32)) & A)}return D}function binl2hex(C) {var B = hexcase ? \"0123456789ABCDEF\" : \"0123456789abcdef\";var D = \"\";"
+ "for (var A = 0; A < C.length * 4; A++) {D += B.charAt((C[A >> 2] >> ((A % 4) * 8 + 4)) & 15)+ B.charAt((C[A >> 2] >> ((A % 4) * 8)) & 15)}return D}"
+ "function binl2b64(D) {var C = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";var F = \"\";for (var B = 0; B < D.length * 4; B += 3) {var E = (((D[B >> 2] >> 8 * (B % 4)) & 255) << 16)"
+ "| (((D[B + 1 >> 2] >> 8 * ((B + 1) % 4)) & 255) << 8)| ((D[B + 2 >> 2] >> 8 * ((B + 2) % 4)) & 255);for (var A = 0; A < 4; A++) {if (B * 8 + A * 6 > D.length * 32) {F += b64pad"
+ "} else {F += C.charAt((E >> 6 * (3 - A)) & 63)}}}return F}function hexchar2bin(str) {var arr = [];for (var i = 0; i < str.length; i = i + 2) {arr.push(\"\\\\x\" + str.substr(i, 2))"
+ "}arr = arr.join(\"\");eval(\"var temp = '\" + arr + \"'\");return temp}function QXWEncodePwd(pt_uin, p, vc) {var I = hexchar2bin(md5(p));var H = md5(I + TTescapechar2bin(pt_uin));"
+ "var G = md5(H + vc.toUpperCase());return G}function TTescapechar2bin(str) {eval(\"var temp = '\" + str + \"'\");return temp}");
if (engine instanceof Invocable) {
Invocable invoke = (Invocable) engine;
pass = invoke.invokeFunction("QXWEncodePwd",
checkNum[2].trim(), p, checkCode.toUpperCase().trim()).toString();
}

/************************* 登录 ****************************/
登录代码 楼下补上



--------------------编程问答-------------------- String strs="http://ptlogin2.qq.com/login?ptlang=2052&u="+uin+"&p="+pass+"&verifycode="+ checkCode+ "&aid=46000101&u1=http%3A%2F%2Ft.qq.com&h=1&ptredirect=1&ptlang=2052&daid=6&from_ui=1&dumy=&low_login_enable=1&low_login_hour=720®master=&fp=loginerroralert&action=6-27-1386060169686&mibao_css=&t=1&g=1&js_ver=10056&js_type=1&login_sig="+login_sig+"&pt_rsa=0";
get = new HttpGet(strs);
get.setHeader("Accept","application/javascript, */*;q=0.8");
get.setHeader("Accept-Language", "zh-CN");
get.setHeader("Accept-Encoding", "gzip,deflate");
get.setHeader("Connection", "keep-alive");
get.setHeader("Host", "ptlogin2.qq.com");
get.setHeader("Referer", "http://ui.ptlogin2.qq.com/cgi-bin/login?appid=46000101&style=13&lang=&low_login=1&hide_title_bar=1&hide_close_icon=1&self_regurl=http%3A//reg.t.qq.com/index.php&s_url=http%3A%2F%2Ft.qq.com&daid=6");
get.setHeader("User-Agent","Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)");
response = client.execute(get);
// response = client.execute(proxy,get);
entity = EntityUtils.toString(response.getEntity());
System.out.println("测试结果:"+entity); --------------------编程问答-------------------- 求大神帮帮忙吧 QQ:289601537 求指点 --------------------编程问答--------------------
引用 楼主 sunshinan2013 的回复:
鄙人设置每登录一个帐号 休息5秒 大概10个左右 就开始要我输入验证码了

看上去像加了啥心跳机制 --------------------编程问答--------------------
引用 3 楼 defonds 的回复:
Quote: 引用 楼主 sunshinan2013 的回复:



鄙人设置每登录一个帐号 休息5秒 大概10个左右 就开始要我输入验证码了

看上去像加了啥心跳机制
 不知道怎么解决 --------------------编程问答-------------------- 抓包,看看它到底发了什么东东。然后给个模拟心跳解决 --------------------编程问答-------------------- 代码没啥问题。对应这种模拟人工的程序,我只想说有攻就有防,腾讯肯定是对于这样的模拟请求进行了限制。你先用你的程序跑,跑到不能正常的时候,你手动去输入试试,感觉也不行。封IP --------------------编程问答--------------------
引用 6 楼 huxiweng 的回复:
代码没啥问题。对应这种模拟人工的程序,我只想说有攻就有防,腾讯肯定是对于这样的模拟请求进行了限制。你先用你的程序跑,跑到不能正常的时候,你手动去输入试试,感觉也不行。封IP

我现在想退一步,就算出验证码,我手动输入实现登录。
但是现在输完验证码就是
ptuiCB('7','0','','0','很遗憾,网络连接出现异常,请您稍后再试。(3933212426)', '0');
前辈可曾遇到过此问题? --------------------编程问答--------------------
引用 7 楼 sunshinan2013 的回复:
Quote: 引用 6 楼 huxiweng 的回复:

代码没啥问题。对应这种模拟人工的程序,我只想说有攻就有防,腾讯肯定是对于这样的模拟请求进行了限制。你先用你的程序跑,跑到不能正常的时候,你手动去输入试试,感觉也不行。封IP

我现在想退一步,就算出验证码,我手动输入实现登录。
但是现在输完验证码就是
ptuiCB('7','0','','0','很遗憾,网络连接出现异常,请您稍后再试。(3933212426)', '0');
前辈可曾遇到过此问题?

我没做腾讯微博的,但是做过类似的东西。程序请求会被咔嚓掉,可以换换其他思路,比如用代理换IP等等 --------------------编程问答-------------------- 不要沉啊 求助啊 --------------------编程问答-------------------- 不要沉啊
没人会吗???? --------------------编程问答-------------------- 哇,解决这个问题有100积分吗?
我帮你解决,给我分啊 !!!!!QQ:1280470683
补充:Java ,  Web 开发
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,