當前位置:首頁 » 安卓系統 » Androidshell文件夾

Androidshell文件夾

發布時間: 2022-11-26 01:48:02

⑴ android adb shell 用什麼命令打包文件夾

linux 打包文件夾的命令是 zip 或者是 tar tar在linux中比較常見,但是手機上肯定都不支持的。

⑵ Android 講述執行怎樣執行shell腳本

一、Android應用啟動服務執行腳本
1 如何寫服務和腳本
在android源碼根目錄下有/device/tegatech/tegav2/init.rc文件相信大家對這個文件都不陌生(如果不明白就仔細研讀下android啟動流程)。如果在該腳本文件中添加諸如以下服務:
service usblp_test /data/setip/init.usblpmod.sh
oneshot
disabled
註解:每個設備下都會有自己對應的init.rc,init.設備名.rc腳本文件。oneshot disabled向我們說明了在系統啟動的時候這個服務是不會自動啟動的。並且該服務的目的是執行/data/setip/init.usblpmod.sh腳本。腳本的內容你可以隨便寫,只要符合shell語法就可以了,比如腳本可以是簡單的設置eth0:
# ! /system/bin/sh //腳本的開頭必須這樣寫。
Ifconfig eth0 172.16.100.206 netmask 255.255.0.0 up//設置ip的命令
2、如何在應用中啟動服務
1)首先了解下在服務啟動的流程
1. 在你的應用中讓init.rc中添加的服務啟動起來。
首先了解下在服務啟動的流程:
在設備目錄下的init.c(切記並不是system/core/init/init.rc)
Main函數的for(;;)循環中有一個handle_property_set_fd(),函數:
for (i = 0; i < fd_count; i++) {
if (ufds[i].revents == POLLIN) {
if (ufds[i].fd == get_property_set_fd())
handle_property_set_fd();
else if (ufds[i].fd == get_keychord_fd())
handle_keychord();
else if (ufds[i].fd == get_signal_fd())
handle_signal();
}
}
這個函數的實現也在system/core/init目錄下,該函數中的check_control_perms(msg.value, cr.uid, cr.gid)函數就是檢查該uid是否有許可權啟動服務(msg.value就是你服務的名字),如果應用為root或system用戶則直接返回1.之後就是調用handle_control_message((char*) msg.name + 4, (char*) msg.value),該函數的參數就是去掉1.ctl.後的start和2.你服務的名字。這個函數的詳細內容:
void handle_control_message(const char *msg, const char *arg)
{
if (!strcmp(msg,"start")) {
msg_start(arg);
} else if (!strcmp(msg,"stop")) {
msg_stop(arg);
} else if (!strcmp(msg,"restart")) {
msg_stop(arg);
msg_start(arg);
} else {
ERROR("unknown control msg '%s'\n", msg);
}
}
匹配start後調用msg_start.服務就這樣起來了,我們的解決方案就是在檢查許可權的地方「下點功夫」,因為我們不確定uid,所以就讓check_control_perms這個函數不要檢查我們的uid,直接檢查我們服務的名字,看看這個函數:
static int check_control_perms(const char *name, unsigned int uid, unsigned int gid) {
int i;
if (uid == AID_SYSTEM || uid == AID_ROOT)
return 1;
/* Search the ACL */
for (i = 0; control_perms[i].service; i++) {
if (strcmp(control_perms[i].service, name) == 0) {
if ((uid && control_perms[i].uid == uid) ||
(gid && control_perms[i].gid == gid)) {
return 1;
}
}
}
return 0;
}
這個函數裡面是必須要檢查uid的,我們只要在for循環上寫上。
if(strcmp(「usblp_test」,name)==0) //usblp_test就是我們服務的名字。
return 1;
這樣做不會破壞android原本的結構,不會有什麼副作用。
init.c和init.rc都改好了,現在就可以編譯源碼了,編譯好了裝到機子開發板上就可以了。

⑶ android系統內置應用

將apk放置系統目錄:/vendor/companyname/

新建apk目錄(apk為名)-->放入apk和Android.mk文件

Android.mk作用主要是解壓apk包將lib庫文件解壓到 system/lib或system/lib64包下,拷貝到system/app或system/pri-app/ 下

第一種方式    Android.mk通過shell命令 mkdir -p  創建對應的文件夾,shell cp命令拷貝到對應的system/app或system/priv-app:

include $(CLEAR_VARS)

LOCAL_MODULE := TestDemo

$(shell mkdir -p $(PRODUCT_OUT)/system/priv-app/TestDemo)

$(shell cp $(LOCAL_PATH)/$(LOCAL_MODULE).apk $(PRODUCT_OUT)/system/priv-app/TestDemo/)

第二種方式:如果apk文件中有依賴的so文件庫,可以解壓將其拷貝到系統system/lib和system/lib64

Android.mk的內容主要就是解壓拷貝:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE := TestDemo

LOCAL_MODULE_CLASS := APPS

LOCAL_CERTIFICATE := PRESIGNED

LOCAL_MODULE_TAGS := optional

LOCAL_SRC_FILES := TestDemo.apk #源文件

LOCAL_MODULE_SUFFIX := $(COMMON_ANDROID_PACKAGE_SUFFIX)

LOCAL_POST_INSTALL_CMD := $(hide) UNZIP_PATH=$(LOCAL_PATH)/$(LOCAL_MODULE); \

        unzip -o $(LOCAL_PATH)/$(LOCAL_SRC_FILES) -d $$UNZIP_PATH; \

        mv $$UNZIP_PATH/lib/armeabi-v7a/ $$UNZIP_PATH/lib/arm; \

        mv $$UNZIP_PATH/lib $(TARGET_OUT)/app/$(LOCAL_MODULE)/lib; \

        rm $$UNZIP_PATH -rf;

include $(BUILD_PREBUILT)

相同的方式建立文件夾,腳本文件和Android.mk文件:

Android.mk內容:

include $(CLEAR_VARS)

LOCAL_MODULE := test.sh    #腳本名稱

LOCAL_MODULE_TAGS := optional

LOCAL_MODULE_PATH := $(TARGET_OUT)/bin #編譯後生成位置

LOCAL_SRC_FILES := $(LOCAL_MODULE)  #源碼文件

LOCAL_MODULE_CLASS := FAKE

如/vendor/companyname/mycompany.mk

PRODUCT_PACKAGES := \

                PrebuiltGmsCore \

                GmsCoreSetupPrebuilt \

                GoogleServicesFramework \

                GoogleLoginService \

                Phonesky \

                libDPN_SECURITY \

                 test.sh  \ #加入

然後在device/目錄下找到本工mk文件,例如:device/softwinner/mycompany/mycompany.mk

加入

$(call inherit-proct,vendor/companyname/mycompany.mk) #這樣系統就可以找到這個mycompany.mk文件,將這些申明的apk編譯進系統

⑷ 安卓文件中Shell文件夾可以刪除嗎

你肯定吧一些軟體轉移到了SD卡

⑸ android的shell有啥用

android 底層驅動實際linux, linux中大量使用了shell。那 shell到底是什麼東西呢?個人理解相當於windows中的

cmd,但是shell很強大,如果你能熟練使用shell,在android開發中如虎添翼。

下面就android常用的shell進行一下說明:

1. cd (change directory)

如: cd / 跳轉到根目錄 cd ~ 跳轉到用戶所在的目錄

2. ls (list)

顯示目錄結構

3. chmod 777 path

在開發過程中,如果發現文件不能讀寫,首先應該想到是否給user許可權,可以通過該命令試試看

改變目錄屬性,如果目錄下面還有子目錄,加上-R

4. chown 該變目錄所有者

如果目錄還有子目錄,加上-R

5. rm 目錄

如果是文件加上-f

如果是目錄加上-r

6. find

找文件,如果找到R.java文件,然後刪除它

find . -name R.java|args rm -rf

find . -name *.svn|xargs rm -rf
find . -name *.class|xargs rm -rf

7. 替換,如某個文件中根據某個模式替換某行

如下命令就是找到FPTitlebar.java這個java文件,找不到// pm.shutDown();,用pm.shutDown();替換之。

find . -name FPTitlebar.java -exec sed -i 's\// pm.shutDown();\ pm.shutDown();\' {} \;

比較難的如下所示:

find . -name *.java -exec sed -i 's\KeyEvent.KEYCODE_2\KeyEvent.KEYCODE_CAMERA \g ' {} \;
find . -name *.java -exec sed -i 's\KeyEvent.KEYCODE_1\KeyEvent.KEYCODE_CALL \g ' {} \;

找到所有的java文件,用KeyEvent.KEYCODE_CAMERA替換KeyEvent.KEYCODE_2

8. 編譯android源碼時實際也是執行shell命令:

//執行build 目錄下envsetup.sh命令

. build/envsetup.sh

//彈出選擇框,分別選擇第一個,第一個,第五個,第三個

choosecombo 1 1 5 3

//設置環境變數

export ANDROID_JAVA_HOME=$JAVA_HOME

//執行update命令

make update-api

//起4 個線程同時編譯

make -j 4

9. 如果你使用了第三so包,需要在android編譯,直接在mk文件中添加如下設置即可:

如下所示:

1. 聲明library名稱

###############################
LOCAL_STATIC_JAVA_LIBRARIES := xstream
###############################

2. 加入引入的庫文件

###############################
include $(CLEAR_VARS)
LOCAL_PREBUILT_STATIC_JAVA_LIBRARIES := xstream:xstream-1.3.1.jar
include $(BUILD_MULTI_PREBUILT)
###############################

⑹ android程序執行shell命令是shell許可權嗎,如果不是該怎麼用shell許可權來執行可執行文件

shell只是一個人機界面,到底以shell什麼用戶執行,看看你那文件許可權,是否該該用戶有執行許可權先。你說的很模糊。

⑺ adb shell想在安卓手機創建目錄但是創建不了

adb shell主要是進入手機內部操作的,跟內存卡有啥關系?內存卡建立目錄也不用打adb shell啊?樓下瞎說;
根目錄一般好像不能創建,或者你沒有取得Root寫入許可權,只是可以訪問而已
1.在CMD裡面(含adb文件的目錄裡面)打入adb shell
2.成功後進入你想要創建目錄的位置,比如你想在data裡面創建
cd data
3.打入mkdir 你的目錄名,回車
如果不成功,試著chmod命令看看

⑻ 安卓文件中Shell文件夾可以刪除嗎機型聯想A708T,SD卡的所用空間有3G然而scard中所有

尊敬的聯想用戶,您好!
非常抱歉,給您的使用帶來困惑了。
shell文件夾一般是用來存放安卓系統相關的腳本,由於涉及到系統文件建議您最好不要刪除,以免造成系統異常。
針對您SD卡空間的問題,如果您把程序安裝在SD的話那麼這部分被使用的空間是隱藏的,另外可能還有一些隱藏的文件占據著一部分的空間,建議您可以使用安全軟體對SD卡進行垃圾掃描清理,請了解。
更多關於手機使用的小知識,可以參考官方視頻網站:
http://ideaservice.lenovo.com.cn/v/
感謝您對聯想的支持,祝您生活愉快!

⑼ 如何更改Android/date下文件夾的許可權

可以在shell終端下修改/data文件夾的許可權:

  1. 命令行執行adb shell 進入shell 。

  2. 執行su切換到root用戶。

  3. chmod 777 /data 使用chmod命令修改許可權,注意/data即是需要修改的文件或文件夾。

⑽ android shell 命令實現復制文件(記錄一下)

有兩種命令:
android shell 命令實現復制文件
1、cat source_file > dest_file
2、dd if=source_file of=dest_file

Android remount命令的兩種寫法
remount命令的兩種寫法

不同系統的參數格式可能不一樣,而且可能沒有--help列印,記錄一下:
mount -o remount -rw /system
mount -o remount,rw /system

有個需求,客戶樣機固件裡面的jar包有些問題需要替換,但是樣機已經賣到用戶手上了
,這里需要用做過apk去給用戶做替換處理;

熱點內容
鎮江節點伺服器測試ip 發布:2024-05-06 07:15:05 瀏覽:540
sqlserver表格 發布:2024-05-06 07:09:54 瀏覽:612
雪鐵龍凡爾賽選哪個配置 發布:2024-05-06 06:56:04 瀏覽:571
福睿斯配置怎麼樣 發布:2024-05-06 06:50:16 瀏覽:103
微生物資料庫 發布:2024-05-06 06:47:33 瀏覽:604
原神和steam游戲哪個需要配置 發布:2024-05-06 06:37:40 瀏覽:666
nginx訪問403 發布:2024-05-06 05:56:39 瀏覽:677
android上傳圖片參數 發布:2024-05-06 05:56:04 瀏覽:221
360控制上傳流量 發布:2024-05-06 05:38:11 瀏覽:999
幾代演算法 發布:2024-05-06 05:33:43 瀏覽:353