在越獄的iPhone/iPad上安裝自開發環境

来源:https://www.cnblogs.com/andrewwang/archive/2018/08/16/9488687.html
-Advertisement-
Play Games

自開發跟自編譯意思一樣,後者表示一個開發語言的開發能力成熟度;前者則表示一個開發平臺的開發能力成熟度。 iPhone跟iPad面世這麼多年,一直無法擺脫“娛樂”工具的宿命。Apple曾經希望通過iPad Pro為平臺增添“生產力工具”的特征,但看起來成效不大。 而競爭對手的Surface Pro,雖 ...



自開發跟自編譯意思一樣,後者表示一個開發語言的開發能力成熟度;前者則表示一個開發平臺的開發能力成熟度。
iPhone跟iPad面世這麼多年,一直無法擺脫“娛樂”工具的宿命。Apple曾經希望通過iPad Pro為平臺增添“生產力工具”的特征,但看起來成效不大。
而競爭對手的Surface Pro,雖然娛樂性不足,但沒有人否認Surface Pro是一個優良的生產力工具。
在實用上,iPad跟Surface在於對文化創意類“生產力”的支持都不錯。但是在其它方面,特別是軟體開發之類的支持,iOS差的實在太多。
如果你有一臺尚可越獄的iOS設備,那麼通過社區的支持,這種情況可以有所緩解。雖然依然離“生產力”的要求差的比較遠,但一些必要的基礎性工作已經有很高的可用度了。

越獄

第一步首先要將設備越獄,自從蘋果加速關閉老版本軟體的升級認證以來,想找到一臺可以越獄的iOS設備已經越來越難了。目前看一些老型號的32位cpu產品因為已經被限制升級到高版本的iOS,反而成為了一個越獄的機會。比如手頭有一款老的iPad3代,最高只能安裝iOS9.3.5,很容易找到對應的越獄程式。
iOS的越獄,不同的軟體版本有不同的開發團隊,這些黑客團隊極具個人特色的風格,使得難以出現一款軟體把這些工具集成到一起,完成自動化的越獄。所以不同版本的設備,都要在網上搜索不同的可行越獄方案,然後完成越獄過程。
以9.3.5為例,大致越獄過程如下:

  1. 在開發者官網https://phoenixpwn.com/下載越獄工具,越獄工具是IPA文件,安裝完成後是一個app,從而有機會執行,完成越獄。
  2. 因為iOS設備只能運行從AppStore下載的軟體。所以想安裝這個IPA,目前只有一個辦法,就是使用合法的開發者賬號對這個IPA重新簽名,讓iOS設備可以執行這個App。這個過程可以由Cydia Impactor工具自動完成,請下載時根據你的電腦,下載對應操作系統的版本。
  3. 因為簽名時還需要生成新的AppID,所以開發者賬號還需要有admin許可權,這對很多人都是一個不大不小的障礙。如果這一點無法解決的話,還可以考慮使用一些第三方工具,比如zJailbrewk、Xabsi,這些工具是收費的。原理是使用了企業簽名預先簽名好了自己的安裝程式和Phoenixpwn越獄程式,從而無需每個越獄者都具備自己具有開發者賬號。安裝這些第三方工具可以用要越獄的iOS設備瀏覽網頁https://pangu8.com/93.html,從其中選擇對應的軟體,企業版的簽名允許直接在瀏覽器中安裝對應的應用。
  4. 不管是個人簽名還是企業簽名,都需要在iOS設備的設置->通用->設備管理中,選擇信任相應的簽名,Phoenix app才可以執行起來,不然一啟動就直接被iOS殺死了。
  5. Phonenix第一次運行起來,點擊按鈕:Prepare For Jailbreak。通常系統會重啟,以後再次執行,同樣的位置,按鈕的名稱會變為:Kickstart Jailbreak。在越獄的過程中,會詢問越獄使用的破解位置偏移,直接選用providers offset 選項即可(上面的選項)。這個越獄是非完美越獄,也就是每次設備重啟後,都需要重新執行Phonenix App,然後使用“Kickstart Jailbreak”再次激活越獄。
  6. 越獄成功率比較低,經常重啟後仍然在未越獄狀態,這時候就需要重新執行上面的過程,通常可能需要重覆2、3次。另外一個就是如果使用個人開發者簽名的話,那簽名都是有時間限制的,如果過期,要使用Cydia Impactor重新安裝Phonenix。

安裝openssh-server

越獄只是拿到了系統根目錄讀寫的許可權,想要通過越獄把iOS設備當做一臺電腦來使用,還需要安裝各項應用軟體,最重要的就是openssh-server,這樣才可以通過ssh連接,得到iOS設備的命令行。
在越獄完成後,設備桌面上會有Cydia的程式圖標。Cydia相當於一個apt的圖形界面控制台,apt是從debian和ubuntu的Linux引入的軟體包管理器,可以安裝、更新、卸載各種系統所需的軟體包。因為各項軟體包都是在安裝過程中從互聯網直接下載的,所以運行Cydia之前,要保證設備聯網正常。
第一次執行Cydia會比較慢,啟動完成後,點擊下方最右側的放大鏡圖標,在搜索列表中輸入openssh。單擊搜索結果,然後選擇屏幕右上角的“安裝”按鈕。如果網速沒有問題的話,一般幾分鐘就能完成安裝。
同樣的搜索框,再次輸入apt,在搜索的結果中選取APT 0.7 Strict軟體包,同樣點擊“安裝”,這個是命令行版本的apt應用。有了命令行,很多軟體的安裝使用命令行的apt安裝會更快捷方便。
APT安裝完成後退出Cydia應用,在WIFI設置中查看一下當前的IP地址,保證你的電腦跟iOS設備在同一個網段。如果是Linux/macOS設備,可以直接使用ssh連接iOS設備。如果是Windows設備,推薦安裝putty或者xshell之類的ssh終端。
剩下就可以跟連接一臺電腦一樣訪問iOS設備了,比如:

ssh [email protected]  

iOS設備的root預設密碼是alpine,請儘快使用ssh登錄並使用passwd命令修改掉預設密碼,不然會很容易被別人控制。

安裝常用工具和開發工具

iOS是一個精簡的bsd unix系統,很多常用的命令行工具比如ifconfig/ping都被刪去了,我們可以使用apt工具來安裝:

#更新軟體源
apt-get update
#安裝常用的命令行工具
apt-get install coreutils coreutils-bin vim inetutils network-cmds adv-cmds wget
#安裝iFile文件管理器(App)
apt-get install eu.heinelt.ifile
#安裝開發常用工具
apt-get install git make tcpdump 

隨後,如果你是64位cpu,可以直接安裝集成的工具包:

apt-get install org.coolstar.iostoolchain

如果是你32位的cpu,但iOS版本在9.0(不含9.0)以下,也可以直接使用上面的語句安裝完整開發工具包。但如果是32位cpu,軟體版本又在9.0以上,則需要換用另外一套編譯工具:

apt-get install org.coolstar.llvm-clang32 org.coolstar.ld64 ldid

上面的org.coolstar.ld64實際是32位/64位cpu通用的。

解決系統分區過小的問題

iOS越獄後稍微操作經常就會在iOS設備屏幕上出現“存儲空間已滿”的警告信息,你如果到設置中查看,設備又遠遠沒有占滿。
其實這個信息指的是系統空間已經被占滿的意思。也就是unix系統的/根目錄。通常這個目錄都是iOS的固件部分,空間是確定的。但因為越獄後,又額外的安裝了很多程式,所以這個空間就不足了。
比較簡單的處理方法是把類似語言包之類,在啟動過程中不需要的庫移到用戶分區去,從而保證根目錄的空間容量:

mv /System/Library/LinguisticData /var/mobile
ln -s /var/mobile/LinguisticData/ /System/Library/

安裝iOS SDK

雖然現在iOS已經升級到了iOS12.x,但因為社區工具鏈的限制,經過多次試驗,感覺還是iOS 8.1的SDK最好用。我從老版本的Xcode中導出了一套,放在這裡:https://pan.baidu.com/s/1fsDs8Al1DnPUwLBGCEO_3Q,下載密碼:y23e。下載完成後,可以使用scp把sdk拷貝到iOS設備上,比如:

scp ios.tar.bz2 [email protected]:~/

隨後在iOS的ssh命令行執行:

mkdir -p /var/stash/Developer/SDKs/  
cd /var/stash/Developer/SDKs/  
tar xjvf ~/ios.tar.bz2

此時iOS已經具備了最基本的開發能力了,我們寫一個最簡單的hello world來測試一下。
首先使用vim編輯一個程式文件,比如test.c:

cd ~
vim test.c

內容為:

#include<stdio.h>

int main(int argc, char **argv){
    printf("hello ios!\n");
}

編譯程式:

clang -o test test.c -I /var/stash/Developer/SDKs/iPhoneOS8.1.sdk/usr/include/ -L /var/stash/Developer/SDKs/iPhoneOS8.1.sdk/usr/lib/ -L /var/stash/Developer/SDKs/iPhoneOS8.1.sdk/usr/lib/system/ 

因為SDK所在路徑的原因,編譯命令比較長,正式使用的時候可以寫入到編譯腳本或者Makefile。
這時候直接運行輸出的結果會報錯:

./test
Killed: 9

這同樣是因為簽名機制的原因,需要為我們編譯的程式簽名後再執行,就一切正常了:

ldid -S test
./test
hello ios!

安裝iOS的ssh終端

現在已經可以在iOS設備上進行開發了,但事情還沒有完。我們剛纔所有的操作,都是在電腦的鍵盤、屏幕的配合下完成的所有操作,這遠遠算不上"自開發"。
可以使用的方法之一是在iOS中安裝ssh終端程式,從而在iOS設備上直接操作自己的命令行。終端程式推薦一個免費又好用的Termius,請自行在AppStore搜索下載。
但在設置的時候你會發現,Termius根本無法連接上自己。原因是自iOS8之後,系統已經禁止App直接連接設備的1024號以下的埠了。
我們可以設置openssh的sshd服務增加一個監聽埠,操作方法如下:

  1. 新建一個自啟動服務文件:
vim /Library/LaunchDaemons/com.openssh.sshd2.plist

內容為:
```xml

<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">

<dict>
    <key>Label</key>
    <string>com.openssh.sshd2</string>

    <key>Program</key>
    <string>/usr/libexec/sshd-keygen-wrapper</string>

    <key>ProgramArguments</key>
    <array>
        <string>/usr/sbin/sshd</string>
        <string>-i</string>
    </array>

    <key>SessionCreate</key>
    <true/>

    <key>Sockets</key>
    <dict>
        <key>Listeners</key>
        <dict>
            <key>SockServiceName</key>
            <string>ssh2</string>
        </dict>
    </dict>

    <key>StandardErrorPath</key>
    <string>/dev/null</string>

    <key>inetdCompatibility</key>
    <dict>
        <key>Wait</key>
        <false/>
    </dict>
</dict>
</plist>
```
  1. 編輯/etc/services文件,在文件最後增加以下兩行:
ssh2              10022/udp     # SSH Remote Login Protocol
ssh2              10022/tcp     # SSH Remote Login Protocol

重啟後,再次激活越獄,可以在Termius中設置ssh連接到本機的10022埠了。

使用iOS的IDE

命令行工具對很多新手來講使用起來難度還是不低的,我們還有另外一個選擇。ios開發社區工程師lufinkey推出了一個集成的開發工具miniCode,能讓程式員像操作電腦一樣在ios開發簡單的試驗工程。miniCode的項目頁面在:https://github.com/lufinkey/miniCode
如果你使用apt-get直接安裝了iostoolchain,那簡單了,直接一行代碼就能安裝上miniCode:

apt-get install com.brokenphysics.minicode

但如果在剛纔的安裝中,你不得不手工選擇安裝了32位的編譯器,那這次還是要手工安裝minicode,因為手工安裝的32位編譯器無法滿足minicode的依賴包要求:

wget http://apt.thebigboss.org/repofiles/cydia/debs2.0/minicode_1.03.5.deb
dpkg -i --force-all minicode_1.03.5.deb

類似上面安裝的iFile,minicode也是一個越獄環境運行的GUI程式,我們在命令行安裝的GUI程式通常需要重啟才能在iOS桌面看到,為了加快速度,我們可以只重啟iOS的外殼SpringBoard:

su -c uicache mobile
killall SpringBoard



參考資料

miniCode brings Xcode to your iPhone and iPad


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、創建資料庫1.啟動服務(三種) 開始--cmd--輸入net start mssqlserver 開始--運行--net start mssqlserver 開始--服務--找到SQLSERVER(MSSQLSERVER)--右鍵--啟動 2.打開ssms 3.登錄:windows身份驗證 混合 ...
  • 在鞋廠的第一個任務,拆表。需要把訂單表按照開始日期和結束日期拆分成多條記錄,挺新鮮的~ transform方式,使用到了python。 (1)把hive表的數據傳入,通過python按照日期迴圈處理,返回多條記錄。 (2)生成序列表,然後採用cross join的方式,在hive端生成多條記錄,再根 ...
  • 本章主要介紹了 MapReduce 的開發原理及應用場景,講解如何利用 Combine、Partitioner、WritableComparable、WritableComparator 等組件對數據進行排序篩選聚合分組的功能。利用例子模仿 SQL 關係資料庫進行SELECT、WHERE、GROUP... ...
  • [toc] mysql utilities 是python編寫 MySQL官方版的命令行工具集,涵蓋主從校驗,主從建立,主從切換等等 安裝 rpm安裝 註意 儘量不要通過yum來安裝mysql utilities,mysql utilities 1.6.5和mysql connector pytho ...
  • 用的Oracle版本是12c,在解鎖scott時提示用戶不存在,於是搜解決方法,給出了兩種方法: 一種是載入scott.sql文件(我的scott.sql文件是存在的,在Oracle安裝目錄下搜索一下),然後在命令行裡面輸入:“@”+“你剛剛查找到的scott.sql文件的目錄”例如:SQL>@E: ...
  • 在安裝APK的時候有時候會出現這種錯誤,原因是卸載之前的APK不徹底,有殘餘,手動刪除android目錄下相關的文件。 ...
  • 大家都知道,想給RecycleView設置分割線可以重寫RecyclerView.ItemDecoration 項目過程中,遇到一個需求:RecycleView頂部有一條灰色的間隔,我想到了給RecycleView設置分割線的方法,當然只給第一個Item設置,而且在上方。 在onDrawOver方法 ...
  • 效果如下 gif圖展示效果不好,實際體驗無卡頓 1.自定義屬性 早Values目錄下New values resource file,命名為attrs.xml(命名隨意,但規範命名為attrs.xml) 自定義屬性如下,註意format不要與Android自帶的命名重覆。 2.編寫自定義View 3 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...