本地网络P2P文件传输

时间:2014-11-09 18:31:02

标签: javascript node.js sockets networking peerjs

我的一项大学任务是开发一个P2P文件共享Web应用程序,以便在同一本地网络上的机器之间传输文件。我不是在寻找关于如何做到这一点的讲义,一旦我得到高级设计,我就能弄明白,我只需要知道这是否理智。

我打算使用PeerJS库。据我所知,每个客户端都获得一个唯一的ID,这些ID用于将客户端相互连接。所以我需要在同一个本地网络上的所有客户端之间协调ID。

我计划这样做的方法是让NodeJS服务器运行Socket.IO。当客户端加载Web应用程序时,它们会向节点服务器发送websocket请求。然后,节点服务器记录客户端的外部IP地址。当另一个客户端连接并使用与另一个客户端相同的外部IP地址发出请求时,这两个客户端将获得彼此的ID,以便它们可以相互连接。

这有一些潜在的问题:

  • 我假设具有相同外部IP地址的人在同一本地网络上。在任何情况下都会出错吗?
  • 我不知道客户端之间的文件传输将如何发生。理想情况下,它应该与本地网络隔离。例如,如果我在两台计算机之间传输文件,它将会显示:computer 1 -> router/switch -> computer 2,而不是computer 1 -> router/switch -> local exchange -> ISP switch -> local exchange -> router/switch -> computer 2。基本上,转移不应该让本地网络进入互联网。

思想?

0 个答案:

没有答案