gpt4 book ai didi

android - 在 Android 插桩测试中访问原始套接字

转载 作者:太空狗 更新时间:2023-10-29 13:08:06 26 4
gpt4 key购买 nike

我在这里浏览了许多关于通过 Android 上的 native 代码进行套接字访问的答案,以及其他关于“androidTest”插桩测试的套接字访问的答案,但没有一个能够完全解释我所看到的一些奇怪的行为。

Windows 10 上的 Android Studio 2.3.3、NDK 15.1.x、构建工具 25.0.3。使用 Cmake 构建。我正在将一些 native 代码移植到 Android,旨在作为一个库进行分发,该库封装在基于 Java JNI 的 API 中。这部分似乎工作正常;至少我可以调试并登录 native 代码,看看哪里出了问题。

我已经创建了一些插桩测试来运行 JNI,但看起来 native 端无法访问套接字,即使 Android Studio 为您的插桩测试包装的测试应用程序可以访问(即,它有应用了 INTERNET 权限,我可以看到它是测试应用程序推送 list 的一部分。我还一气之下应用了 ACCESS_NETWORK_STATE perm。)

也就是说,部分库知道如何设置和使用 TCP 套接字(数据报和流;在本例中为流)并解析失败的 DNS(这可能是我的端口中的一个错误,因为设备本身仍然似乎根据下面的 adb shell 输出解析 DNS)。如果我使用 IP 地址进行测试,它会重试直到失败。每次调用 socket() 都会返回 11 EAGAIN(“再试一次”)的 ERRNO。

如果我使用 adb shell 通过 USB 登录被测设备,我可以 ping 并使用 curl 等。但是,一旦我将 run-as 作为测试应用程序,我就会不再允许使用任何网络设备。

shell@venice:/data/data/org.clvrmnky.library.test $ ping www.example.com
PING www.example.com (93.184.216.34) 56(84) bytes of data.
ping: sendmsg: Operation not permitted
ping: sendmsg: Operation not permitted
ping: sendmsg: Operation not permitted
^C
--- www.example.com ping statistics ---
3 packets transmitted, 0 received, 100% packet loss, time 2004ms

1|shell@venice:/data/data/org.clvrmnky.library.test $ ping -I wlan0 www.example.com
ping: SO_BINDTODEVICE: Operation not permitted
2|shell@venice:/data/data/org.clvrmnky.library.test $ curl -4 --verbose www.example.com/
* Trying 93.184.216.34...
* connect to 93.184.216.34 port 80 failed: Connection timed out
* Failed to connect to www.example.com port 80: Connection timed out
* Closing connection 0
curl: (7) Failed to connect to www.example.com port 80: Connection timed out
7|shell@venice:/data/data/org.clvrmnky.library.test $

我不会在这里粘贴它,但是 wlan0(和其他)存在并且具有有效的、可访问的 IP 地址。这是“Link encap:UNSPEC”,我承认我没有完全理解。

我假设应用程序在连续的套接字调用中失败以及无法绑定(bind)到网络设备并在 adb shell 中使用它以某种方式相关,但如果有人有理由说明这可能不是这样,请告诉我。

我试过:

  • 在后台线程中调用测试方法,以防插桩测试在测试应用主线程中运行。
  • 在测试类的 @Before 子句中将 StrictMode 线程策略设置为 permitAll()
  • 使用和不使用测试 list 中设置的 INTERNET 权限运行。如果没有此权限,它会到达 native 代码,但在初始化过程中会更早地失败。我必须深入研究我的笔记才能获取更多相关细节。我假设我需要这个权限。 (旁注:如果我启用 INTERNET,则远程调试器无法再连接到设备,因此我只能通过日志进行调试。)

最佳答案

看起来仪器测试,至少在撰写本文时,不支持通过 NDK 访问原始套接字。自动创建的 .test 应用程序似乎在 list 中包含所需的一切(我直接从设备检查了 base.apk)。

一旦使用相同的 list 设置创建了一个 DemoApp,我就能够打开套接字、连接到它们、进行名称查找等。此外,我能够在运行时通过 adb shell 访问网络作为(“运行方式”)DemoApp。

仍然有一些奇怪的事情发生,因为我创建了一个单独的 JNI 应用程序来打开套接字,并针对它破解了一个仪器测试。至少作为 ext.other.app.test 运行的 adb shell 确实可以访问互联网。

关于android - 在 Android 插桩测试中访问原始套接字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44974357/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com