使用Xposed實(shí)現(xiàn)QQ/TIM自動(dòng)確認(rèn)電腦掃一掃登錄

本文同步更新于旺仔的個(gè)人博客,訪問可能有點(diǎn)慢,多刷新幾次。

緣由

不知道大家有沒有用過QQ/TIM登錄的時(shí)候使用掃描二維碼登錄的功能呢?

也就是登錄界面的右下角那里有個(gè)二維碼的按鈕

點(diǎn)擊之后就會(huì)出現(xiàn)二維碼

然后用手機(jī)QQ/TIM打開掃一掃界面,掃了之后,會(huì)彈出允許登錄的界面

然后我們需要點(diǎn)擊允許登錄TIM/QQ,電腦端就登錄成功了。

但是每次登錄都要點(diǎn)擊允許登錄,我覺得好麻煩,所以就實(shí)現(xiàn)了自動(dòng)點(diǎn)擊功能,這篇文章就是來介紹如何使用Xposed來實(shí)現(xiàn)自動(dòng)點(diǎn)擊。

實(shí)踐

首先我們先整理一下思路,先要獲取確認(rèn)登錄界面的Class,然后獲取允許登錄這個(gè)控件的Field,然后通過調(diào)用performClick這個(gè)方法來實(shí)現(xiàn)點(diǎn)擊。

查找確認(rèn)登錄Activity

接下來,我們需要獲取確認(rèn)登錄界面的Activity是哪一個(gè),在這里我們先下載一個(gè)軟件當(dāng)前界面,可以獲取到當(dāng)前界面的Activity

在這里我們找到了確認(rèn)界面的Activity的類名是com.tencent.biz.qrcode.activity.QRLoginActivity,然后我們進(jìn)行下一步

反編譯classes.dex

當(dāng)前使用的apk版本是2.0.0,然后改后綴,打開壓縮包,復(fù)制里面的dex文件

然后通過dex2jardex轉(zhuǎn)換成jar文件,然后用jd-gui打開jar包,最后在classes6-dex2jar.jar里面找到QRLoginActivity

使用AndroidKiller

由于我們需要獲取控件相關(guān)的內(nèi)容,就需要獲取控件的id、text之類的東西,那么僅僅靠dex2jarjd-gui兩個(gè)東西是完成不了的,所以這里我們需要用到AndroidKillerAndroidKiller是一款可視化的安卓應(yīng)用逆向工具,具體使用,大家自行上網(wǎng)搜索,這里不介紹。

獲取text引用

將我們的TIM的apk打開,然后搜索允許登錄內(nèi)容,找到對(duì)應(yīng)的16進(jìn)制內(nèi)容

找到之后,發(fā)現(xiàn)有兩個(gè)16進(jìn)制的值,一個(gè)是7f0a0872,一個(gè)是7f0a0ba9,既然有兩個(gè),那么就有分別去搜索這兩個(gè)值的調(diào)用,我這里有搜索過,第二個(gè)才是我們需要的,我們來看搜索結(jié)果

可以看出,這個(gè)值的引用是在hxq類上面調(diào)用的,點(diǎn)開jd-gui,找到這個(gè)類,同樣是在classes6-dex2jar.jar里面

可以看出這個(gè)類是個(gè)Handler類,那么我們就可以這樣理解,當(dāng)掃描二維碼后,會(huì)調(diào)用sendMessage之類的方法,然后在handleMessage里面進(jìn)行修改控件的Text值。

Hook方法

通過上面的說明,我們可以很明確的知道該hook的地方在哪里了:

  1. 首先我們需要將Hook控件初始化的方法,然后再Hook我們的hxq類里面的handleMessage方法
  2. 之后進(jìn)行判斷控件的值是不是包含允許登錄的內(nèi)容(因?yàn)槎S碼過期我們不需要進(jìn)行處理,只有登錄的時(shí)候才進(jìn)行處理),如果包含的話就調(diào)用performClick這個(gè)方法實(shí)現(xiàn)點(diǎn)擊。

找到初始化方法

如何找到初始化方法呢,通過搜索findviewbyid,找到了doOnCreate方法

然后我們Hook這個(gè)方法

// 獲取Class
final Class<?> aClass = XposedHelpers.findClassIfExists("com.tencent.biz.qrcode.activity.QRLoginActivity", lpparam.classLoader);
if (aClass == null) {
    return;
}
// Hook指定方法
XposedHelpers.findAndHookMethod(aClass, "doOnCreate", Bundle.class, new XC_MethodHook() {
    @Override
    protected void afterHookedMethod(MethodHookParam param) throws Throwable {
        // 操作
    }
});

反射獲取控件

通過獲取QRLoginActivity的Class之后,我們通過反射獲取里面的所有變量,然后通過判斷變量的類型,然后判斷控件的Text值是否包含允許登錄內(nèi)容,然后實(shí)現(xiàn)點(diǎn)擊。

for (Field declaredField : declaredFields) {
    // 設(shè)置true
    declaredField.setAccessible(true);
    // 判斷類型是否是Button
    if (declaredField.getGenericType().toString().contains("android.widget.Button")) {
        // 獲取值
        final Button loginButton = (Button) declaredField.get(param.thisObject);
        if (loginButton == null) {
            return;
        }
        // 默認(rèn)的Button的Text為空,需要在Handler這個(gè)類里面的方法后面加上判斷
        Class<?> handlerClass = XposedHelpers.findClassIfExists(resultStr, lpparam.classLoader);
        if (handlerClass == null) {
            return;
        }
        try {
            // Hook方法,對(duì)handleMessage方法調(diào)用后,進(jìn)行判斷Button的Text進(jìn)行判斷,并且自動(dòng)調(diào)用點(diǎn)擊方法
            XposedHelpers.findAndHookMethod(handlerClass, "handleMessage", Message.class, new XC_MethodHook() {
                @Override
                protected void afterHookedMethod(MethodHookParam param) throws Throwable {
                    // 當(dāng)Button的Text為允許登錄TIM/允許登錄QQ的時(shí)候才實(shí)現(xiàn)點(diǎn)擊
                    if (loginButton.getText().toString().contains("允許登錄")) {
                        loginButton.performClick();
                    }
                }
            });
        } catch (Throwable t) {
            XposedBridge.log("Hook 出錯(cuò) " + t);
        }
    }
}

最后打包,安裝,激活重啟

結(jié)果:

掃一掃登錄

結(jié)語

文章說的簡(jiǎn)單一點(diǎn),實(shí)際上自己反編譯并且查找內(nèi)容,是一個(gè)比較繁瑣的事情,明確的方向會(huì)減輕需要操作的步驟。

微信自動(dòng)確認(rèn)登錄

同樣我們可以實(shí)現(xiàn)自動(dòng)確認(rèn)電腦端登錄,這里就不再介紹了,大家可以自己試一試:

自動(dòng)確認(rèn)電腦端登錄

GitHub

Github地址在此奉上:ScanLogin,歡迎star

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,156評(píng)論 6 529
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 97,866評(píng)論 3 413
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 174,880評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,398評(píng)論 1 308
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,202評(píng)論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,743評(píng)論 1 320
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,822評(píng)論 3 438
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 41,962評(píng)論 0 285
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,476評(píng)論 1 331
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,444評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,579評(píng)論 1 365
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,129評(píng)論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 43,840評(píng)論 3 344
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,231評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,487評(píng)論 1 281
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,177評(píng)論 3 388
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,568評(píng)論 2 370