زیر و بم ADB اندروید

در مجموعه ابزارهای توسعه‌ی اندروید (Android SDK) یکی از پرکاربردترین و مهم‌ترین ابزارها، ابزار خط‌فرمانی‌ای به نام adb (سرواژه‌های Android Debug Bridge) هست. adb وسیله‌ی اصلی ارتباط بین رایانه و دستگاه اندرویدی (یا امولاتور) هست  که خود IDEها (مثل اندروید استودیو، IntelliJ IDEA و سابقاً eclipse) به کمک این ابزار ارتباطشون با دستگاه برای کارهایی مثل نصب اپ، وصل کردن debugger و نمایش logcat انجام می‌دن. در ادامه با تعدادی از کاربردهای مفید این ابزار رو آشنا می‌شید که می‌تونه خیلی از کارهاتون رو راحت کنه.

اضافه کردن adb به PATH

برای اینکه بتونید مستقیماً دستورات رو در ترمینال/خط‌فرمان وارد کنید بهتره که پوشه‌ی حاوی ‎‎‎adb ‎‎(platform-tools)‎ رو به PATH سیستم اضافه کنید. تو لینوکس خط زیر رو باید به آخر فایل ‎.‎bashrc‎ اضافه کنید. تو ویندوز هم باید مثل این عکس System Properties رو باز کنید، دکمه‌ی Environment Variables رو کلیک کنید و در بخش System variables متغیر PATH رو ویرایش کنید. اگر وجود نداشت باید بسازید.

export PATH=$PATH:/path/to/android-sdk/platform-tools/

image

بخش اول: شروع کار با adb

در ترمینال یا Power Shell اسم adb رو بنویسید و enter بزنید. باید نسخه و لیستی ازکامندهای adb رو ببینید؛ اگر اینطور نیست تنظیمات PATH یا نصب Android SDK ممکنه مشکل داشته باشه.

adb devices

لیست دستگاه‌هایی (و امولاتورهای فعال) که USB Debuggingشون روشنه و با کابل به کامپیوترتون وصل شدند رو نشون می‌ده.

image

بعضی اوقات در لینوکس ممکنه سریال دستگاه به صورت ؟؟؟؟؟؟؟ نشون داده بشه، در این مواقع باید adb رو restart کنید و با sudo اجرا کنید. این کار رو با دوتا دستور زیر میشه انجام داد:

adb kill-server
sudo adb start-server

بخش دوم: اتصال به دستگاه از طریق Wi-Fi +

adb بدون کابل USB هم می‌تونه به دستگاه وصل شه. برای دولوپر‌ها و QAهایی که تعداد زیادی دستگاه برای تست دارند ولی به اون اندازه پورت خالی USB ندارن میتونه خیلی کاربردی باشه. با دستور tcpip باید دستگاه رو وارد حالت wifi کرد. بعد از اجرای موفق این دستور می‌تونید کابل رو از دستگاه جدا کنید و با adb connect به دستگاه وصل شید. برای فهمیدن آدرس IP دستگاه می‌تونید وارد بخش Settings > About Phone > Network بشید یا قبل از جدا کردن کابل usb از دستور adb shell ntcfg استفاده کنید.

adb tcpip 5555
adb shell netcfg
# Disconnect phone from USB cable
adb connect [ip]:5555 

image

برای دستگاه‌هایی که با Wi-Fi وصل شدند تو خروجی adb devices بجای سریال نامبر گوشی آدرس IP و پورت ۵۵۵۵ دیده می‌شه.

بخش سوم

انتقال فایل

با دستورهای push و pull می‌تونید بین دستگاه اندرویدی و رایانه‌تون فایل انتقال بدید.

adb push [Local Path] [Device Path] # Copy file to device
adb pull [Device Path] [Local Path] # Copy file from device

نصب و مدیریت اپلیکیشن‌ها

نصب یک اپلیکیشن از روی فایل apk:

adb install my-application.apk

نصب همزمان چند اپلیکیشن

adb install-multiple app1.apk app2.apk ...

نصب روی SDCard:

adb install -s my-application.apk

نصب یک نسخه‌ی به‌روز تر از برنامه‌ای که روی دستگاه نصب شده:

adb install -r my-application.apk

نصب نسخه‌ی قدیمی‌تر نسبت به نسخه‌ای که روی دستگاه نصب شده:

adb install -r -d my-application.apk 

حذف برنامه با اسم پکیج وارد شده:

adb uninstall [Package Name]

حذف، بدون پاک شدن دیتا:

adb uninstall -k [Package Name]

فهرست برنامه‌های نصب شده روی گوشی:

adb shell pm list packages

حذف تمام اطلاعات برنامه، معادل دکمه‌ی Clear Data در Settings:

adb shell pm clear [Package Name]

توقف و از بین بردن تمام مؤلفه‌های (اکتیویتی، سرویس، …) یک اپلیکیشن در حال اجرا از حافظه. معادل دکمه‌ی Force Stop در Settings:

adb shell am force-stop [Package Name]

چند دستور متفرقه

ریبوت دستگاه به صورت عادی یا حالت safe:

adb reboot
adb reboot recovery
adb reboot bootloader

با دستور زیر به خروجی logcat دسترسی پیدا می‌کنید. برای مثال به عنوان کاربرد مفیدش می‌تونید این خروجی رو در فایل ذخیره کنید یا به grep ارسال کنید.

adb logcat
adb logcat -f logs.txt
adb logcat -t 20
adb logcat *:e

خط اول فراخوانی و نمایش log دستگاه به صورت عادی است. خط دوم محتویات log را در فایلی به اسم logs.txt ذخیره می‌کند. خط سوم فقط 20 مورد آخر logها را نمایش می‌دهد. خط چهارم فقط مواردی را نشان می‌دهد که در سطح Error یا وخیم تر باشند. levelهای دیگر قابل استفاده:

level meaning
v verbose - همه‌چیز
d debug
i info
w warning
e error
f fatal
s silent - هیچ‌چیز

با این دستور در اندروید ۴ به بالا می‌تونید از یک یا چند اپلیکیشن فایل backup تهیه کنید و بعدا restore کنید. این فایل backup شامل دیتای اپلیکیشن مورد نظر هست. اگر مثل خط دوم و سوم از آپشن ‎-apk استفاده کنید فایل‌های apk برنامه‌ها هم در فایل بکاپ وجود خواهند داشت. با استفاده از کدی که روی گیتهاب به اشتراک گذاشتم می‌تونید فایل بکاپ اندروید رو تبدیل به یک فایل tar کنید که به راحتی فایل‌های داخلش قابل مشاهده و extract کردن هست.

adb backup -f backup-file.ab com.example.app1 com.example.app2
adb backup -apk -f backup-file.ab com.example.app1 com.example.app2
abd backup -all -apk -f backup-file.ab # پشتیبان گیری از تمام اپلیکیشن‌ها همراه با فایل نصب
adb restore backup-file.ab

بخش چهارم: Shell

دستور ‎adb shell ‎[‎command]‎ برای اجرای یک دستور شل روی دستگاه کاربرد دارد؛ بالاتر برای clear data و force stop کردن برنامه‌ها دو نمونه استفاده از این دستور را دیدید. اگر دستور adb shell` را بدون وارد کردن دستور خاصی وارد کنید، وارد یک shell روی دستگاه می‌شود، درست مثل اینکه به دستگاه با ssh وصل شده باشید.

[mjafar@mjafar-VAIO]$ adb shell
shell@g2:/ $

از این شل می‌تونید دستورات مختلفی مثل pm (Package Manager)‎ برای مدیریت اپلیکیشن‌ها، am (Activity Manager)‎ برای باز و بسته کردن و از بین بردن … اکتیویتی‌های برنامه‌ها، bmgr (Backup Manager)‎ برای تنظیمات پشتیبان گیری و بازگردانی گوشی، netcfg برای تنظیمات شبکه دستگاه رو خیلی راحت اجرا کنید. ابزار monkey که برای تست اپلیکیشن‌ها کاربرد داره هم تو این شل قابل استفاده‌ست.

شل از نوع sh و خیلی مینیمال هست اما به اندازه‌ی خیلی خوبی کار راه انداز. یکی از مهم ترین دستوراتی که تو این شل می‌تونید ازش استفاده کنید run-as هست. این دستور user فعلی رو به user مربوط به اپلیکیشنی که وارد کردید تغییر میده و وارد پوشه‌ی dataی اون اپ میشه. بعد از این می‌تونید دیتای اپلیکیشن رو بخونید یا دست کاری کنید به طوری که انگار خود اپلیکیشن این تغییرات رو انجام داده.

shell@g2:/ $ run-as com.example.myapp
com.example.myapp@g2:/data/data/com.example.myapp $

مثلا می‌شه مقادیر ذخیره شده در shared preferences اپلیکیشن رو که به صورت xml ذخیره شدند بخونید. دستور sqlite3 برای خواندن و تغییر محتویات دیتابیس اپلیکیشن قابل استفاده است.

com.example.myapp@g2:/data/data/com.example.myapp $ ls shared_prefs
com.example.myapp@g2:/data/data/com.example.myapp $ sqlite3 databases/main.sqlite

امیدوارم این پست براتون مفید بوده باشه :-)

Mohammad Jafar Mashhadi

Mohammad Jafar Mashhadi

Your average genius.

comments powered by Disqus
rss facebook twitter github gitlab youtube mail spotify lastfm instagram linkedin google google-plus pinterest medium vimeo stackoverflow reddit quora quora