我正在使用*jailbroken设备,我想编写一个应用程序来列出打开的端口(例如 TCP 端口)。
我有两个想法:
- 使用一些本机 API 获取打开的端口列表
- 执行 shell 命令以获取打开的端口列表并解析此 shell 命令的结果。
我应该使用哪个 API 或 shell 命令以及如何以编程方式触发它?
我这样做的方法是让您的应用程序以lsof
编程方式调用 UNIX 命令。 lsof
列出打开的“文件”,在 BSD 系统上包括套接字,其中包括 TCP 套接字。
过去,Saurik 发布了一个lsof
在 Cydia 上可用的版本。不幸的是,我最近无法让它工作。您可以自己尝试一下,因为 Saurik 的软件通常应该是值得信赖的。您也可以尝试lsof
自己编译源代码,因为它可以在线获得。
但是,我在这里找到了一个关于此的讨论线程。用户 Firewire888 能够获得lsof
在 iOS 上运行的自制版本。如果您信任他们的工作,那么您可以在此处下载二进制文件。根据他们的指示:
- 在 mac osx 上下载 macosx 的 ldid。https://networkpx.googlecode.com/files/ldid
- 在 mac osx上,在此线程中下载扫描仪版本的 lsof。再次感谢!
- 在 mac osx 上运行
ldid -S lsof
- scp 或其他任何方式
lsof
在/usr/sbin/lsof
iPhone 上访问(必须在 /usr/sbin 中,否则会出错无法分叉)
因此,您需要伪造该版本的代码lsof
,然后将其安装在您的 iPhone 上/usr/sbin/lsof
。
然后,您可以使用 Private API NSTask
(在 OS X 上为公共)从您的应用程序中运行 shell 命令,并捕获输出。
例如,使用命令:
lsof -i4tcp
将列出所有 IPv4 TCP 端口。
在您的 Objective-C 代码中,您可以这样做:
#include "NSTask.h"
- (void) listTcpPorts {
NSTask *task = [[NSTask alloc] init];
[task setLaunchPath: @"/usr/sbin/lsof"];
[task setArguments: [[NSArray alloc] initWithObjects: @"-i4tcp", nil]];
NSPipe *pipe= [NSPipe pipe];
[task setStandardOutput: pipe];
NSFileHandle *file = [pipe fileHandleForReading];
[task launch];
NSData *data = [file readDataToEndOfFile];
NSString *output = [[NSString alloc] initWithData: data encoding: NSUTF8StringEncoding];
NSLog(@"tcp ports: \n %@", output);
}
这需要下载NSTask
标题,您可以在此处找到。
这给了我标准输出:
Sep 11 18:53:47 iPhone5 HelloJB[34535] <Warning>: tcp ports:
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
apsd 143 mobile 9u IPv4 0x12345678 0t0 TCP 10.244.7.127:51216->17.172.238.202:5223 (ESTABLISHED)
apsd 143 mobile 10u IPv4 0x12345678 0t0 TCP 10.244.7.127:51215->17.149.37.18:5223 (ESTABLISHED)
apsd 143 mobile 12u IPv4 0x12345678 0t0 TCP 10.244.7.127:51215->17.149.37.18:5223 (ESTABLISHED)
apsd 143 mobile 14u IPv4 0x12345678 0t0 TCP 10.244.7.127:51216->17.172.238.202:5223 (ESTABLISHED)
dataacces 166 mobile 25u IPv4 0x12345678 0t0 TCP 10.244.7.127:51276->pc-in-f193.1e100.net:https (ESTABLISHED)
dataacces 166 mobile 27u IPv4 0x12345678 0t0 TCP 10.244.7.127:51276->pc-in-f193.1e100.net:https (ESTABLISHED)
afcd 26764 mobile 9u IPv4 0x12345678 0t0 TCP localhost:51284->localhost:51285 (ESTABLISHED)
MobileSaf 33165 mobile 11u IPv4 0x12345678 0t0 TCP 192.168.4.119:51349->stackoverflow.com:http (ESTABLISHED)
MobileSaf 33165 mobile 12u IPv4 0x12345678 0t0 TCP 192.168.4.119:51349->stackoverflow.com:http (ESTABLISHED)
Weather 33191 mobile 5u IPv4 0x12345678 0t0 TCP 192.168.4.119:50181->yts2.yql.vip.gq1.yahoo.com:http (LAST_ACK)
Weather 33191 mobile 7u IPv4 0x12345678 0t0 TCP 192.168.4.119:50182->yts2.yql.vip.gq1.yahoo.com:http (LAST_ACK)
Weather 33191 mobile 8u IPv4 0x12345678 0t0 TCP 192.168.4.119:50181->yts2.yql.vip.gq1.yahoo.com:http (LAST_ACK)
Weather 33191 mobile 10u IPv4 0x12345678 0t0 TCP 192.168.4.119:50182->yts2.yql.vip.gq1.yahoo.com:http (LAST_ACK)
notificat 33929 mobile 4u IPv4 0x12345678 0t0 TCP localhost:51295->localhost:51296 (ESTABLISHED)
notificat 33929 mobile 5u IPv4 0x12345678 0t0 TCP localhost:51301->localhost:51302 (ESTABLISHED)
notificat 33929 mobile 6u IPv4 0x12345678 0t0 TCP localhost:51318->localhost:51319 (ESTABLISHED)
notificat 33929 mobile 7u IPv4 0x12345678 0t0 TCP localhost:51330->localhost:51331 (ESTABLISHED)
syslog_re 34468 mobile 3u IPv4 0x12345678 0t0 TCP localhost:51321->localhost:51322 (ESTABLISHED)
您可以选择使用不同的命令行选项和/或解析输出以满足您的需要。祝你好运!