逆向之-Cycript操作案例

一.Cycript的簡(jiǎn)單介紹

Cycript可以攻擊iOS軟件.它是一種介于Oc和JavaScript之間的編程語(yǔ)言. Cycript由JayFreeman(杰弗里曼)編寫(xiě),他是iOS第三方工具的作者,包括Cydia軟件安裝器, Cydgets以及iOS的一個(gè)Java移植版.Cycript完全兼容JavaScript,你可以使用完整的JS語(yǔ)法來(lái)編寫(xiě)程序, 但同時(shí)可以直接操作OC語(yǔ)言的組件.簡(jiǎn)單來(lái)說(shuō)Cycript高超地實(shí)現(xiàn)了目前所有的運(yùn)行時(shí)操作技巧.

在已越獄的手機(jī)上,去Cydia商店里面下載安裝Cycript.
cycript是混合了oc與js語(yǔ)法的一個(gè)工具, 讓開(kāi)發(fā)者在命令行下和應(yīng)用交互,在運(yùn)行時(shí)查看和修改應(yīng)用

Snip20170615_1.png

二. 使用Cycript做三個(gè)案例

1.在手機(jī)上彈出提示框,截屏,改變桌面背景顏色

2.通過(guò)終端來(lái)改變手機(jī)上的應(yīng)用界面

3.修改支付寶上面的文字

最后的效果如下:
支付寶效果.gif

1.通過(guò)ssh在MAC終端來(lái)登錄你的手機(jī)

在登錄越獄手機(jī)之前, 必須在你的iOS上面安裝OpenSSH,OpenSSH同樣可以在Cydia商店里面去進(jìn)行下載進(jìn)行安裝. 它給外界就提供了一個(gè)通過(guò)SSH接入的遠(yuǎn)程登錄.登錄的具體操作,我們可以看下圖的操作

iOS默認(rèn)的端口是22, 本地端是2222
在電腦上安裝usbmuxd,它里面自帶iproxy這樣一個(gè)小工具, 可以把手機(jī)上的端口號(hào)映射到我們的電腦上.打開(kāi)兩個(gè)終端.
第一個(gè)終端輸入如下指令

先在第一個(gè)指令.png

第二個(gè)終端輸入如下指令

終端連接手機(jī).png

連接的時(shí)候,會(huì)默認(rèn)提示要你輸入密碼ios的Root密碼,它的一個(gè)默認(rèn)密碼是alpine.
完了之后,可以使用ps -e來(lái)查看進(jìn)程ID

通過(guò)Cycript指令來(lái)注入進(jìn)程,SpringBoard簡(jiǎn)單理解,是我們所能看到的iOS上面的東西,都屬于SpringBoard里面.
然后彈框就這樣簡(jiǎn)單的通過(guò)我們的終端實(shí)現(xiàn)了:

iPhone:~ root# cycript -p SpringBoard
cy# var alert = [[UIAlertView alloc] initWithTitle:'\u9006\u5411\u738b\u5c3c\u39b' message:'\u4ece\u5929\u800c\u964d\u7684\u738b\u5c3c\u739b' delegate:nil cncelButtonTitle:'\u662f\u738b\u5c3c\u739b' otherButtonTitles:nil]
#"<UIAlertView: 0x15fe91110; frame = (0 0; 0 0); layer = <CALayer: 0x1612e14d0>>"
cy# [alert show]

還有其它顯示彈框的方式,通過(guò)地址調(diào)用來(lái)顯示

cy# [#0x15fe91110 show]

接著就來(lái)通過(guò)終端對(duì)手機(jī)端進(jìn)行截屏和改變桌面的背景顏色.可以一口氣敲完

iPhone:~ root# cycript -p SpringBoard
cy# var shot = [SBScreenShotter sharedInstance]  // 賦值給shot
#"<SBScreenShotter: 0x15e5eb8f0>" //創(chuàng)建成功就會(huì)打印出地址
cy# [shot saveScreenshot:YES]  // 像oc那樣直接調(diào)用就可以對(duì)顯示屏進(jìn)行截屏了
// 改變透明度和隱藏顯示的操作
iPhone:~ root# cycript -p SpringBoard  // 如果上面已經(jīng)注入了,這地方就沒(méi)必要再寫(xiě)了,直接在終端操作下面的指令就行
cy# UIApp.keyWindow
#"<SBHomeScreenWindow: 0x15fa40f40; baseClass = UIWindow; frame = (0 0; 320 568); clipsToBounds = YES; opaque = NO; gestureRecognizers = <NSArray: 0x15fa22270>; layer = <UIWindowLayer: 0x15fa22070>>"
cy# screen = #0x15fa40f40
#"<SBHomeScreenWindow: 0x15fa40f40; baseClass = UIWindow; frame = (0 0; 320 568); clipsToBounds = YES; opaque = NO; gestureRecognizers = <NSArray: 0x15fa22270>; layer = <UIWindowLayer: 0x15fa22070>>"
cy# screen.hidden = YES   // 這條指令一回車(chē)桌面圖標(biāo)就隱藏了
true
cy# screen.hidden = NO
false
cy# screen.alpha = 0.5  // 改變桌面圖標(biāo)透明度
0.5
cy# screen.alpha = 0.2
0.20000000000000001
cy# screen.alpha = 1

// 以下是改變手機(jī)的背景色,效果可以看前面的gif效果圖
cy# screen.backgroundColor = [UIColor redColor]
#"UIDeviceRGBColorSpace 1 0 0 1"
cy# screen.backgroundColor = [UIColor greenColor]
#"UIDeviceRGBColorSpace 0 1 0 1"
cy# screen.backgroundColor = [UIColor yellowColor]
#"UIDeviceRGBColorSpace 1 1 0 1"
cy# screen.backgroundColor = [UIColor blackColor]
#"UIDeviceWhiteColorSpace 0 1"


2.通過(guò)app的名字來(lái)注入進(jìn)程,改變app的view,文字,和其它控件

原始的圖.png
iPhone:~ root# cycript -p xiaoguo  // 注入進(jìn)程
cy# 
// 打印當(dāng)前的控制器
UIApp.keyWindow.rootViewController.visibleViewController  
#"<ViewController: 0x124645240>"
cy# viewC = #0x124645240
#"<ViewController: 0x124645240>"
cy# viewC.view
#"<UIView: 0x124538560; frame = (0 0; 320 568); autoresize = W+H; layer = <CALayer: 0x124536a60>>"
cy# view = #0x124538560
#"<UIView: 0x124538560; frame = (0 0; 320 568); autoresize = W+H; layer = <CALayer: 0x124536a60>>"
cy# view.recursiveDescription().toString()  // 使用遞歸的方式,打印出當(dāng)前控制器的view里面的層級(jí)結(jié)構(gòu)

遞歸的方式打印出來(lái)的層級(jí)結(jié)構(gòu)圖.png

在上圖里面我們可以看到遞歸的方式打印出來(lái)了應(yīng)用上面的所用控件.一個(gè)view兩個(gè)label和一個(gè)button.

最后的效果是這樣的.


最后的效果.png

3.修改支付寶上面的文字

iPhone:~ root# cycript -p AlipayWallet 
cy# UIApp.keyWindow.rootViewController.visibleViewController
#"<ALULoginNewcomerViewController: 0x1388d4290>"
cy# #0x1388d4290.view
#"<UIView: 0x1376f22d0; frame = (0 0; 320 568); autoresize = W+H; layer = <CALayer: 0x13881c700>>"
cy# view = #0x1376f22d0
#"<UIView: 0x1376f22d0; frame = (0 0; 320 568); autoresize = W+H; layer = <CALayer: 0x13881c700>>"
cy# view.recursiveDescription().toString()
...
cy# #0x138b1ab40.text
@"\xe8\x9a\x82\xe8\x9a\x81\xe9\x87\x91\xe6\x9c\x8d\xe6\x97\x97\xe4\xb8\x8b\xe5\x93\x81\xe7\x89\x8c"

// 改了支付寶上面的問(wèn)題,這些編碼是unicode轉(zhuǎn)化的,可以打印出問(wèn)題
cy# #0x138b1ab40.text = '\u7a77\u5f97\u53ea\u5269\u4e0b\u94b1\u4e86\u002cu0020\u771f\u4e0d\u597d\u610f\u601d'

// 最后是修改UITextField, 可以打印出應(yīng)用里面使用textField做的控件信息
cy# choose(UITextField)

// 這里打印的信息省略了
[#"<UITextField: 0x128a6c2a0; frame = (9 0; 302 30); text = ''; clipsToBounds = YES; opaque = NO;  .........]

// 拿到地址之后,直接改變文字就行
cy# #0x128b35680.text = '\u5f20\u4e09'
"\u5f20\u4e09"
cy# #0x128b35680.text = '\u674e\u56db'
"\u674e\u56db"
cy# #0x128b77380.text = '12345678'
"12345678"

// 設(shè)置密碼是否顯示或者隱藏
cy# #0x128b77380.secureTextEntry = YES
true
cy# #0x128b77380.secureTextEntry = NO
false

支付寶里面的原理跟第二個(gè)案例是一樣的,打印出當(dāng)前控制器上面的view中控件.

遞歸的方式打印出的控件結(jié)構(gòu)圖.png
最后的結(jié)果.png
image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市勇吊,隨后出現(xiàn)的幾起案子曼追,更是在濱河造成了極大的恐慌,老刑警劉巖汉规,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件礼殊,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡针史,警方通過(guò)查閱死者的電腦和手機(jī)晶伦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)啄枕,“玉大人婚陪,你說(shuō)我怎么就攤上這事∑底#” “怎么了泌参?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵脆淹,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我沽一,道長(zhǎng)盖溺,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任锯玛,我火速辦了婚禮咐柜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘攘残。我一直安慰自己拙友,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布歼郭。 她就那樣靜靜地躺著遗契,像睡著了一般。 火紅的嫁衣襯著肌膚如雪病曾。 梳的紋絲不亂的頭發(fā)上牍蜂,一...
    開(kāi)封第一講書(shū)人閱讀 51,727評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音泰涂,去河邊找鬼鲫竞。 笑死,一個(gè)胖子當(dāng)著我的面吹牛逼蒙,可吹牛的內(nèi)容都是我干的从绘。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼是牢,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼僵井!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起驳棱,我...
    開(kāi)封第一講書(shū)人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤批什,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后社搅,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體驻债,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年形葬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了却汉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡荷并,死狀恐怖合砂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤翩伪,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布微猖,位于F島的核電站,受9級(jí)特大地震影響缘屹,放射性物質(zhì)發(fā)生泄漏凛剥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一轻姿、第九天 我趴在偏房一處隱蔽的房頂上張望犁珠。 院中可真熱鬧,春花似錦互亮、人聲如沸犁享。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)炊昆。三九已至,卻和暖如春威根,著一層夾襖步出監(jiān)牢的瞬間凤巨,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工洛搀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留敢茁,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓留美,卻偏偏與公主長(zhǎng)得像卷要,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子独榴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容