一、packages.list
com.android.soundrecorder 10021 0 /data/data/com.android.soundrecorder
com.android.sdksetup 10020 0 /data/data/com.android.sdksetup
com.android.launcher 10005 0 /data/data/com.android.launcher
com.android.defcontainer 10009 0 /data/data/com.android.defcontainer
com.android.smoketest 10044 0 /data/data/com.android.smoketest
com.android.quicksearchbox 10001 0 /data/data/com.android.quicksearchbox
com.android.contacts 10004 0 /data/data/com.android.contacts
com.android.inputmethod.latin 10024 0 /data/data/com.android.inputmethod.latin
com.android.calculator2 10037 0 /data/data/com.android.calculator2
com.zsph.out_patient_appointment 10046 1 /data/data/com.zsph.out_patient_appointment
com.android.htmlviewer 10002 0 /data/data/com.android.htmlviewer
com.android.providers.calendar 10033 0 /data/data/com.android.providers.calendar
获取程序包名和uid-owner。
二、iptables
/data/x -t nat -m owner --uid-owner 10021 -A OUTPUT -o tiwlan+ -p tcp --dport 80 -j DNAT --to-destination 192.168.1.1:12870;
把特定app 10021 流向internet网络的数据包转发到redsocks特定端口上。
三、gdb
本部分参考链接http://blog.chinaunix.net/uid-12567959-id-3214283.html
0.把本地开发好需要调试的程序redsocks推送到远端设备上。
1.在设备上:
./gdbserver :1234 DIR/redsocks -p DIR/redsocks.pid -c DIR/redsocks.conf
在android设备端口1234上启动gdbserver,并附到需要调试的程序redsocks启动后生成的进程上。
2.主机上:
adb forward tcp:1234 tcp:1234;
本机端口tcp端口1234转发到远端设备的tcp 1234端口上。
arm-linux-androideabi-gdb ./obj/local/armeabi/redsocks
在本机启动需要调试程序redsocks。
gdb target remote :1234
通过target remote命令与运行在远端设备上的程序建立连接。
3.之后就可以利用gdb命令n,b,s,p等命令调试程序了。