快速构建一个用本地网络发送和接收消息的APP

本文将创建一个使用HTTP服务器在本地网络发送和接收消息的简单通信APP。

创新互联建站成立与2013年,先为古蔺等服务建站,古蔺等地企业,进行企业商务咨询服务。为古蔺企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

​​

该应用程序需要有一个简单的HTTP服务器发送消息:

  1. 获取我的本地IP地址
  2. 尝试发送消息到每个本地IP,如:
GET xxx.xxx.xxx.1/?msg=message
GET xxx.xxx.xxx.2/?msg= message
...
GET xxx.xxx.xxx.254/?msg= message

本地IP地址

我们需要获取本地IP地址来发送消息并创建HttpServer实例。下面是一个简单的方法:

// Hard coded, needs improvement
Future myLocalIp() async {
final interfaces =
await NetworkInterface.list(type: InternetAddressType.IPv4, includeLinkLocal: true);
return interfaces
.where((e) => e.addresses.first.address.indexOf('192.') == 0)
?.first
?.addresses
?.first
?.address;
}

它返回一个类似这样的IP地址:192.168.0.107

我们将使用前三个字节向每个本地IP发送一个请求:192.168.0.xxx

HttpServer

为了能够接收请求,我们需要使用我们的本地IP和从1024到65353的任何端口创建一个HttpServer实例。

Future startServe() async {
final ip = await myLocalIp();
var server = await HttpServer.bind(ip, 8080);
await for (HttpRequest request in server) {
_handleRequest(request);
request.response.write('Ok');
await request.response.close();
}
}

当我们收到一个请求时,我们返回' Ok '。要检查它是否有效,可以使用这个链接:http://{your local IP}:8080

你应该会看到Ok消息。

在iOS或Android上检查之前,需要添加权限。

添加到iOS *info.plist*文件:

NSAppTransportSecurity
NSAllowsArbitraryLoads

添加到*AndroidManifest.xml*文件:

处理请求

为了简单起见,我们将使用GET方法并使用查询参数来发送这样的消息:

http://{local IP}:8080?msg=message&ipip=ip

如果请求有msg和ip这样的参数,我们将这些值添加到我们的消息列表中,并调用setState或notify在屏幕上显示该列表:

void _handleRequest(HttpRequest request) {
final msg = request.uri.queryParameters['msg'];
final from = request.uri.queryParameters['ip'];
if (msg != null) {
messages.insert(0, [from, msg]);
// set state or update
}
}

发送消息

我们必须把信息发送到每一个本地IP。我们可以使用本地IP地址来获得前三个字节,并由此建立本地IP地址列表:

void sendMessage(String msg) async {
final ip = await myLocalIp();
final threeOctet = ip.substring(0, ip.lastIndexOf('.'));
for (var i = 1; i < 200; i++) {
_sendRequest('$threeOctet.$i', "?ip=$ip&msg=$msg");
}
}

void _sendRequest(String to, String path) async {
final client = HttpClient();
client.connectionTimeout = const Duration(seconds: 2);
try {
final resp = await client.get(to, 8080, path);
resp.close();
} catch (e) {}
}

在本例中,它只将消息发送到从x.x.x.1到x.x.x.199的IP地址上,但理论上,我们可以从1发送到255。

现在,我们可以向活跃的本地设备发送信息。左下方的图片是一个物理的iOS设备,右边的是一个macOS桌面应用程序。虽它们有不同的本地IP地址,但你可以看到他们可以互相发送消息。

​​ 

【译稿,合作站点转载请注明原文译者和出处为.com】

网站栏目:快速构建一个用本地网络发送和接收消息的APP
文章网址:http://www.mswzjz.cn/qtweb/news26/537076.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能