ก่อนอื่นคุณต้องมีบัญชีนักพัฒนา Weibo สิ่งที่เราต้องการคือคีย์แอพแอพ Secre และ Redirect_uri แต่เดิม บริษัท มีขั้นตอนนี้ดังนั้นจึงบันทึกไว้ มีการค้นหามากมายเกี่ยวกับ Baidu
โอเคเริ่มกันเลย:
ก่อนอื่นฉันพบรหัสนี้ออนไลน์และฉันเขียนลิงค์ที่นี่
ฉันมีความสุขมากที่ได้แก้ไขในครั้งเดียว แต่ข้อผิดพลาด " การรีเฟรชโทเค็นล้มเหลว " หลังจากอ่านรหัสฉันกลับ 200 ไม่ใช่ 302 และฉันสับสนเล็กน้อย ไม่ว่าฉันจะศึกษาว่าทำไมสิ่งนี้จึงเกิดขึ้นก่อนฉันใส่ URL ที่เขาสร้างขึ้นบนเบราว์เซอร์และอ่านมัน ฉันเข้าสู่หน้าการอนุญาตและไม่จำเป็นต้องเข้าสู่ระบบก่อน หลังจากดู F12 มันเป็น 200 แน่นอนดังนั้นฉันคิดว่ามันเป็นเพราะฉันไม่ได้เข้าสู่ระบบสำเร็จดังนั้นฉันจึงเริ่มเข้าสู่ระบบ Weibo Backend เพื่อค้นหารหัสดังกล่าว ที่อยู่เดิมถูกลืมไปแล้วและผู้เขียนดั้งเดิมก็อาย
แพ็คเกจ com.spider.httpClient; นำเข้า java.io.bufferedreader; นำเข้า java.io.ioexception; นำเข้า java.io.inputstream; นำเข้า java.io.inputstreamreader; นำเข้า java.net.uri; นำเข้า Java.net.urisyntaxexception; java.util.date; นำเข้า java.util.list; นำเข้า javax.script.invocable; นำเข้า Javax.script.scriptEngine; นำเข้า Javax.script.scriptenginginager; นำเข้า Javax.script.scriptException; org.apache.http.htttentity; นำเข้า org.apache.http.httpresponse; นำเข้า org.apache.http.namevaluepair; นำเข้า org.apache.http.client.clientprotocolexception; org.apache.http.client.config.cookiespecs; นำเข้า org.apache.http.client.entity.urlencodedformentity; นำเข้า org.apache.http.client.methods.httpget; org.apache.http.config.registry; นำเข้า org.apache.http.config.registryBuilder; นำเข้า org.apache.http.cookie.cookiespec; นำเข้า org.apache.http.cookie.cookiesprovider; org.apache.http.impl.client.httpclients; นำเข้า org.apache.http.impl.cookie.defaultcookiespec; นำเข้า org.apache.http.impl.cookie.defaultcookiespecrovider; org.apache.http.protocol.httpcontext; นำเข้า org.apache.http.util.entityutils; นำเข้า com.alibaba.fastjson.jsonarray; นำเข้า com.alibaba.fastjson.jsonobject; วิธีการเข้ารหัสอยู่ใน js * * @author tom * */คลาสสาธารณะ sinaweibologger {ไคลเอนต์ httpClient ส่วนตัว; โพสต์ httppost ส่วนตัว; httpget ส่วนตัวได้รับ; BasicCookiestore ส่วนตัว Cookiestore; ชื่อผู้ใช้สตริงส่วนตัว; // PlainText Account String รหัสผ่านส่วนตัว; // รหัสผ่าน plaintext สตริงส่วนตัว su; // base64 บัญชีที่เข้ารหัสสตริงส่วนตัว sp; // รหัสผ่านที่เข้ารหัส RSA // ข้อมูลที่จำเป็นสำหรับข้อมูลล่วงหน้าเริ่มต้นเริ่มต้น Servertime ส่วนตัวยาว // เซิร์ฟเวอร์การประทับเวลาสตริงส่วนตัว nonce; // เซิร์ฟเวอร์ส่งคืนสตริงส่วนตัว RSAKV; // เซิร์ฟเวอร์ส่งคืนสตริงและรหัสผ่านการเข้ารหัส RSA คือสตริงส่วนตัว Pubkey; // เซิร์ฟเวอร์ส่งคืนคีย์สาธารณะการเข้ารหัส RSA ใช้สำหรับการเข้ารหัส RSA ส่วนตัว INT retcode; // ค่าสถานะสตริงส่วนตัว PCID; INT IS_OPENLOCK ส่วนตัว; private int showpin; การดำเนินการ INT ส่วนตัว // ข้อมูลล่วงหน้า login สิ้นสุดลง // ส่งคืนข้อมูล JSON หลังจากเข้าสู่ระบบสตริงส่วนตัว uid; นิคสตริงส่วนตัว; Domainurls ส่วนตัว jsonarray; // private StringBuffer HeaderCookie = new StringBuffer (); // เข้าสู่ระบบรหัสผ่านเข้ารหัส JS เนื้อหาเนื้อหาส่วนตัวสตริงคงที่ sina_js = "var sinassoencoder = sinassoencoder || {}; (ฟังก์ชั่น () {var hexcase = 0; var chrsz = 8; his.hex_sha1 = ฟังก์ชัน (s) {return binb2hex (core_sha1 core_sha1 = ฟังก์ชั่น (x, len) {x [len >> 5] | = 0x80 << (24-len%32); x [((len+64 >> 9) << 4) +15] = len; var w = array (80); var a = 1732584193; d = 271733878; var e = -1009589776; สำหรับ (var i = 0; i <x.length; i+= 16) {var olda = a; var oldb = b; var oldc = c; var oldd = d; var เก่า = e; W [J] = ROL (W [J-3]^W [J-8]^W [J-14]^W [J-16], 1); VAR t = safe_add (safe_add (rol (a, 5), sha1_ft (j, b, c, d)), safe_add (safe_add (e, w [j]), sha1_kt (j)); e = d; d = c; c = rol (b, 30)) ; b = a; a = t;} a = safe_add (a, olda); b = safe_add (b, oldb); c = safe_add (c, oldc); d = safe_add (d, oldd); e = safe_add (e, เก่า); return array (a, b, c, d, e);}; var sha1_ft = ฟังก์ชั่น (t, b, c, d) {ถ้า (t <20) return (b & c) | (~ b) & d); ถ้า (t <40) กลับ b^c^d; if (t <60) กลับ (b & c) | (b & d) sha1_kt = function (t) {return (t <20)? 1518500249: (t <40)? 1859775393: (t <60)?-1894007588: -899497514;}; msw = (x >> 16)+(y >> 16)+(lsw >> 16); return (msw << 16) | (lsw & 0xfff);}; var rol = ฟังก์ชั่น (num, cnt) {return (num << cnt) | (num >> (32-cnt); mask = (1 << chrsz) -1; สำหรับ (var i = 0; i <str.length*chrsz; i+= chrsz) bin [i >> 5] | = (str.charcodeat (i/chrsz) & mask) << (24-i%32); hex_tab = hexcase? '0123456789abcdef': '0123456789abcdef'; var str = ''; i = 0; i <binarray.length*4; i ++) {str+= hex_tab.charat ((binarray [i >> 2] >> ((3-i%4)*8+4)) & 0xf)+hex_tab.charat ((binarray [i >> 2] str;}; this.base64 = {encode: function (input) {input = ''+input; if (input == ') return' '; var output =' '; var chr1, chr2, chr3 =' 'var enc1, enc2, enc3 i = 0; ทำ {chr1 = input.charcodeat (i ++); chr2 = input.charcodeat (i ++); chr3 = input.charcodeat (i ++); enc1 = chr1 >> 2; en; c2 = ((Chr1 & 3) << 4) | (chr2 >> 4); enc3 = ((chr2 & 15) << 2) | (chr3 >> 6); enc4 = chr3 & 63; ถ้า (isnan (chr2)) {enc3 = enc4 = 64; ถ้า (isnan (chr3)) {enc4 = 64;} output = เอาต์พุต+this._keys.charat (enc1)+this._keys.charat (enc2)+this._keys.charat (enc3)+enc3 = enc3 = enc3 เอาท์พุท;}, _ keys: 'abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz0123456789+/='};}) call (sinassoencoder); j_lm = ((canary & 0xffffffff) == 0xefcafe); ฟังก์ชั่น biginteger (a, b, c) {ถ้า (a! = null) ถ้า ('number' == typeof a) this.fromnumber (a, b, c); this.FromString (a, b);} ฟังก์ชั่น nbi () {ส่งคืน biginteger ใหม่ (null);} ฟังก์ชั่น am1 (i, x, w, j, c, n) {ในขณะที่ (-n> = 0) {var v = x*นี่ [i ++]+w [j]+c; c = math.floor (v/0x4000000); w [j ++] = v & 0x3ffffff;} return c;} ฟังก์ชั่น am2 (i, x, w, j, c, n) {var xl = x & 0x7fff l = this [i] & 0x7ff; var h = this [i ++] >> 15; var m = xh*l+h*xl; l = xl*l+((m & 0x7ffff) << 15)+w [j]+(c & 0x3ffffffff); c = (l >>> 30)+(m >>> 15)+xh*h+(c >>> 30); am3 (i, x, w, j, c, n) {var xl = x & 0x3ffff, xh = x >> 14; ในขณะที่ (-n> = 0) {var l = this [i] & 0x3ffff; var h = this [i ++] >> 14; var; var; var; var; var; var; m = xh*l+h*xl; l = xl*l+((m & 0x3ffff) << 14)+w [j]+c; c = (l >> 28)+(m >> 14)+xh*h; w [j ++] = l & 0xffffffff; c;} biginteger.prototype.am = am3; dbits = 28; biginteger.prototype.db = dbits; biginteger.prototype.dm = (1 << dbits) -1); biginteger.prototype.dv = (1 < bi_fp = 52; biginteger.prototype.fv = math.pow (2, bi_fp); biginteger.prototype.f1 = bi_fp-dbits; biginteger.prototype.f2 = 2*dbits-bi_fp; bi_rm = '0123456789abcdefghijklmnopqrstuvwxyz'; var bi_rc = อาร์เรย์ใหม่ (); var; rr, vv; rr = '0'.charcodeat (0); สำหรับ (vv = 0; vv <= 9; ++ vv) bi_rc [rr ++] = vv; rr =' a'.charcodeat (0); สำหรับ (vv = 10 ; vv <36; ++ vv) bi_rc [rr ++] = vv; rr = 'a'.charcodeat (0); สำหรับ (vv = 10; vv <36; ++ vv) bi_rc [rr ++] = vv; ฟังก์ชั่น; int2char (n) {return bi_rm.charat (n);} ฟังก์ชั่น intat (s, i) {var c = bi_rc [s.charcodeat (i)]; return (c == null)?-1: c;} ฟังก์ชั่น bnpcopyto (r) {สำหรับ (var i = this.t-1; i> = 0;-i) r [i] = this [i]; rt = this.t; rs = this.s;} ฟังก์ชั่น bnpfromint (x) {this.t = 1; this.s = (x <0)?-1: 0; ถ้า (x> 0) nbv (i) {var r = nbi (); r.fromint (i); return r;} ฟังก์ชั่น bnpfromstring (s, b) {var k; ถ้า (b == 16) k = 4; อื่น ๆ ถ้า (b == 8) k = 3; ถ้า b == 256) k = 8; if (b == 4) k = 2; else {this.fromradix (s, b); return;} this.t = 0; this.s = 0; var i = s.length, mi = false, sh = 0; ในขณะที่ (-i> = 0) {var x = (k == 8)? s [i] & 0xff: intat (s, i); ถ้า (x <0) {ถ้า (s.charat (i) == '-') mi = true; ดำเนินการต่อ;} mi = false; ถ้า (sh == 0) สิ่งนี้ if (sh+k> this.db) {this [this.t-1] | = (x & ((1 << (this.db-sh))-1)) << sh; นี่ [this.t ++] = (x >> (this.db-sh));} อื่น สิ่งนี้ [this.t-1] | = x << sh; sh+= k; ถ้า (sh> = this.db) sh- = this.db;} ถ้า (k == 8 && (s [0] & 0x80)! = 0) {this.s = -1; คือ [this.t-1] | = ((1 << << (this.db-sh))-1) << sh;} this.clamp (); ถ้า (mi) biginteger.zero.subto (นี่); bnpclamp () {var c = this.s & this.dm; ในขณะที่ (this.t> 0 && this [this.t-1] == c)-this.t;} ฟังก์ชั่น bntoString (b) {ถ้า (this.s <0) กลับ '-'+this.negate () ถ้า (b == 2) k = 1; อื่น ๆ ถ้า (b == 32) k = 5; อื่น ๆ ถ้า (b == 4) k = 2; อื่น ๆ กลับมา this.toradix (b); var km = (1 << k) -1, d, m = false, r = '' p = this.db- (i*this.db)%k; if (i-> 0) {ถ้า (p <this.db && (d = this [i] >> p)> 0) {m = true; r = int2char (d);} ในขณะที่ (i> = 0) {ถ้า (p <k) {d = ( (kp); d | = this [-i] >> (p+= this.db-k);} else {d = (นี่ [i] >> (p- = k)) & km; ถ้า (p <= 0) {p+= this.db; m? r: '0';} ฟังก์ชั่น bnnegate () {var r = nbi (); biginteger.zero.subto (นี่, r); return r;} ฟังก์ชั่น bnabs () {return (this.s <0)? i = this.t; r = ia.t; ถ้า (r! = 0) return r; ในขณะที่ (-i> = 0) ถ้า ((r = this [i] -a [i])! = 0) return r; return 0;} function nbits (x) {var r = 1, t; ถ้า ((t = x >>> 16)! = 0) {x = t; r+= 16;} ถ้า ((t = x >> 8)! = 0) {x = t; r+= 8;} ถ้า ((t = x >> 4) ! = 0) {x = t; r+= 4;} ถ้า ((t = x >> 2)! = 0) {x = t; r+= 2;} ถ้า ((t = x >> 1)! = 0) {x = t; r+= 1;} r;} ฟังก์ชั่น bnbitLength () {ถ้า (this.t <= 0) ส่งคืน 0; return.db*(this.t-1)+nbits (นี่ [this.t-1]^(this.s & this.dm));} ฟังก์ชั่น bnbitlength () this.db*(this.t-1)+nbits (นี่ [this.t-1]^(this.s & this.dm));} ฟังก์ชั่น bnpdlshiftto (n, r) {var i; สำหรับ (i = this.t-1; i> = 0; -i) r [i+n] = this [i]; สำหรับ (i = n-1; i> = 0; -i) r [i] = 0; rt = this.t+n; rs = this.s;} bnpdrshiftto (n, r) i = n; i <this.t; ++ i) r [ใน] = this [i]; rt = math.max (this.tn, 0); rs = this.s;} ฟังก์ชั่น bnplshiftto (n, r) {var bs = n%this.db; ds = math.floor (n/this.db), c = (this.s << bs) & this.dm, i; สำหรับ (i = this.t-1; i> = 0;-i) {r [i+ds+1] = (นี่ [i] >> cbs) | c; c = (นี่ [i] & bm) << bs;} สำหรับ (i = ds-1; i> = 0; -i) r [i] = 0; r [ds] = c; rt = this.t+ds+1; rs = this.s; r.clamp (); bnprshiftto (n, r) {rs = this.s; var ds = math.floor (n/this.db); ถ้า (ds> = this.t) {rt = 0; return;} var bs = n%this.db; var cbs = this.db-bs; var bm = (1 < i = ds+1; i <this.t; ++ i) {r [i-ds-1] | = (นี่ [i] & bm) << cbs; r [i-ds] = this [i] >> bs;} ถ้า (bs> 0) r [this.t-ds-1] | = (this.s & bm) << cbs; bnpsubto (a, r) {var i = 0, c = 0, m = math.min (at, this.t); ในขณะที่ (i <m) {c+= this [i] -a [i]; r [i ++] = c & this.dm; c >> = this.db;} ถ้า (ที่ <this.t) {c- =; is.dm; c >> = this.db;} c+= this.s;} else {c+= this.s; ในขณะที่ (i <at) {c- = a [i]; r [i ++] = c & this.dm; c >> = this.db;} c- = as;} rs = (c <0)?-1: 0; ถ้า (c <-1) r [i ++] = this.dv+c; if (c> 0) r [i ++] = c; rt = i; r.clamp ();} ฟังก์ชั่น bnpmultiplyto (a, r) {var x = this.abs (), y = a.abs (); var; i = xt; rt = i+yt; ในขณะที่ (-i> = 0) r [i] = 0; สำหรับ (i = 0; i <yt; ++ i) r [i+xt] = x.am (0, y [i], r, i, 0, xt); rs = 0; bnpsquareto (r) {var x = this.abs (); var i = rt = 2*xt; ในขณะที่ (-i> = 0) r [i] = 0; สำหรับ (i = 0; i <xt-1; ++ i) {var c = x.am (i, x [i], r, 2*i, 0,1); ถ้า (((r [i+xt]+= x.am (i+1,2*x [i], r, 2*i+1, c, xt-i-1))> = x.dv) {r [i+xt ]-= x.dv; r [i+x.t+1] = 1;}} ถ้า (rt> 0) r [rt-1]+= x.am (i, x [i], r, 2*i, 0,1); rs = 0; r.clamp ();}; bnpdivremto (m, q, r) {var pm = m.abs (); ถ้า (pm.t <= 0) กลับ; var pt = this.abs (); ถ้า (pt.t <pm.t) {ถ้า (q! = null) q.fromint (0); ถ้า (r! = null) y = nbi (), ts = this.s, ms = ms; var nsh = this.db-nbits (pm [pm.t-1]); ถ้า (nsh> 0) {pm.lshiftto (nsh, y); pt.lshiftto (nsh, r);} {pm.copyto (y); y0 = y [ys-1]; ถ้า (y0 == 0) return; var yt = y0*(1 << this.f1)+((ys> 1)? y [ys-2] >> this.f2: 0); var d1 = this.fv/yt, d2 = (1 << this.f1) i = rt, j = i-ys, t = (q == null)? nbi (): q; y.dlshiftto (j, t); ถ้า (r.compareto (t)> = 0) {r [r.t ++] = 1; r.subto (t, r); ในขณะที่ (yt <ys) y [y.t ++] = 0; ในขณะที่ (-j> = 0) {var qd = (r [-i] == y0)? this.dm: math.floor (r [i]*d1+(r [i-1]+e)*d2); ถ้า ((r [i]+= y.am (0, qd , r, j, 0, ys)) <qd) {y.dlshiftto (j, t); r.subto (t, r); ในขณะที่ (r [i] <-qd) r.subto (t, r);}}} if (q! = null) {r.drshiftto (ys, q); ถ้า (ts! = ms) biginteger.zero.subto (q, q);} rt = ys; r.clamp (); if (nsh> 0) r.rshiftto (nsh, r); r = nbi (); this.abs (). divremto (a, null, r); ถ้า (this.s <0 && r.compareto (biginteger.zero)> 0) A.Subto (r, r); return r;} ฟังก์ชั่นคลาสสิก (m) {this.m = m; cconvert (x) {ถ้า (xs <0 || x.compareto (this.m)> = 0) ส่งคืน x.mod (this.m); อื่น ๆ กลับ x;} ฟังก์ชั่น crevert (x) {return x;} ฟังก์ชั่น creduce (x) {x.divremto (this.m, null, x); cmulto (x, y, r) {x.multiplyto (y, r); this.reduce (r);} ฟังก์ชัน csqrto (x, r) {x.squareto (r); this.reduce (r);} classic.prototype.convert = cconvert; classic.prototype.revert = crevert; classic.prototype.reduce. bnpinvdigit () {ถ้า (this.t <1) return 0; var x = this [0]; if ((x & 1) == 0) return 0; var y = x & 3; y = (y*(2- (x & 0xf)*y)) & 0xf; y = (y*(2- (x & 0xff)*y)) & 0xff; y = (y*(2-((x & 0xffff)*y) & 0xff; xffff))) & 0xffff; y = (y*(2-x*y%this.dv))%this.dv; return (y> 0)? this.dv-y: -y;} ฟังก์ชัน Montgomery (m) {this.m = m; this.mp = m.invdigit (); this.mpl = this.mp & 0x7ff; this.mph = this.mp >> 15; this.um = (1 << (m.db-15))-1; this.mt2 = 2*mt; r = nbi (); x.abs (). dlshiftto (this.mt, r); r.divremto (this.m, null, r); ถ้า (xs <0 && r.compareto (biginteger.zero)> 0) this.m.subto (r, r); r = nbi (); x.copyto (r); this.reduce (r); return r;} ฟังก์ชั่น montreduce (x) {ในขณะที่ (xt <= this.mt2) x [x.t ++] = 0; สำหรับ (var i = 0; u0 = (j*this.mpl+(((j*this.mph+(x [i] >> 15)*this.mpl) & this.um) << 15)) & x.dm; j = i+this.mt; x [j]+= this.m.am (0, u0, x, i, 0, this.mt); e (x [j]> = x.dv) {x [j]-= x.dv; x [++ j] ++;}} x.clamp (); x.drshiftto (this.mt, x); if (x.compareto (this.m)> = 0) x.subto (this.m, x); montsqrto (x, r) {x.squareto (r); this.reduce (r);} ฟังก์ชัน montmulto (x, y, r) {x.multiplyto (y, r); this.reduce (r);} montgomery.prototype.convert = montconvert; montgomery.prototype.revert = montre Vert; Montgomery.prototype.Reduce = Montreduce; Montgomery.prototype.multo = Montmulto; Montgomery.prototype.sqrto = Montsqrto; ฟังก์ชั่น; bnpiseven () {return ((this.t> 0)? (สิ่งนี้ [0] & 1): this.s) == 0;} ฟังก์ชั่น bnpexp (e, z) {ถ้า (e> 0xffffffffffe r = nbi (), r2 = nbi (), g = z.convert (this), i = nbits (e) -1; g.copyto (r); ในขณะที่ (-i> = 0) {z.sqrto (r, r2); ถ้า (e & (1 << i)> 0) t = r; r = r2; r2 = t;}} return z.revert (r);} ฟังก์ชั่น bnmodpowint (e, m) {var z; ถ้า (e <256 || m.iseven ()) z = ใหม่คลาสสิก (m) this.exp (e, z);} biginteger.prototype.copyto = bnpcopyto; biginteger.prototype.fromint = bnpfromint; biginteger.prototype.fromstring = bnpfromstring; iginteger.prototype.clamp = bnpclamp; biginteger.prototype.dlshiftto = bnpdlshiftto; biginteger.prototype.dlshiftto = bnpdlshiftto; biginteger.protot ype.drshiftto = bnpdrshiftto; biginteger.prototype.lshiftto = bnplshiftto; biginteger.prototype.rshiftto = bnprshiftto; biginte ger.prototype.subto = bnpsubto; biginteger.prototype.multiplyto = bnpmultiplyto; biginteger.prototype.squareto = bnpsquareto; bi; ginteger.prototype.divremto = bnpdivremto; biginteger.prototype.invdigit = bnpinvdigit; biginteger.prototype.iseven = bnpiseeve n; biginteger.prototype.exp = bnpexp; biginteger.prototype.toString = bntoString; biginteger.prototype.negate = bnnegate; biginte ger.prototype.abs = bnabs; biginteger.prototype.compareto = bncompareto; biginteger.prototype.bitlength = bnbitlength; BigInteg er.prototype.mod = bnmod; biginteger.prototype.modpowint = bnmodpowint; biginteger.zero = nbv (0); biginteger.one = nbv (1); ฟังก์ชั่น; arcfour () {this.i = 0; this.j = 0; this.s = new Array ();} ฟังก์ชั่น arc4init (คีย์) {var i, j, t; สำหรับ (i = 0; i <256; ++ i) this.s [i] = i; j = 0; สำหรับ (i = 0; i <256; ++ i) {j = (j+this.s [i]+key [i%key ความยาว]) & 255; t = this.s [i]; this.s [i] = this.s [j]; this.s [j] = t;} this.i = 0; this.j = 0;} ฟังก์ชัน arc4next () {var t; this.i = (this.i+1) & 255; this.j = (this.j+this.s [this.i]) & 255; t = this.s [this.i]; this.s [this.i] = this.s [this.j]; this.s [(t+this.s [this.i]) & 255];} arcfour.prototype.init = arc4init; arcfour.prototype.next = arc4next; ฟังก์ชั่น prng_newstate () {กลับมาใหม่ rng_pptr; ฟังก์ชั่น rng_seed_int (x) {rng_pool [rng_pptr ++]^= x & 255; rng_pool [rng_pptr ++]^= (x >> 8) & 255; rng_pool [rng_pptr ++]^ = (x >> 16) & 255; rng_pool [rng_pptr ++]^= (x >> 24) & 255; ถ้า (rng_pptr> = rng_psize) rng_pptr- = rng_psize;} ฟังก์ชัน rng_seed_time () {rng_seed_int (วันที่ใหม่ (). getTime ());} ถ้า (rng_pool = null) {rng_pool = new Array (); rng_pptr = 0; var; t; ในขณะที่ (rng_pptr <rng_psize) {t = math.floor (65536*math.random ()); rng_pool [rng_pptr ++] = t >>> 8; rng_pool [rng_pptr ++] = t & 255; rng_get_byte () {ถ้า (rng_state == null) {rng_seed_time (); rng_state = prng_newstate (); rng_state.init (rng_ พูล); สำหรับ (rng_pptr = 0; rng_pptr <rng_pool.length; ++ rng_pptr) rng_pool [rng_pptr] = 0; rng_pptr = 0;} return rng_state.next ();} ฟังก์ชั่น rng_get_bytes (ba) {var i; สำหรับ (i = 0; i <ba.length; ++ i) ba [i] = rng_get_byte (); parsebigint (str, r) {ส่งคืนใหม่ biginteger (str, r);} ฟังก์ชั่น linebrk (s, n) {var ret = ''; var i = 0; ในขณะที่ (i+n <s.length) {ret+= s.substring (i, i+n)+'// n'; i+= n; byte2Hex (b) {ถ้า (b <0x10) ส่งคืน '0'+b.toString (16); อื่นกลับ b.toString (16);} ฟังก์ชั่น pkcs1pad2 (s, n) {ถ้า (n <s.length+11) {return null; C = S.CharCodeat (i-); ถ้า (C <128) {Ba [-n] = C;} อื่น if ((c> 127) && (c <2048)) {ba [-n] = (c & 63) | 128; ba [-n] = (c >> 6) | 192;} else {ba [-- n] = (C & 63) | 128; ba [-n] = (c >> 6) & 63) | 128; ba [-n] = (c >> 12) | 224;}} ba [-n] = 0; var; rng = ใหม่ securerandom (); var x = new array (); ในขณะที่ (n> 2) {x [0] = 0; ในขณะที่ (x [0] == 0) rng.nextbytes (x); ba [-n] = x [0];} ba [-n] = 2; rsakey () {this.n = null; this.e = 0; this.d = null; this.p = null; this.q = null; this.dmp1 = null; this.dmq1 = null; this.coeff = null;} ฟังก์ชัน rsasetpublic (n, e) {ถ้า (n! = null && e! = null && n.length> 0 && e.length> 0) {this.n = parsebigint (n, 16); this.e = parseint (e, 16); x.modpowint (this.e, this.n);} ฟังก์ชั่น rsaencrypt (ข้อความ) {var m = pkcs1pad2 (ข้อความ, (this.n.bitlength ()+7) >> 3); ถ้า (m == null) ส่งคืน null; var c = this.dopublic (m); H = C.TOSTRING (16); ถ้า ((H.Length & 1) == 0) กลับ H; eltle return '0'+h;} rsakey.prototype.dopublic = rsadopublic; rsakey.prototype.setPublic = rsasetpublic; this.rsakey = rsakey;}). การโทร (sinassoencoder); ฟังก์ชั่น getpass (pwd, serviceTime, nonce, rsapubkey) {var rsakey = ใหม่ sinassoencoder.rsakey (); rsakey.setpublic (rsapubkey, '10001'); รหัสผ่าน = rsakey.encrypt ([serviceTime, nonce] .join ('// t')+'// n'+pwd); ส่งคืนรหัสผ่าน;} "; sinaweibologger สาธารณะ Mycookiestore (); Cookiespecprovider MyCookie = ใหม่ Cookiespecprovider () {Cookiespec สาธารณะสร้าง (บริบท httpContex .build (); เข้ารหัสรหัสผ่านผู้ใช้เพื่อขออีกครั้ง * * @throws ioexception * @throws clientprotocolexception * @throws urisyntaxexception */ โมฆะส่วนตัว prelogin () พ่น clientprotocolexception, ioexception, urisyntaxexception "UTF-8"). getBytes ())); String preloginurl = "http://login.sina.com.cn/sso/prelogin.php?entry=account&callback=sinassocontroller.prelogincallback&su=" + su + "& rsakt = mod & client = ssologin.js get.seturi (uri ใหม่ (preloginurl)); get.addheader ("โฮสต์", "login.sina.com.cn"); get.addheader ("ผู้ใช้ตัวแทน", "Mozilla/5.0 (Windows NT 6.1; wow64; RV: 45.0) Gecko/20100101 Firefox/45.0"); get.addheader ("ยอมรับ", "*/*"); get.addheader ("ยอมรับภาษา", "zh-cn, zh; q = 0.8, en-us; q = 0.5, en; q = 0.3"); get.addheader ("ยอมรับการเข้ารหัส", "gzip, deflate"); get.addheader ("ผู้อ้างอิง", "http://login.sina.com.cn/"); get.addheader ("การเชื่อมต่อ", "Keep-Alive"); httpresponse resp = client.execute (รับ); // บันทึกคำขอและส่งคืนคุกกี้ หลังจากเข้าสู่ระบบคุณต้องใช้คุกกี้เพื่อขอหน้าอื่น ๆ Savecookie (resp.getallheaders (), this.headercookie); HTTPENTITY เอนทิตี = resp.getEntity (); String cont = entityUtils.toString (เอนทิตี); // system.out.println (ต่อ); cont = cont.replace ("sinassocontroller.prelogincallback (", ""); cont = cont.replace (")", ""); jsonObject json = jsonobject.parseObject (ต่อ); this.retCode = json.getIntValue ("retcode"); this.servertime = json.getLongValue ("servertime"); this.pubkey = json.getString ("pubkey"); this.rsakv = json.getString ("RSAKV"); this.is_openlock = json.getIntValue ("is_openlock"); this.showpin = json.getIntValue ("showpin"); this.exectime = json.getIntValue ("exectime"); } โมฆะส่วนตัว Savecookie (ส่วนหัว [] ส่วนหัว, HeaderCookie StringBuffer) {สำหรับ (ส่วนหัว H: ส่วนหัว) {ถ้า (h.getName (). เท่ากับ ("set-cookie")) {HeaderCookie.Append (h.getValue ()) }}}} / ** * เข้าสู่บัญชี Sina Pass, เข้ารหัสรหัสผ่าน, การโพสต์คำขอ * * @return * * @throws ioexception * @throws clientProtocolexception * @throws scriptexception * @throws nosuchmethodexception * @throws urisyntaxexception clientprotocolexception, ioexception, urisyntaxexception {// 2 สตริง loginurl = "http://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.4.15)&_=" + วันที่ใหม่ () post.seturi (uri ใหม่ (loginurl)); post.addheader ("โฮสต์", "login.sina.com.cn"); post.addheader ("ผู้ใช้ตัวแทน", "Mozilla/5.0 (Windows NT 6.1; wow64; RV: 45.0) Gecko/20100101 Firefox/45.0"); post.addheader ("ยอมรับ", "*/*"); post.addheader ("ประเภทเนื้อหา", "แอปพลิเคชัน/x-www-form-urlencoded"); post.addheader ("ยอมรับภาษา", "zh-cn, zh; q = 0.8, en-us; q = 0.5, en; q = 0.3"); post.addheader ("ยอมรับการเข้ารหัส", "gzip, deflate"); post.addheader ("ผู้อ้างอิง", "http://login.sina.com.cn/"); post.addheader ("การเชื่อมต่อ", "Keep-Alive"); // ใช้ js เพื่อเข้ารหัสรหัสผ่าน RSA โทรหาวิธีการใน JS ScriptengineManager SEM = ใหม่ ScriptenGinEmanager (); ScriptEngine SE = Sem.GetEngineByName ("JavaScript"); se.eval (sina_js); if (se instanceof revocable) {revocable iv = (สามารถเรียกได้) se; sp = (สตริง) iv.invokefunction ("getPass", this.password, this.servertime, this.nonce, this.pubkey); } รายการ <NameValuePair> parms = new ArrayList <NameValuePair> (); parms.add (ใหม่ BasicNameValuePair ("รายการ", "บัญชี")); parms.add (ใหม่ BasicNameValuePair ("Gateway", "1")); parms.add (ใหม่ BasicNameValuePair ("จาก", "")); parms.add (ใหม่ BasicNameValuePair ("Savestate", "0")); parms.add (ใหม่ BasicNameValuePair ("Savestate", "0")); parms.add (ใหม่ BasicNameValuePair ("USETICKET", "0")); parms.add (ใหม่ BasicNameValuePair ("PageRefer", "")); parms.add (ใหม่ BasicNameValuePair ("VSNF", "1")); parms.add (ใหม่ BasicNameValuePair ("su", su)); parms.add (ใหม่ BasicNameValuePair ("บริการ", "SSO")); PARMS.Add (ใหม่ BasicNameValuePair ("servertime", servertime + "")); parms.add (ใหม่ BasicNameValuePair ("nonce", nonce)); PARMS.ADD (ใหม่ BasicNameValuePair ("PWENCODE", "RSA2")); parms.add (ใหม่ BasicNameValuePair ("RSAKV", RSAKV)); PARMS.Add (ใหม่ BasicNameValuePair ("SP", SP)); parms.add (ใหม่ BasicNameValuePair ("SR", "1366*768")); parms.add (ใหม่ BasicNameValuePair ("การเข้ารหัส", "UTF-8")); PARMS.Add (ใหม่ BasicNameValuePair ("cdult", "3")); PARMS.Add (ใหม่ BasicNameValuePair ("โดเมน", "sina.com.cn")); parms.add (ใหม่ BasicNameValuePair ("prelt", "51")); PARMS.Add (ใหม่ BasicNameValuePair ("returnType", "text")); post.setEntity (urlencodedFormentity ใหม่ (PARMS)); httpresponse resp = client.execute (โพสต์); // บันทึกคำขอและส่งคืนคุกกี้ หลังจากเข้าสู่ระบบคุณต้องมีคุกกี้ Savecookie (resp.getallheaders (), this.headercookie); // คำขอคืนลิงก์ jsonObject jsonobj = jsonobject.parseObject (entityutils.toString (resp.getEntity ())); System.out.println (jsonobj.tojsonstring ()); this.retCode = jsonobj.getIntValue ("retcode"); this.uid = jsonobj.getString ("uid"); this.nick = jsonobj.getString ("nick"); this.domainurls = jsonobj.getjsonarray ("crossdomainurllist"); รายการ <String> retmsg = arrayList ใหม่ <String> (); int i = 0; สำหรับ (URL Object: DomainUrls) {get.seturi (uri ใหม่ (url.toString ()+"& callback = sinassocontroller.docrossdomaincallback & scriptId = sscipline"+i+"& client = ssologin.js (v1.4.15) & _ ="+"+"+" resp = client.execute (รับ); retmsg.add (entityutils.toString (resp.getEntity ())); i ++; } get.seturi (uri ใหม่ ("http://login.sina.com.cn/member/my.php?entry=sso")); // เพิ่มคุกกี้คำขอลงในส่วนหัวคำขอ get.addheader ("คุกกี้", this.headercookie.toString ()); resp = client.execute (รับ); String cont = readstreambyencoding (resp.getEntity (). getContent (), "gbk"); retmsg.add (ต่อ); สำหรับ (String s: retmsg) {system.out.println (s); }} สตริงส่วนตัว readStreamByEncoding (inputStream ใน, การเข้ารหัสสตริง) พ่น IOException {StringBuffer cont = new StringBuffer (); bufferedReader br = new bufferedReader (ใหม่ inputStreamReader (ใน, การเข้ารหัส)); สตริง tmp = ""; ในขณะที่ ((tmp = br.readline ())! = null) {cont.append (tmp); } br.close (); return cont.toString (); } / *** เข้าสู่ระบบ* / โมฆะสาธารณะเข้าสู่ระบบ () {ลอง {this.prelogin (); this.accountlogin (); } catch (clientprotocolexception e) {e.printstacktrace (); } catch (ioexception e) {e.printstacktrace (); } catch (nosuchmethodexception e) {e.printstacktrace (); } catch (scriptexception e) {e.printstacktrace (); } catch (urisyntaxexception e) {e.printstacktrace (); }} public httpClient getClient () {return client; } โมฆะสาธารณะ setClient (ไคลเอนต์ httpClient) {this.client = ไคลเอนต์; } สาธารณะ httppost getPost () {return post; } โมฆะสาธารณะ setPost (โพสต์ httppost) {this.post = post; } public httpget getGet () {return get; } โมฆะสาธารณะ setget (httpget get) {this.get = get; } สตริงสาธารณะ getUserName () {ส่งคืนชื่อผู้ใช้; } โมฆะสาธารณะ setUserName (ชื่อผู้ใช้สตริง) {this.userName = ชื่อผู้ใช้; } สตริงสาธารณะ getSu () {return su; } โมฆะสาธารณะ setsu (String su) {this.su = su; } สตริงสาธารณะ getSp () {return sp; } โมฆะสาธารณะ setSp (สตริง sp) {this.sp = sp; } สตริงสาธารณะ getNonce () {return nonce; } โมฆะสาธารณะ setNonce (สตริง nonce) {this.nonce = nonce; } สตริงสาธารณะ getRsAkv () {return rsakv; } โมฆะสาธารณะ setRsAkv (สตริง rsAkv) {this.rsakv = rsakv; } สตริงสาธารณะ getPubkey () {return pubkey; } โมฆะสาธารณะ setPubkey (String pubkey) {this.pubkey = pubkey; } public int getRetCode () {return retcode; } โมฆะสาธารณะ setRetCode (int retCode) {this.RetCode = retCode; } สตริงสาธารณะ getUid () {return uid; } โมฆะสาธารณะ setuid (string uid) {this.uid = uid; } สตริงสาธารณะ getNick () {return nick; } โมฆะสาธารณะ setnick (สตริงนิค) {this.nick = nick; } สตริงคงที่สาธารณะ getSina_js () {return sina_js; } สาธารณะ BasicCookiestore getCookiestore () {return cookiestore; } โมฆะสาธารณะ setCookiestore (BasicCookiestore Cookiestore) {this.cookiestore = cookiestore; } โมฆะคงที่สาธารณะหลัก (สตริง [] args) {ใหม่ sinaweibologger ("", "") .login (); - การเข้าสู่ระบบค่อนข้างประสบความสำเร็จดังนั้นฉันจึงเพิ่มการแก้ไขบางอย่างในรหัสนี้และหลังจากเรียกใช้รหัสแล้วมีการรายงานข้อผิดพลาดการรีเซ็ตการเชื่อมต่อ
หลังจากการวิจัยพบว่าการอนุญาตได้รับการอนุญาตสำเร็จ แต่หลังจากการอนุญาตได้สำเร็จหน้าจะถูกเปลี่ยนเส้นทางสองครั้งดังนั้นข้อผิดพลาดนี้จะถูกรายงาน ดังนั้นฉันจึงเริ่มเขียนลิงก์ที่นี่อีกครั้ง
ในที่สุดก็พบสิ่งที่ฉันต้องการในเรื่องนี้
/ ** * รับตำแหน่งการเปลี่ยนเส้นทางทั้งหมดตามลิงก์ที่กำหนด * ลิงค์ @param ที่ให้ไว้ลิงก์ * @return * @throws clientprotocolexception * @throws ioexception */ รายการสาธารณะ <uri> getAllredirectLocations (ลิงก์สตริง) โยน clientprotocolexception การตอบสนองแบบ closeablehtpresponse = null; ลอง {httpClientContext context = httpClientContext.create (); httpget httpget = new httpget (ลิงก์); การตอบสนอง = httpClient.execute (httpget, บริบท); // รับตำแหน่งการเปลี่ยนเส้นทางทั้งหมดการเปลี่ยนเส้นทาง = context.getRedirectLocations (); } ในที่สุด {ถ้า (ตอบกลับ! = null) {response.close (); }} ส่งคืนการเปลี่ยนเส้นทาง; -ด้วยวิธีนี้ด้วย SDK ของ Weibo ชุดปฏิบัติการจาก Weibo ไปยังการส่ง Weibo จะเสร็จสมบูรณ์ รหัสที่สมบูรณ์มีดังนี้:
แพ็คเกจ weibo4j.examples.test; นำเข้า java.io.ioexception; นำเข้า java.net.uri; นำเข้า java.net.urisyntaxexception; นำเข้า java.net.urlencoder; นำเข้า java.text.simpledateformat javax.script.invocable; นำเข้า Javax.script.scriptEngine; นำเข้า Javax.script.scriptenginagenager; นำเข้า Javax.script.scriptException; นำเข้า org.apache.Commons.codec.binary.base64; org.apache.http.htttentity; นำเข้า org.apache.http.httpresponse; นำเข้า org.apache.http.namevaluepair; นำเข้า org.apache.http.client.clientprotocolexception; org.apache.http.client.entity.urlencodedformentity; นำเข้า org.apache.http.client.methods.closeablehttpresponse; นำเข้า org.apache.http.client.methods.httpget org.apache.http.client.protocol.httpClientContext; นำเข้า org.apache.http.config.registry; นำเข้า org.apache.http.config.registryBuilder; นำเข้า org.apache.http.cookie.cookiespec; org.apache.http.impl.client.basiccookiestore; นำเข้า org.apache.http.impl.client.httpclients นำเข้า org.apache.http.impl.client.httpclients; นำเข้า org.apache.http.impl.cookie.defaultcoolients.httpclients; org.apache.http.message.basicnamevaluepair; นำเข้า org.apache.http.protocol.httpcontext; นำเข้า org.apache.http.util.entityutils; นำเข้า weibo4j.oauth; นำเข้า weibo4j.timeline; weibo4j.model.status; นำเข้า weibo4j.model.weiboexception; นำเข้า weibo4j.util.weiboconfig; นำเข้า com.alibaba.fastjson.jsonarray; นำเข้า com.alibaba.fastjson.jsonobject; RSA2, วิธีการเข้ารหัสใน JS * * @author TOM * */คลาสสาธารณะ Sinaweibologger {ไคลเอนต์ httpClient ส่วนตัว; โพสต์ httppost ส่วนตัว; httpget ส่วนตัวได้รับ; BasicCookiestore ส่วนตัว Cookiestore; ชื่อผู้ใช้สตริงส่วนตัว; // PlainText Account String รหัสผ่านส่วนตัว; // รหัสผ่าน plaintext สตริงส่วนตัว su; // base64 บัญชีที่เข้ารหัสสตริงส่วนตัว sp; // รหัสผ่านที่เข้ารหัส RSA // ข้อมูลที่จำเป็นสำหรับข้อมูลล่วงหน้าเริ่มต้นเริ่มต้น Servertime ส่วนตัวยาว // เซิร์ฟเวอร์การประทับเวลาสตริงส่วนตัว nonce; // เซิร์ฟเวอร์ส่งคืนสตริงส่วนตัว RSAKV; // เซิร์ฟเวอร์ส่งคืนสตริงและรหัสผ่านการเข้ารหัส RSA คือสตริงส่วนตัว Pubkey; // เซิร์ฟเวอร์ส่งคืนคีย์สาธารณะการเข้ารหัส RSA ใช้สำหรับการเข้ารหัส RSA ส่วนตัว INT retcode; // ค่าสถานะสตริงส่วนตัว PID; INT IS_OPENLOCK ส่วนตัว; private int showpin; การดำเนินการ INT ส่วนตัว // ข้อมูลล่วงหน้า login สิ้นสุดลง // ส่งคืนข้อมูล JSON หลังจากเข้าสู่ระบบสตริงส่วนตัว uid; นิคสตริงส่วนตัว; Domainurls ส่วนตัว jsonarray; // string clientId = weiboconfig.getValue ("client_id"); String redirecturi = weiboconfig.getValue ("redirect_uri"); String AdventiZeUrl = Weiboconfig.getValue ("AuthorizeUrl"); Private StringBuffer HeaderCookie = New StringBuffer (); //Login password encrypts js file content private static String sina_js = "var sinaSSOEncoder=sinaSSOEncoder||{};(function(){var hexcase=0;var chrsz=8;this.hex_sha1=function(s){return binb2hex(core_sha1(str2binb(s),s.length*chrsz));};var core_sha1=function(x,len){x[len>>5]|=0x80<<(24-len%32);x[((len+64>>9)<<4)+15]=len;var w=Array(80);var a=1732584193;var b=-271733879;var c=-1732584194;var d=271733878;var e=-1009589776;for(var i=0;i<x.length;i+=16){var olda=a;var oldb=b;var oldc=c;var oldd=d;var old=e;for(var j=0;j<80;j++){if(j<16)w[j]=x[i+j];else w[j]=rol(w[j-3]^w[j-8]^w[j-14]^w[j-16],1);var t=safe_add(safe_add(rol(a,5),sha1_ft(j,b,c,d)),safe_add(safe_add(e,w[j]),sha1_kt(j)));e=d;d=c;c=rol(b,30) ;b=a;a=t;}a=safe_add(a,olda);b=safe_add(b,oldb);c=safe_add(c,oldc);d=safe_add(d,oldd);e=safe_add(e,old);} return Array(a,b,c,d,e);};var sha1_ft=function(t,b,c,d){if(t<20)return(b&c)|(~b)&d);if(t<40)return b^c^d;if(t<60)return(b&c)|(b&d)|(c&d);(c&d);return b^c^d;};var sha1_kt=function(t){return(t<20)?1518500249:(t<40)?1859775393:(t<60)?-1894007588:-899497514;};var safe_add=function(x,y){var lsw=(x&0xFFFF)+(y&0xFFFF);var msw=(x>>16)+(y>>16)+(lsw>>16);return(msw<<16)|(lsw&0xFFF);};var rol=function(num,cnt){return(num<<cnt)|(num>>>(32-cnt));};var str2binb=function(str){var bin=Array();var mask=(1<<chrsz)-1;for(var i=0;i<str.length*chrsz;i+=chrsz)bin[i>>5]|=(str.charCodeAt(i/chrsz)&mask)<<(24-i%32);return bin;};var binb2hex=function(binarray){var hex_tab=hexcase?'0123456789ABCDEF':'0123456789abcdef';var str='';for(var i=0;i<binarray.length*4;i++){str+=hex_tab.charAt((binarray[i>>2]>>((3-i%4)*8+4))&0xF)+hex_tab.charAt((binarray[i>>2]>>((3-i%4)*8))&0xF);}return str;};this.base64={encode:function(input){input=''+input;if(input=='')return '';var output='';var chr1,chr2,chr3='';var enc1,enc2,enc3,enc4='';var i=0;do{chr1=input.charCodeAt(i++);chr2=input.charCodeAt(i++);chr3=input.charCodeAt(i++);enc1=chr1>>2;en c2=((chr1&3)<<4)|(chr2>>4);enc3=((chr2&15)<<2)|(chr3>>6);enc4=chr3&63;if(isNaN(chr2)){enc3=enc4=64;}else if(isNaN(chr3)){enc4=64;}output=output+this._keys.charAt(enc1)+this._keys.charAt(enc2)+this._keys.charAt(enc3)+this._keys.charAt(enc4);chr1=chr2=chr3='';enc1=enc2=enc3=enc4='';}while(i<input.length);return output;},_keys:'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='};}).call(sinaSSOEncoder);;(function(){var dbits;var canary=0xdeadbeefcafe;var j_lm=((canary&0xffffffff)==0xefcafe);function BigInteger(a,b,c){if(a!=null)if('number'==typeof a)this.fromNumber(a,b,c);else if(b==null && 'string' !=typeof a)this.fromString(a,256);else this.fromString(a,b);}function nbi(){return new BigInteger(null);}function am1(i,x,w,j,c,n){while(--n>=0){var v=x*this[i++]+w[j]+c;c=Math.floor(v/0x4000000);w[j++]=v&0x3ffffff;}return c;}function am2(i,x,w,j,c,n){var xl=x&0x7fff,xh=x>>15;while(--n>=0){var l=this[i]&0x7ff;var h=this[i++]>>15;var m=xh*l+h*xl;l=xl*l+((m&0x7ffff)<<15)+w[j]+(c&0x3ffffffff);c=(l>>>30)+(m>>>15)+xh*h+(c>>>30);w[j++]=l&0x3ffffffff;}return c;}function am3(i,x,w,j,c,n){var xl=x&0x3ffff,xh=x>>14;while(--n>=0){var l=this[i]&0x3ffff;var h=this[i++]>>14;var m=xh*l+h*xl;l=xl*l+((m&0x3ffff)<<14)+w[j]+c;c=(l>>28)+(m>>14)+xh*h;w[j++]=l&0xffffffff;}return c;}BigInteger.prototype.am=am3;dbits=28;BigInteger.prototype.DB=dbits;BigInteger.prototype.DM=((1<<dbits)-1);BigInteger.prototype.DV=(1<<dbits);var BI_FP=52;BigInteger.prototype.FV=Math.pow(2,BI_FP);BigInteger.prototype.F1=BI_FP-dbits;BigInteger.prototype.F2=2*dbits-BI_FP;var BI_RM='0123456789abcdefghijklmnopqrstuvwxyz';var BI_RC=new Array();var rr,vv;rr='0'.charCodeAt(0);for(vv=0;vv<=9;++vv)BI_RC[rr++]=vv;rr='a'.charCodeAt(0);for(vv=10 ;vv<36;++vv)BI_RC[rr++]=vv;rr='A'.charCodeAt(0);for(vv=10;vv<36;++vv)BI_RC[rr++]=vv;function int2char(n){return BI_RM.charAt(n);}function intAt(s,i){var c=BI_RC[s.charCodeAt(i)];return(c==null)?-1:c;}function bnpCopyTo(r){for(var i=this.t-1;i>=0;--i)r[i]=this[i];rt=this.t;rs=this.s;}function bnpFromInt(x){this.t=1;this.s=(x<0)?-1:0;if(x>0)this[0]=x;else if(x<-1)this[0]=x+DV;else this.t=0;}function nbv(i){var r=nbi();r.fromInt(i);return r;}function bnpFromString(s,b){var k;if(b==16)k=4;else if(b==8)k=3;else if(b==256)k=8;else if(b==2)k=1;else if(b==32)k=5;else if(b==4)k=2;else{this.fromRadix(s,b);return;}this.t=0;this.s=0;var i=s.length,mi=false,sh=0;while(--i>=0){var x=(k==8)?s[i]&0xff:intAt(s,i);if(x<0){if(s.charAt(i)=='-')mi=true;continue;}mi=false;if(sh==0)this[this.t++]=x;else if(sh+k>this.DB){this[this.t-1]|=(x&((1<<(this.DB-sh))-1))<<sh;this[this.t++]=(x>>(this.DB-sh));}else this[this.t-1]|=x<<sh;sh+=k;if(sh>=this.DB)sh-=this.DB;}if(k==8&&(s[0]&0x80)!=0){this.s=-1;if(sh>0)th is[this.t-1]|=((1<<(this.DB-sh))-1)<<sh;}this.clamp();if(mi)BigInteger.ZERO.subTo(this,this);}function bnpClamp(){var c=this.s&this.DM;while(this.t>0&&this[this.t-1]==c)--this.t;}function bnToString(b){if(this.s<0)return '-'+this.negate().toString(b);var k;if(b==16)k=4;else if(b==8)k=3;else if(b==2)k=1;else if(b==32)k=5;else if(b==4)k=2;else return this.toRadix(b);var km=(1<<k)-1,d,m=false,r='',i=this.t;var p=this.DB-(i*this.DB)%k;if(i-->0){if(p<this.DB&&(d=this[i]>>p)>0){m=true;r=int2char(d);}while(i>=0){if(p<k){d=(this[i]&(1<<p)-1))<< (kp);d|=this[--i]>>(p+=this.DB-k);}else{d=(this[i]>>(p-=k))&km;if(p<=0){p+=this.DB;--i;}}if(d>0)m=true;if(m)r+=int2char(d);}}return m?r:'0';}function bnNegate(){var r=nbi();BigInteger.ZERO.subTo(this,r);return r;}function bnAbs(){return(this.s<0)?this.negate():this;}function bnCompareTo(a){var r=this.sa.s;if(r!=0)return r;var i=this.t;r=ia.t;if(r!=0)return r;while(--i>=0)if((r=this[i]-a[i])!=0)return r;return 0;}function nbits(x){var r=1,t;if((t=x>>>16)!=0){x=t;r+=16;}if((t=x>>8)!=0){x=t;r+=8;}if((t=x>>4) !=0){x=t;r+=4;}if((t=x>>2)!=0){x=t;r+=2;}if((t=x>>1)!=0){x=t;r+=1;}return r;}function bnBitLength(){if(this.t<=0)return 0;return this.DB*(this.t-1)+nbits(this[this.t-1]^(this.s&this.DM));}function bnBitLength(){if(this.t<=0)return 0;return this.DB*(this.t-1)+nbits(this[this.t-1]^(this.s&this.DM));}function bnpDLShiftTo(n,r){var i;for(i=this.t-1;i>=0;-i)r[i+n]=this[i];for(i=n-1;i>=0;-i)r[i]=0;rt=this.t+n;rs=this.s;}function bnpDRShiftTo(n,r){for(var i=n;i<this.t;++i)r[in]=this[i];rt=Math.max(this.tn,0);rs=this.s;}function bnpLShiftTo(n,r){var bs=n%this.DB;var cbs=this.DB-bs;var bm=(1<<cbs)-1;var ds=Math.floor(n/this.DB),c=(this.s<<bs)&this.DM,i;for(i=this.t-1;i>=0;--i){r[i+ds+1]=(this[i]>>cbs)| c;c=(this[i]&bm)<<bs;}for(i=ds-1;i>=0;-i)r[i]=0;r[ds]=c;rt=this.t+ds+1;rs=this.s;r.clamp();}function bnpRShiftTo(n,r){rs=this.s;var ds=Math.floor(n/this.DB);if(ds>=this.t){rt=0;return;}var bs=n%this.DB;var cbs=this.DB-bs;var bm=(1<<bs)-1;r[0]=this[ds]>>bs;for(var i=ds+1;i<this.t;++i){r[i-ds-1]|=(this[i]&bm)<<cbs;r[i-ds]=this[i]>>bs;}if(bs>0)r[this.t-ds-1]|=(this.s&bm)<<cbs;rt=this.t-ds;r.clamp();}function bnpSubTo(a,r){var i=0,c=0,m=Math.min(at,this.t);while(i<m){c+=this[i]-a[i];r[i++]=c&this.DM;c>>=this.DB;}if(at<this.t){c-=as;while(i<this.t){c+=this[i];r[i++]=c&th is.DM;c>>=this.DB;}c+=this.s;}else{c+=this.s;while(i<at){c-=a[i];r[i++]= c&this.DM;c>>=this.DB;}c-=as;}rs=(c<0)?-1:0;if(c<-1)r[i++]=this.DV+c;else if(c>0)r[i++]=c;rt=i;r.clamp();}function bnpMultiplyTo(a,r){var x=this.abs(),y=a.abs();var i=xt;rt=i+yt;while(--i>=0)r[i]=0;for(i=0;i<yt;++i)r[i+xt]=x.am(0,y[i],r,i,0,xt);rs=0;r.clamp();if(this.s!=as)BigInteger.ZERO.subTo(r,r);}function bnpSquareTo(r){var x=this.abs();var i=rt=2*xt;while(--i>=0)r[i]=0;for(i=0;i<xt-1;++i){var c=x.am(i,x[i],r,2*i,0,1);if((r[i+xt]+=x.am(i+1,2*x[i],r,2*i+1,c,xt-i-1))>=x.DV){r[i+xt ]-=x.DV;r[i+x.t+1]=1;}}if(rt>0)r[rt-1]+=x.am(i,x[i],r,2*i,0,1);rs=0;r.clamp();}function bnpDivRemTo(m,q,r){var pm=m.abs();if(pm.t<=0)return;var pt=this.abs();if(pt.t<pm.t){if(q!=null)q.fromInt(0);if(r!=null)this.copyTo(r);return;}if(r==null)r=nbi();var y=nbi(),ts=this.s,ms=ms;var nsh=this.DB-nbits(pm[pm.t-1]);if(nsh>0){pm.lShiftTo(nsh,y);pt.lShiftTo(nsh,r);}else{pm.copyTo(y);pt.copyTo(r);}var ys=yt;var y0=y[ys-1];if(y0==0)return;var yt=y0*(1<<this.F1)+((ys>1)?y[ys-2]>>this.F2:0);var d1=this.FV/yt,d2=(1<<this.F1)/yt,e=1<<this.F2;var i=rt,j=i-ys,t=(q==null)?nbi():q;y.dlShiftTo(j,t);if(r.compareTo(t)>=0){r[r.t++]=1;r.subTo(t,r);}BigInteger.ONE.dlShiftTo(ys,t);t.subTo(y,y); while(yt<ys)y[y.t++]=0;while(--j>=0){var qd=(r[--i]==y0)?this.DM:Math.floor(r[i]*d1+(r[i-1]+e)*d2);if((r[i]+=y.am(0,qd ,r,j,0,ys))<qd){y.dlShiftTo(j,t);r.subTo(t,r);while(r[i]<--qd)r.subTo(t,r);}} if(q!=null){r.drShiftTo(ys,q);if(ts!=ms)BigInteger.ZERO.subTo(q,q);}rt=ys;r.clamp();if(nsh>0)r.rShiftTo(nsh,r);if(ts<0)BigInteger.ZERO.subTo(r,r);}function bnMod(a){var r=nbi();this.abs().divRemTo(a,null,r);if(this.s<0&&r.compareTo(BigInteger.ZERO)>0)a.subTo(r,r);return r;}function Classic(m){this.m=m;}function cConvert(x){if(xs<0||x.compareTo(this.m)>=0)return x.mod(this.m);else return x;}function cRevert(x){return x;}function cReduce(x){x.divRemTo(this.m,null,x);}function cMulTo(x,y,r){x.multiplyTo(y,r);this.reduce(r);}function cSqrTo(x,r){x.squareTo(r);this.reduce(r);}Classic.prototype.convert=cConvert;Classic.prototype.revert=cRevert;Classic.prototype.reduce=cReduce;Classic.prototype.mulTo=cMulTo;Classic.prototype.sqrTo=cSqrTo;function bnpInvDigit(){if(this.t<1)return 0;var x=this[0];if((x&1)==0)return 0;var y=x&3;y=(y*(2-(x&0xf)*y))&0xf;y=(y*(2-(x&0xff)*y))&0xff;y=(y*(2-((x&0xffff)*y)&0 xffff)))&0xffff;y=(y*(2-x*y%this.DV))%this.DV;return(y>0)?this.DV-y:-y;}function Montgomery(m){this.m=m;this.mp=m.invDigit();this.mpl=this.mp&0x7ff;this.mph=this.mp>>15;this.um=(1<<(m.DB-15))-1;this.mt2=2*mt;}function montConvert(x){var r=nbi();x.abs().dlShiftTo(this.mt,r);r.divRemTo(this.m,null,r);if(xs<0&&r.compareTo(BigInteger.ZERO)>0)this.m.subTo(r,r);return r;}function montRevert(x){var r=nbi();x.copyTo(r);this.reduce(r);return r;}function montReduce(x){while(xt<=this.mt2)x[x.t++]=0;for(var i=0;i<this.mt;++i){var j=x[i]&0x7ff;var u0=(j*this.mpl+(((j*this.mph+(x[i]>>15)*this.mpl)&this.um)<<15))&x.DM;j=i+this.mt;x[j]+=this.m.am(0,u0,x,i,0,this.mt);whil e(x[j]>=x.DV){x[j]-=x.DV;x[++j]++;}}x.clamp();x.drShiftTo(this.mt,x);if(x.compareTo(this.m)>=0)x.subTo(this.m,x);}function montSqrTo(x,r){x.squareTo(r);this.reduce(r);}function montMulTo(x,y,r){x.multiplyTo(y,r);this.reduce(r);}Montgomery.prototype.convert=montConvert;Montgomery.prototype.revert=montRe vert;Montgomery.prototype.reduce=montReduce;Montgomery.prototype.mulTo=montMulTo;Montgomery.prototype.sqrTo=montSqrTo;function bnpIsEven(){return((this.t>0)?(this[0]&1):this.s)==0;}function bnpExp(e,z){if(e>0xffffffffff||e<1)return BigInteger.ONE;var r=nbi(),r2=nbi(),g=z.convert(this),i=nbits(e)-1;g.copyTo(r);while(--i>=0){z.sqrTo(r,r2);if((e&(1<<i))>0)z.mulTo(r2,g,r);else{var t=r;r=r2;r2=t;}}return z.revert(r);}function bnModPowInt(e,m){var z;if(e<256||m.isEven())z=new Classic(m);else z=new Montgomery(m);return this.exp(e,z);}BigInteger.prototype.copyTo=bnpCopyTo;BigInteger.prototype.fromInt=bnpFromInt;BigInteger.prototype.fromString=bnpFromString;B igInteger.prototype.clamp=bnpClamp;BigInteger.prototype.dlShiftTo=bnpDLShiftTo;BigInteger.prototype.dlShiftTo=bnpDLShiftTo;BigInteger.protot ype.drShiftTo=bnpDRShiftTo;BigInteger.prototype.lShiftTo=bnpLShiftTo;BigInteger.prototype.rShiftTo=bnpRShiftTo;BigInte ger.prototype.subTo=bnpSubTo;BigInteger.prototype.multiplyTo=bnpMultiplyTo;BigInteger.prototype.squareTo=bnpSquareTo;Bi gInteger.prototype.divRemTo=bnpDivRemTo;BigInteger.prototype.invDigit=bnpInvDigit;BigInteger.prototype.isEven=bnpIsEve n;BigInteger.prototype.exp=bnpExp;BigInteger.prototype.toString=bnToString;BigInteger.prototype.negate=bnNegate;BigInte ger.prototype.abs=bnAbs;BigInteger.prototype.compareTo=bnCompareTo;BigInteger.prototype.bitLength=bnBitLength;BigInteg er.prototype.mod=bnMod;BigInteger.prototype.modPowInt=bnModPowInt;BigInteger.ZERO=nbv(0);BigInteger.ONE=nbv(1);function Arcfour(){this.i=0;this.j=0;this.S=new Array();}function ARC4init(key){var i,j,t;for(i=0;i<256;++i)this.S[i]=i;j=0;for(i=0;i<256;++i){j=(j+this.S[i]+key[i%key. length])&255;t=this.S[i];this.S[i]=this.S[j];this.S[j]=t;}this.i=0;this.j=0;}function ARC4next(){var t;this.i=(this.i+1)&255;this.j=(this.j+this.S[this.i])&255;t=this.S[this.i];this.S[this.i]=this.S[this.j];this.S[this.j]=t;return this.S[(t+this.S[this.i])&255];}Arcfour.prototype.init=ARC4init;Arcfour.prototype.next=ARC4next;function prng_newstate(){return new Arcfour();}var rng_psize=256;var rng_state;var rng_pool;var rng_pptr;function rng_seed_int(x){rng_pool[rng_pptr++]^=x&255;rng_pool[rng_pptr++]^=(x>>8)&255;rng_pool[rng_pptr++]^ =(x>>16)&255;rng_pool[rng_pptr++]^=(x>>24)&255;if(rng_pptr>=rng_psize)rng_pptr-=rng_psize;}function rng_seed_time(){rng_seed_int(new Date().getTime());}if(rng_pool=null){rng_pool=new Array();rng_pptr=0;var t;while(rng_pptr<rng_psize){t=Math.floor(65536*Math.random());rng_pool[rng_pptr++]=t>>>8;rng_pool[rng_pptr++]=t&255;}rng_pptr=0;rng_seed_time();}function rng_get_byte(){if(rng_state==null){rng_seed_time();rng_state=prng_newstate();rng_state.init(rng_ pool);for(rng_pptr=0;rng_pptr<rng_pool.length;++rng_pptr)rng_pool[rng_pptr]=0;rng_pptr=0;}return rng_state.next();}function rng_get_bytes(ba){var i;for(i=0;i<ba.length;++i)ba[i]=rng_get_byte();}function SecureRandom(){}SecureRandom.prototype.nextBytes=rng_get_bytes;function parseBigInt(str,r){return new BigInteger(str,r);}function linebrk(s,n){var ret='';var i=0;while(i+n<s.length){ret+=s.substring(i,i+n)+'//n';i+=n;}return ret+s.substring(i,s.length);}function byte2Hex(b){if(b<0x10)return '0'+b.toString(16);else return b.toString(16);}function pkcs1pad2(s,n){if(n<s.length+11){return null;}var ba=new Array();var i=s.length-1;while(i>=0&&n>0){var c=s.charCodeAt(i--);if(c<128){ba[--n]=c;}else if((c>127)&&(c<2048)){ba[--n]=(c&63)|128;ba[--n]=(c>>6)|192;}else{ba[-- n]=(c&63)|128;ba[--n]=(c>>6)&63)|128;ba[--n]=(c>>12)|224;}}ba[--n]=0;var rng=new SecureRandom();var x=new Array();while(n>2){x[0]=0;while(x[0]==0)rng.nextBytes(x);ba[-n]=x[0];}ba[--n]=2;ba[-n]=0;return new BigInteger(ba);}function RSAKey(){this.n=null;this.e=0;this.d=null;this.p=null;this.q=null;this.dmp1=null;this.dmq1=null;this.coeff=null;}function RSASetPublic(N,E){if(N!=null&&E!=null&&N.length>0&&E.length>0){this.n=parseBigInt(N,16);this.e=parseInt(E,16);}else alert('Invalid RSA public key');}function RSADoPublic(x){return x.modPowInt(this.e,this.n);}function RSAEncrypt(text){var m=pkcs1pad2(text,(this.n.bitLength()+7)>>3);if(m==null)return null;var c=this.doPublic(m);if(c==null)return null;var h=c.toString(16);if((h.length&1)==0)return h;else return '0'+h;}RSAKey.prototype.doPublic=RSADoPublic;RSAKey.prototype.setPublic=RSASetPublic;RSAKey.prototype.encrypt=RSAEncrypt; this.RSAKey=RSAKey;}).call(sinaSSOEncoder);function getpass(pwd,servicetime,nonce,rsaPubkey){var RSAKey=new sinaSSOEncoder.RSAKey();RSAKey.setPublic(rsaPubkey,'10001');var password=RSAKey.encrypt([servicetime,nonce].join('//t')+'//n'+pwd);return password;}"; public SinaWeiboLogger(String username, String password) { this.username = username; this.password = password; //cookie policy, if you do not set, cookie rejected, set policy to save cookie information cookieStore = new BasicCookieStore(); CookieSpecProvider myCookie = new CookieSpecProvider() { public CookieSpec create(HttpContext context) { return new DefaultCookieSpec(); } }; Registry<CookieSpecProvider> rg = RegistryBuilder.<CookieSpecProvider> create().register("myCookie", myCookie) .build(); client = HttpClients.custom().setDefaultCookieStore(cookieStore).setDefaultCookieSpecRegistry(rg).build(); get = new HttpGet(); post = new HttpPost(); } /** * Pre-login, use username base64 to encrypt and get the request, get the return value, use the return value to encrypt the user password to request again* * @throws IOException * @throws ClientProtocolException * @throws URISyntaxException */ private void preLogin() throws ClientProtocolException, IOException, URISyntaxException { // 1 su = new String(Base64.encodeBase64(URLEncoder.encode(this.username, "UTF-8").getBytes())); String preLoginUrl = "http://login.sina.com.cn/sso/prelogin.php?entry=account&callback=sinaSSOController.preloginCallBack&su=" + su + "&rsakt=mod&client=ssologin.js(v1.4.15)&_=" + new Date().getTime(); get.setURI(new URI(preLoginUrl)); get.addHeader("Host", "login.sina.com.cn"); get.addHeader("User-Agent", "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0"); get.addHeader("Accept", "*/*"); get.addHeader("Accept-Language", "zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3"); get.addHeader("Accept-Encoding", "gzip, deflate"); get.addHeader("Referer", "http://login.sina.com.cn/"); get.addHeader("Connection", "keep-alive"); HttpResponse resp = client.execute(get); //Save the request and return the cookie. After logging in, you need to use cookies to request other pages. saveCookie(resp.getAllHeaders(), this.headerCookie); HttpEntity entity = resp.getEntity(); String cont = EntityUtils.toString(entity); // System.out.println(cont); cont = cont.replace("sinaSSOController.preloginCallBack(", ""); cont = cont.replace(")", ""); JSONObject json = JSONObject.parseObject(cont); this.retcode = json.getIntValue("retcode"); this.servertime = json.getLongValue("servertime"); this.pubkey = json.getString("pubkey"); this.rsakv = json.getString("rsakv"); this.is_openlock = json.getIntValue("is_openlock"); this.showpin = json.getIntValue("showpin"); this.exectime = json.getIntValue("exectime"); } private void saveCookie(Header[] headers, StringBuffer headerCookie) { for(Header h : headers) { if (h.getName().equals("Set-Cookie")) { headerCookie.append(h.getValue()).append(";"); } } } } /** * Log in to Sina Pass account, encrypt password, post request* * @return * * @throws IOException * @throws ClientProtocolException * @throws ScriptException * @throws NoSuchMethodException * @throws URISyntaxException */ private AccessToken accountLogin() throws NoSuchMethodException, ScriptException, ClientProtocolException, IOException, URISyntaxException { // 2 String loginUrl = "http://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.4.15)&_=" + new Date().getTime(); post.setURI(new URI(loginUrl)); post.addHeader("Host", "login.sina.com.cn"); post.addHeader("User-Agent", "Mozilla/5.0 (Windows NT 6.1; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0"); post.addHeader("Accept", "*/*"); post.addHeader("Content-Type", "application/x-www-form-urlencoded"); post.addHeader("Accept-Language", "zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3"); post.addHeader("Accept-Encoding", "gzip, deflate"); post.addHeader("Referer", "http://login.sina.com.cn/"); post.addHeader("Connection", "keep-alive"); // Use js to encrypt the password, RSA, call the method in js ScriptEngineManager sem = new ScriptEngineManager(); ScriptEngine se = sem.getEngineByName("javascript"); se.eval(sina_js); if (se instanceof Invocable) { Invocable iv = (Invocable) se; sp = (String) iv.invokeFunction("getpass", this.password, this.servertime, this.nonce, this.pubkey); } List<NameValuePair> parms = new ArrayList<NameValuePair>(); parms.add(new BasicNameValuePair("entry", "account")); parms.add(new BasicNameValuePair("gateway", "1")); parms.add(new BasicNameValuePair("from", "")); parms.add(new BasicNameValuePair("savestate", "0")); parms.add(new BasicNameValuePair("savestate", "0")); parms.add(new BasicNameValuePair("useticket", "0")); parms.add(new BasicNameValuePair("pagerefer", "")); parms.add(new BasicNameValuePair("vsnf", "1")); parms.add(new BasicNameValuePair("su", su)); parms.add(new BasicNameValuePair("service", "sso")); parms.add(new BasicNameValuePair("servertime", servertime + "")); parms.add(new BasicNameValuePair("nonce", nonce)); parms.add(new BasicNameValuePair("pwencode", "rsa2")); parms.add(new BasicNameValuePair("rsakv", rsakv)); parms.add(new BasicNameValuePair("sp", sp)); parms.add(new BasicNameValuePair("sr", "1366*768")); parms.add(new BasicNameValuePair("encoding", "UTF-8")); parms.add(new BasicNameValuePair("cdult", "3")); parms.add(new BasicNameValuePair("domain", "sina.com.cn")); parms.add(new BasicNameValuePair("prelt", "51")); parms.add(new BasicNameValuePair("returntype", "TEXT")); post.setEntity(new UrlEncodedFormEntity(parms)); HttpResponse resp = client.execute(post); //Save the request and return the cookie. After logging in, you need to have a cookie. saveCookie(resp.getAllHeaders(), this.headerCookie); //Request return link JSONObject jsonObj = JSONObject.parseObject(EntityUtils.toString(resp.getEntity())); this.retcode = jsonObj.getIntValue("retcode"); this.uid = jsonObj.getString("uid"); this.nick = jsonObj.getString("nick"); this.domainurls = jsonObj.getJSONArray("crossDomainUrlList"); List<String> retMsg = new ArrayList<String>(); int i = 0; for (Object url : domainurls) { System.out.println("url:"+url.toString()); get.setURI(new URI(url.toString()+"&callback=sinaSSOController.doCrossDomainCallBack&scriptId=ssscript"+i+"&client=ssologin.js(v1.4.15)&_="+new Date().getTime())); resp = client.execute(get); retMsg.add(EntityUtils.toString(resp.getEntity())); i ++; } Oauth oauth = new Oauth(); try { String url = oauth.authorize("code"); get.setURI(new URI(url)); List<URI> allRedirectLocations = getAllRedirectLocations(url); for (URI uri : allRedirectLocations) { String retUrl = uri.toString(); int begin = retUrl.indexOf("code="); if (begin != -1) { int end = retUrl.indexOf("&", begin); if (end == -1) end = retUrl.length(); String code = retUrl.substring(begin + 5, end); if (code != null) { try{ AccessToken token = oauth.getAccessTokenByCode(code); return token; } catch (exception e) {e.printstacktrace (); } } หยุดพัก; } } } catch (WeiboException e) { // TODO Auto-generated catch block e.printStackTrace(); } return null; } public List<URI> getAllRedirectLocations(String link) throws ClientProtocolException, IOException{ List<URI> redirectLocations = null; CloseableHttpResponse response = null; try{ HttpClientContext context = HttpClientContext.create(); HttpGet httpGet = new HttpGet(link); //Add the request cookie to the request header httpGet.addHeader("Cookie", this.headerCookie.toString()); response = (CloseableHttpResponse) client.execute(httpGet, context); // Get all redirect locations redirectLocations = context.getRedirectLocations(); } finally{ if(response!=null){ response.close(); } } return redirectLocations; } /** * Post to Weibo* @param token Authentication Token * @param content Weibo content* @return * @throws Exception */ public static boolean sinaSendWeibo(String token,String content) throws Exception { boolean flag = false ; Timeline tm = new Timeline(token); try { Status status = tm.updateStatus(content); flag = true ; } catch (WeiboException e) { flag = false ; System.out.println(e.getErrorCode()); } return flag; } /** * Login*/ @SuppressWarnings("static-access") public void login(String context) { try { this.preLogin(); AccessToken at = this.accountLogin(); this.sinaSendWeibo(at.getAccessToken(),context); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (NoSuchMethodException e) { e.printStackTrace(); } catch (ScriptException e) { e.printStackTrace(); } catch (URISyntaxException e) { e.printStackTrace(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } public HttpClient getClient() { return client; } public void setClient(HttpClient client) { this.client = client; } public HttpPost getPost() { return post; } public void setPost(HttpPost post) { this.post = post; } public HttpGet getGet() { return get; } public void setPost(HttpPost post) { this.post = post; } public HttpGet getGet() { return get; } public void setGet(HttpGet get) { this.get = get; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getSu() { return su; } public void setSu(String su) { this.su = su; } public String getSp() { return sp; } public void setSp(String sp) { this.sp = sp; } public String getNonce() { return nonce; } public void setNonce(String nonce) { this.nonce = nonce; } public String getRsakv() { return rsakv; } public void setRsakv(String rsakv) { this.rsakv = rsakv; } public String getPubkey() { return pubkey; } public void setPubkey(String pubkey) { this.pubkey = pubkey; } public int getRetcode() { return retcode; } public void setRetcode(int retcode) { this.retcode = retcode; } public String getUid() { return uid; } public void setUid(String uid) { this.uid = uid; } public String getNick() { return nick; } public void setNick(String nick) { this.nick = nick; } public static String getSina_js() { return sina_js; } public BasicCookieStore getCookieStore() { return cookieStore; } public void setCookieStore(BasicCookieStore cookieStore) { this.cookieStore = cookieStore; } public static void main(String[] args) throws HttpException, IOException { new SinaWeiboLogger("WeiboLogger", "Password").login("xxxxx"); -ข้างต้นเป็นเนื้อหาทั้งหมดของบทความนี้ ฉันหวังว่ามันจะเป็นประโยชน์ต่อการเรียนรู้ของทุกคนและฉันหวังว่าทุกคนจะสนับสนุน wulin.com มากขึ้น