How to open “adb shell” in context of application being debugged (on non-rooted device)?

后端 未结 3 870
北海茫月
北海茫月 2021-01-03 15:36

When I just run adb shell, I get shell running from uid=2000(shell) gid=2000(shell), without ptrace access to my application.

How to open a

相关标签:
3条回答
  • 2021-01-03 16:07

    From this answer:

    • The packages.xml file present in /data/system
    • The packages.list file present in /data/system

    Contain the list of applications installed and their corresponding UID's.

    Another answer in the same question suggests:

    adb shell dumpsys package com.example.myapp | grep userId=
    

    You can then open your shell as normal and run:

    $ su <UID>
    

    You should then have the same access and privileges as the app that uses that UID.

    0 讨论(0)
  • 2021-01-03 16:10

    Workaround way using socat:

    1. Add android.permission.INTERNET to your application;
    2. Put socat binary (mirror) to /data/local/tmp/. Ensure everybody can start it;
    3. Add Runtime.getRuntime().exec("/data/local/tmp/socat tcp-l:4446,fork,reuseaddr exec:/system/bin/sh,pty,stderr,setsid"); at startup of your Java-based application;
    4. adb forward tcp:4446 tcp:4446
    5. Use socat `tty`,raw,echo=0,opost=1 tcp:127.0.0.1:4446 on host to connect to the shell in your application context.

    Note that this setup is not secure and should not be left in production app.

    0 讨论(0)
  • 2021-01-03 16:12

    Use run-as <your package name> to switch to your app's UID or run-as <your package name> <command> to run a single command with your app's UID.

    0 讨论(0)
提交回复
热议问题