CSE 5520/4520 Wireless Networks
Fall’2012, Project 3
(Due 11/28/2012)
In project 3 we focus on analyzing the behavior of different Android applications on the mobile platform. Such a monitor can be useful in detecting malicious activities and malwares.
An android application requires a certain set of permissions to access some restricted resources in the smart phone. When a user about to install an application, the installation process will prompt the user about the type of the permissions required in running the application. If the user accepts, then the application will be installed. Once installed, it acquires the authority to use those resources. Sometimes, some of the privileges and resources are not even used by the application.
For project3, first, create an android application to monitor the usage of different resources and log them in a file (in the smart phone storage -sd card). Let’s call this app ResourceMonitor (you may give any creative name of your choice).
Next, you will be given a set of android applications (talk to TA to get this list) which can be downloaded from the Google Paly. This set of applications are related to each other based on functionality (For example Games, Business Applications etc.). The goal is to install applications in your device and monitor the resource usage using the Resource Monitor (written by you) and prepare a report about the system resource usage.
This project can be divided into four phases.
Step1: Build Android SDK and test on the hardware.
Step2. Download and build an Android application to monitor at least one system resource and log them in a file (use the monitor program supplied/pointed by the TA)
Step3: In this step, you are expected to develop a module for logging usage of different resources. Find/Decide a set of system resources (at least 5) that can be monitored. Then update your application to monitor these new set of resources and log them (e.g., network access, RAM usage, SD usage, CPU usage, location, SMS usage). It is also worth checking if the application is using the camera, microphone and other sensors.
Step4: Download a set of applications and monitor their behavior. For example, develop histograms for monitoring how long and how many times the resource has been accessed. The X-axis describes temporal aspects (time, in ms or seconds) of the application and the Y-axis histogram bins for “how long” or “how many time” the resource is accessed. Create the bar graph for each application and comment (4-5 lines for each plot) on the behavior of the application. The report should include problem definition, introduction, and methodology describing your monitor and how it monitors various resources, results, discussion, conclusion and references (5-10 pages including the graphs)
Tips for step 2:
Create an initial android resource monitoring app that monitors at least one resource (ex: network monitoring). You may use the same network monitoring app that TA gave you in the slides. But keep in mind this is a very basic app. It is not capable of logging data into a file nor it can run as a service in the background to monitor other apps. Next, you can start with this app (the one in the slides) and add the following functionality;
1. Capability in logging the data into a file with time stamps.
2. Also, the app should run as a service in the background
Finally, you may use this app to monitor other apps. Create your app so that it can start and stop the monitoring service.
Some useful links:
1. On Java file handling :
http://www.java2s.com/Tutorial/Java/0180__File/Catalog0180__File.htm
2. It is advised to use buffered reader / writer
http://www.java2s.com/Tutorial/Java/0180__File/0260__BufferedReader.htm
http://www.java2s.com/Tutorial/Java/0180__File/0340__BufferedWriter.htm
3. Don't forget to enable the WRITE_EXTERNAL_STORAGE permission.
4. Android services:
http://www.vogella.com/articles/AndroidServices/article.html
http://developer.android.com/guide/components/services.html
To Install and APK file in the Emulator:
There are many methods to do this.
This particular method uses a command line instruction in the PC to install the APK file in the emulator (or in the mobile phone).
Steps:
1. Start the emulator
2. Add the following directory to your path in your PC
"[Android SDK Home]\android-sdk\platform-tools\"
3. Using the command line, go to the directory where you have your APK files
4. Issue the following command in the command line to install the APK file in the emulator
adb -s emulator-5554 install "your apk file name.apk"
Then wait until it installs and gives you the confirmation.
Note: you may use the command: adb install "your apk file name.apk", but make sure only one emulator is running an no mobile phones are plugged in.
5. Then go to the menu in your emulator to check the installed application.
References:
[1] http://www.mobisoftinfotech.com/blog/android/installing-apk-files-on-android-device-emulator/
[2] A video (this does not show the same steps as above but it is a similar method): http://www.youtube.com/watch?v=7ALFFPPdvgs
I have attached a set of Android apps (5 apps) for you to test with your Android monitoring program. Please find the link in front of your name.
Amelia Chase http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(1).zip
Amrutha Chalasani http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(2).zip
Bhoomi Manharbhai Raval http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(3).zip
Chao Wang http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(4).zip
Chitra Yarlagadda http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(5).zip
Gajendira R. Sivajothi http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(6).zip
Jagannadh Vempati http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(7).zip
Patrick Cryer http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(8).zip
Ratna Eluri http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(9).zip
Ravi Teja Gannavarapu http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(10).zip
Savitha Chintakindi http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(11).zip
Snigdhitha Kasarla http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(12).zip
Sonal Tanpure http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(13).zip
Srikanth Datti http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(14).zip
Sultan Alotaibi http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(15).zip
Vishwajyoth Palle http://nsl.cse.unt.edu/~fazeen/AndroidApps/Apps%20(16).zip
DEMO
Please demo the following (by displaying on the monitor, string
in files, plots, etc) for the five applications.
Make sure you practice your demo before coming to the lab.
1. What server (name or IP address) is being accessed during
network access while running the application ?
2. How often is access the internet ?
3. Based on the resource monitoring, are you be able to determine
what kind of advertisements are activated in the run-time?
4. If so, how long the app runs the add?
5. Does the app store/access the data/info in the SD card?
6. If so, what kind of files it stores/access in the SD card.
7. How frequently does it access the storage?
8. What is the battery consumption when the app is running?
9. What is the CPU sage, while the app is running and how, and when it varies?
10. What is the RAM usage while the app is running?