Моя цель — перечислить имена и ips всех устройств в локальной сети.
перечислить все имена компьютеров в локальной сети на iPhone похож на этот пост, но он не получил ответа.
Я посмотрел на яблоки Bonjour и не думаю, что это то, что мне нужно. Он не показывает все устройства в сети.
Я также попробовал код ниже, но я получаю странный вывод (ниже).
int sock;
struct ifconf ifconf;
struct ifreq ifreq[30];
int interfaces;
int i;
// Create a socket or return an error.
sock = socket(AF_INET, SOCK_STREAM, 0);
if (sock < 0)
diep("socket");
// Point ifconf's ifc_buf to our array of interface ifreqs.
ifconf.ifc_buf = (char *) ifreq;
// Set ifconf's ifc_len to the length of our array of interface ifreqs.
ifconf.ifc_len = sizeof ifreq;
// Populate ifconf.ifc_buf (ifreq) with a list of interface names and addresses.
if (ioctl(sock, SIOCGIFCONF, &ifconf) == -1)
diep("ioctl");
// Divide the length of the interface list by the size of each entry.
// This gives us the number of interfaces on the system.
interfaces = ifconf.ifc_len / sizeof(ifreq[0]);
// Print a heading that includes the total # of interfaces.
printf("IF(%d)\tIP\n", interfaces);
// Loop through the array of interfaces, printing each one's name and IP.
for (i = 0; i < interfaces; i++) {
char ip[INET_ADDRSTRLEN];
struct sockaddr_in *address = (struct sockaddr_in *) &ifreq[i].ifr_addr;
// Convert the binary IP address into a readable string.
if (!inet_ntop(AF_INET, &address->sin_addr, ip, sizeof(ip)))
diep("inet_ntop");
printf("FOUND: %s\t%s\n", ifreq[i].ifr_name, ip);
}
close(sock);
Это результат, который я не могу понять.
FOUND: lo0 24.3.0.0
FOUND: 28.30.0.0
FOUND: 0.0.0.0
FOUND: 0.0.0.0
FOUND: 0.0.0.1
FOUND: ip0 112.100.112.95
FOUND: pdp_ip1 255.7.0.0
FOUND: 20.18.4.0
FOUND: ip2 0.0.0.0
FOUND: ap1\256\372\272J\221\253 0.0.0.0
FOUND: 105.112.50.0
FOUND: 254.74.145.171
FOUND: ip2 0.0.0.0
FOUND: ip2 101.110.49.142
FOUND: awdl0 6.5.6.0
FOUND: \273Y\311 28.30.0.0
Я хотел бы видеть вывод что-то вроде этого:
My-Mac 192.168.0.21
My-iPad 192.168.0.22
Mum's iPhone 192.168.0.23
Решение в Objective-C или C ++ было бы полезно. Благодарю.
Просто выкопайте этот проект еще раз … и это моя попытка поделиться кодом, как этого требует @PRSingh … надеюсь, это поможет.
Определено в моем .h
NSNetServiceBrowser *serviceBrowser;
NSNetService *service;
NSMutableArray* snames;
NSMutableArray* sips;
UIActivityIndicatorView* spinner;
По моему .m
#pragma mark - NSNetServiceDelegate Methods
- (void)netServiceWillResolve:(NSNetService *)sender {
NSLog(@"netServiceWillResolve");
serviceBrowser = [[NSNetServiceBrowser alloc] init];
if(!serviceBrowser) {
NSLog(@"The NSNetServiceBrowser couldn't be allocated and initialized.");
}
serviceBrowser.delegate = self;
[serviceBrowser searchForServicesOfType:@"_type._tcp." inDomain:@"local."];
}
- (void)netServiceWillPublish:(NSNetService *)netService
{
NSLog(@"netServiceWillPublish");
}
- (void)netServiceDidPublish:(NSNetService *)sender {
NSLog(@"netServiceDidPublish");
}
- (void)netService:(NSNetService *)sender didNotPublish:(NSDictionary *)errorDict {
NSLog(@"didNotPublish");
}
- (void)netServiceDidResolveAddress:(NSNetService *)netService {
NSLog(@"netServiceDidResolveAddress");
for (NSData* data in [netService addresses]) {
char addressBuffer[100];
struct sockaddr_in* socketAddress = (struct sockaddr_in*) [data bytes];
int sockFamily = socketAddress->sin_family;
if (sockFamily == AF_INET /*|| sockFamily == AF_INET6*/) {
const char* addressStr = inet_ntop(sockFamily,
&(socketAddress->sin_addr), addressBuffer,
sizeof(addressBuffer));
// int port = ntohs(socketAddress->sin_port);
if (addressStr){
if(![sips containsObject:[NSString stringWithFormat:@"%s",addressStr]]){
[snames addObject:netService.name];
[sips addObject:[NSString stringWithFormat:@"%s",addressStr]];
[self.tableView reloadSections:[NSIndexSet indexSetWithIndex:0] withRowAnimation:UITableViewRowAnimationFade];
}
}
}
}
}
- (void)netService:(NSNetService *)sender didNotResolve:(NSDictionary *)errorDict {
NSLog(@"didNotResolve: %@",errorDict);
}
- (void)netService:(NSNetService *)sender didUpdateTXTRecordData:(NSData *)data {
NSLog(@"didUpdateTXTRecordData");
}
- (void)netServiceDidStop:(NSNetService *)netService {
NSLog(@"netServiceDidStop");
}
#pragma mark - NSNetServiceBrowserDelegate Methods
- (void)netServiceBrowser:(NSNetServiceBrowser *)netServiceBrowser didFindService:(NSNetService *)netService moreComing:(BOOL)moreServicesComing {
NSLog(@"didFindService: %@ lenght:%d",netService.name,[netService.name length]);
[services addObject:netService];
}- (void)netServiceBrowser:(NSNetServiceBrowser *)netServiceBrowser didRemoveService:(NSNetService *)netService moreComing:(BOOL)moreServicesComing {
[services removeObject:netService];
[netService stop];
int index = [snames indexOfObject:netService.name];
[snames removeObjectAtIndex:index];
[sips removeObjectAtIndex:index];
[self.tableView reloadSections:[NSIndexSet indexSetWithIndex:0] withRowAnimation:UITableViewRowAnimationFade];
NSLog(@"didRemoveService");
}
Чтобы это работало, я считаю, что все устройства в сети должны быть запущены с «типом» _type_.tcp (или каким-либо другим именем, которое вы ему дадите). Вы можете поиграть с типом, просто чтобы посмотреть, какие устройства в вашей локальной сети уже используют определенные типы услуг (https://developer.apple.com/library/mac/qa/qa1312/_index.html).
Других решений пока нет …