當前位置:首頁 » 編程軟體 » 如何自己編譯安卓刷機包

如何自己編譯安卓刷機包

發布時間: 2023-11-26 00:24:20

Ⅰ 如何修改製作卡刷包 安卓卡刷包製作教程

在此先要明確聲明一下:
依照此做法出現您的手機出現任何問題,概不負責的喔!!
英文好的朋友,可以直接看英文官方的參考網站即可:
只用android源代碼做一些簡單實驗的朋友可以參考下面這幾個網站:
說起android刷機包,聽起來非常神秘,實際上它僅僅是一個經過數字簽名的zip壓縮包而已。如果要自己製作刷機包,則必須了解刷機包的基本工作原理,偶首先從android系統的啟動說起:
android系統啟動的時候,首先會進行一些諸如硬體自檢之類的操作,這些操作完成以後(至少它應該知道當前的機器有沒有電),會檢查一下當前手機按鍵的狀態(接下來就是所謂刷機模式切換了,不同的android手機有不同的按鍵組合用來進入刷機模式),如果此時按鍵狀態處於刷機組合,那麼系統會調用ROM裡面的一個叫做recovery的程序(這時就是進入了所謂的刷機程序了,它只是一個工具性質程序,用於檢查刷機包的完整性和數字簽名的合法性。對於目前大多數root過的機器而言,數字簽名的合法性都不會成問題,然後由recovery程序將刷機包進行解壓,然後把刷機包裡面的文件寫入到ROM中去,以此完成刷機過程);如果此時按鍵沒有標明是刷機模式,那麼系統會創建內存檔,開始從ROM裡面載入相應的文件系統,並把相關的文件拷貝到內存檔中,進而引導linux啟動,然後是啟動虛擬機dalvik,然後就是創建工作進程載入和運行framework,然後就會看到待機的畫面。當然在這個過程中還發生了許多事情,啟動了許多服務,為了簡化起見,對於啟動過程偶只講解到此,感興趣的朋友可以自己結合著linux的啟動過程加以對比來學習。
現在來總結一下,實際上刷機包就是一個ROM文件的壓縮包,進入刷機模式後,recovery程序會把刷機包裡面的文件寫入ROM存儲區替換ROM存儲區的原有文件;當下次啟動手機的時候,會從ROM中載入剛剛替換過的文件,並利用這些文件來啟動和運行系統。這就是刷機包的全部功能和作用,看不懂的朋友可以反復看幾次,刷機的本質就是文件的覆蓋和替換操作,偶相信各位一定能看懂!
OK,現在大家已經知道ROM文件的zip壓縮包就是所謂的刷機包。製作刷機包的過程就是准備這些文件,然後重新把這些文件壓縮成一個zip包的過程,在製作的最後,使用簽名工具簽個名,就可以測試和發布刷機包了。雖然說起來就是一句話的事情,但是實際上准備這些文件的過程是非常痛苦和漫長的。
那麼update.zip壓縮包裡面的都包含哪些文件?這些文件又都是如何做出來的呢?hoho,現在開始漸漸接觸到問題的本質了,解壓縮這個update.zip壓縮包以後我們可以看到兩個目錄和一個文件:
boot.img <---文件,這是編譯內核源代碼生成的內核映像,然後與android源碼編譯出來的ramdisk.img一起通過mkbootimg工具創建出來的,圖省事的朋友也可以從網上其他的刷機包裡面拷貝一個能用的出來即可,基本上都差不多。
META-INF <---目錄,這個目錄是手工創建的,主要用來存放一個升級腳本update-script(這個腳本的內容與system目錄中包含的文件有很大關聯)以及保存若干刷機包內的apk文件的簽名。
system <---目錄,這個目錄就是編譯android的平台源代碼生成的,
其實最好的學習方式就是把現在互聯網上的那些update.zip包給解包,然後自己一個一個文件地看和分析,然後修改,嘗試做自己的刷機包。
對於這個boot.img,基本思路是編譯android kernel代碼,生成內核image然後利用mkbootimg感興趣的朋友可以參考下面這兩個wiki網站:
下面的做法偶都是在linux下面完成的(slackware 13.1):
(1)下載和編譯android的源代碼,具體過程不再贅述
如果各位還不知道repo sync之類的命令的話,可以參考網上的關於下載android源代碼以及編譯的文章,據偶所知這些文章非常豐富。編譯之前一定要注意平台的選擇,不同平台的驅動程序是不一樣的!這些參數可以通過:
$ cd android-src <---進入android的源代碼目錄
$ . build/envsetup.sh <---設置環境變數,運行完畢後,你可以輸入一下help命令,看看google的團隊提供了多少有用的便利命令,這對於我們以後修改代碼重新編譯非常有幫助。
$ lunch generic-eng <---開始配置android的源代碼的編譯選項
運行上述命令後會看到如下輸出:
wayne@wayne:~/android-src$ lunch generic-eng
============================================
PLATFORM_VERSION_CODENAME=REL
PLATFORM_VERSION=2.1-update1
TARGET_PRODUCT=generic
TARGET_BUILD_VARIANT=eng
TARGET_SIMULATOR=false
TARGET_BUILD_TYPE=release
TARGET_ARCH=arm
HOST_ARCH=x86
HOST_OS=linux
HOST_BUILD_TYPE=release
BUILD_ID=ECLAIR
============================================
$ make -j2 <---只有單核的CPU的朋友可以嘗試此參數,雙核的朋友可以試試-j3,否則就老老實實運行make即可。
然後就是一個漫長的等待,這個時間大概有1-2小時左右(偶的機器比較慢),完全編譯完畢以後硬碟的佔用大概需要8個G左右。
(2)編譯完成以後,進入wayne@wayne:~/android-src/out/target/proct/generic目錄,應該會看到如下的文件:
android-info.txt
data
obj
ramdisk.img
sdk
system
userdata.img
clean_steps.mk
installed-files.txt
previous_build_config.mk
root
symbols
system.img
這里的system.img是不是很眼熟?!對拉,這個就是刷機包裡面好像也有一個叫做什麼system的目錄,那麼這個system.img裡面都有什麼呢?這裡面的東西其實就是當前目錄下的一個叫做system的目錄裡面的內容了,只是保存成了yaffs文件系統的格式。我們可以通過unyaffs工具來把system.img給解開來看看,就明白偶說話了。
unyaffs的代碼下載地址為:
在linux下編譯方法非常地簡單,只需要下載源代碼,然後運行:$ gcc -c unyaffs.c
$ gcc -o unyaffs unyaffs.o
即可生成這個unyaffs的解包工具,利用這個工具就可以把自己生成的system.img進行解包,然後修改裡面的內容了。
unyaffs使用方法非常簡單:
$ unyaffs system.img [回車]
即可將system.img解包成一個叫做system的目錄,裡麵包含了整個android的文件系統
(3)剛剛開始,不適合一切從頭來,還是老實一些,先從修改別的大牛們做得刷機包開始吧
首先拷貝一個從網上下載下來的刷機包,然後找一個目錄解壓縮(當然,這是最保險的做法,自己做這些目錄也沒有任何問題,只是比較費時間而已)
$ unzip xxxxxx.zip <--- 這個xxxxx.zip就是從網上下載的某刷機包(一定要跟你的代碼版本基本一致喔,偶在這里用的是2.1的刷機包)
(4)替換原有的system目錄
解壓縮刷機包以後,會看到在開篇的時候提到的兩個目錄,一個文件:
boot.img
META-INF
system
好了,可以把system目錄拷貝到別的路徑下備份一給,防止這些修改發生別的問題。然後把wayne@wayne:~/android-src/out/target/proct/generic這個目錄下面的system拷貝到當前的工作目錄下。注意,這個system目錄裡面有很多「符號鏈接」指向了toolbox。這些鏈接其實沒啥用,可以通過後面的update-script自動進行創建的,因此,需要用一個腳本把這些鏈接都刪掉。
可以參考:
這個網頁附件給出來的DeleteExtras.txt改寫成一個DeleteExtras.sh腳本來清除這些符號鏈接。
(5)修改update-script腳本
修改META-INF/com/google/android目錄下的那個叫做update-script的腳本,只要修改一下即可,主要是刪除一些不存在的文件以及增加一些文件的許可權之類的定義(語法十分清晰,一目瞭然)。把需要「預裝」到刷機包裡面的apk安裝程序都准備好,將這些apk拷貝到system/app目錄下即可。那個boot.img能不改就不改,因為這東西涉及到驅動和內核的問題,出了問題刷機包就啟動不了了。

Ⅱ 怎麼在手機上製作刷機包

.

目前有好幾種方法來安裝軟體或是庫文件到你的Android手機上。你可以使用市場程序來查找並安裝軟體,也可以使用adb命令行工具來安裝或是發送文件到你的Android文件系統中。這些方法對於操作單個文件來說都挺方便的,但是如果你需要一次性安裝多個軟體或是庫文件時,那麼最為方便的方法大概就是使用update.zip(也就是刷機包)文件了。Android系統使用恢復工具(recovery)來安裝這個update.zip文件中的軟體或庫文件到Android文件系統中。而一個ROM或是主題開發者通常都是使用這個方式來發布他們的作品(刷機包)。

創建一個update.zip文件是很簡單的事情,你所需要做的就是將文件放置到與Android文件系統中相對應的文件夾中,然後編寫一個用來復制這些文件到手機對應位置的update-script文件。作為舉例,本文會安裝Calculator.apk到system/app文件夾,復制libsec-ril.so文件到system/lib文件夾:

新建一個空文件夾(本文例:C:\mumayi)

新建用來放置Calculator.apk的文件夾C:\mumayi\system\app以及用來放置libsec-ril.so的文件夾C:\mumayi\system\lib。

創建用來放置update-script文件的文件夾C:\mumayi\META-INF\com\google\android。

創建一個名為update-script的文件,其內容如下(高亮部分):

行1和行5:顯示進度條

行3:復制刷機包中的system文件夾到Android的/system

注意:你應該在文件的最末尾多添加一個空行(也就是行6)

將C:\mumayi壓縮中的所有內容壓縮為zip包(千萬記住:是壓縮mumayi這個文件夾中的內容,不是mumayi文件夾本身)

為mumayi.zip簽名

簽名命令:java -jar signapk.jar certificate.pem key.pk8 mumayi.zip update.zip

將update.zip文件復制到SD卡中,然後手機進入recovery界面來刷入這個刷機包

進階學習:(以下僅作參考,因實際情況不同,可能會有一定的出入。但是極度推薦學習本部分)

update-script 語法參考(在Android源碼的recovery.c文件中定義):

_dir

語法:_dir <源目錄> <目標目錄> [<時間戳>]

描述:復制<源目錄>中的內容到<目標目錄>中。如果<源目錄>中沒有同名文件進行覆蓋,那麼<目標目錄>中的原始內容會仍然存在不變。

示例:_dir PACKAGE:system SYSTEM:,這個命令會把刷機包中的system文件夾復制到手機的/system文件夾中

format

語法:format <根目錄>

描述:格式化一個分區。

示例:format SYSTEM:,這個命令會格式化整個/system。注意:格式化時所進行的數據刪除操作是不可逆轉的。

delete

語法:delete <文件1> [... <文件N>]

描述:刪除文件。

示例:delete SYSTEM:app/Calculator.apk,這個命令會刪除手機system/app文件夾中的Calculator.apk文件。

delete_recursive

語法:delete_recursive <文件或目錄1> [... <文件或目錄N>]

描述:刪除一個文件或遞歸刪除某個文件夾(也就是包括該文件夾中的所有內容)

示例:delete_recursive DATA:dalvik-cache,這個命令會刪除/data/dalvik-cache文件夾以及該文件夾中的所有內容。

run_program

語法:run_program <執行程序> [<參數> ...]

描述:運行一個刷機包中的外部程序。

示例:run_program PACKAGE:install_busybox.sh,這個命令會執行刷機包中的install_busybox.sh腳本(命令行)。

set_perm(本命令中涉及的數值,如有疑惑,請自行Google。uid=user id,gid=group id)

語法:set_perm <uid> <gid> <屬性> <路徑> [... <路徑N>]

描述:設置某個文件或是指定的整個目錄樹的所有者和許可權,就像是一個『chmod』、『chown』、以及『chgrp』命令的集合體。

示例:set_perm 0 2000 0550 SYSTEM:etc/init.goldfish.sh,這個命令會設置手機上system分區中etc/init.goldfish.sh文件的用戶組為:shell;用戶為:root;許可權為:所有者以及所屬用戶組成員可以進行讀取和執行操作,其他用戶無操作許可權。

set_perm_recursive(本命令中涉及的數值,如有疑惑,請自行Google。uid=user id,gid=group id)

語法:set_perm_recursive <uid> <gid> <文件夾屬性> <文件屬性> <路徑> [... <路徑N>]

描述:遞歸設置某個文件夾中所有內容的所有者和許可權

示例:set_perm_recursive 0 0 0755 0644 SYSTEM:app,這個命令會遞歸設置手機上system/app文件夾以及其所有內容的用戶組為:root;用戶為:root;app文件夾的許可權為:所有者可以進行讀、寫、執行操作,其他用戶可以進行讀取和執行操作;app文件夾下的所有文件的許可權為:所有者可以進行讀寫操作,其他用戶可以進行讀取操作。

show_progress

語法:show_progress <小數> <持續時間>

描述:為下一個操作在屏幕上顯示一個進度條,自動的根據<持續時間>指定的秒數來遞增進度條狀態(如果實際上進度條的推進是可以確定的,那就會更加迅速)。

示例:show_progress 0.1 0,這個命令是指,操作完成後,進度條前進0.1(10%)

symlink

語法:symlink <鏈接目標> <鏈接所在路徑>

描述:創建一個符合鏈接(就像是 『ln-s』)。<鏈接所在路徑>的格式類似於這樣:根目錄:路徑, 但是<鏈接目標>則是指目標文件(而且位置可能是相對與鏈接所在路徑的)

示例:symlink /system/bin/su SYSTEM:xbin/su,這個命令會為/system/bin/su在手機system分區的xbin文件夾下創建一個符號鏈接,名為su

熱點內容
如何用安卓編譯項目 發布:2025-01-24 08:30:46 瀏覽:863
計算機同時輸出和存儲設備的區別 發布:2025-01-24 08:29:21 瀏覽:581
食物語上傳 發布:2025-01-24 07:58:44 瀏覽:754
編程相關書籍 發布:2025-01-24 07:55:45 瀏覽:430
英雄聯盟手游需要哪些配置 發布:2025-01-24 07:42:03 瀏覽:985
regex可以靜態編譯嗎 發布:2025-01-24 07:40:32 瀏覽:79
怎麼編譯rec 發布:2025-01-24 07:39:04 瀏覽:56
卡片沒加密 發布:2025-01-24 07:33:56 瀏覽:381
linux備份mysql 發布:2025-01-24 07:26:54 瀏覽:391
蘋果手機忘記id密碼怎麼刷機 發布:2025-01-24 07:26:47 瀏覽:695