本篇文章讨论了一种设计P2P网络应用程序的简单方法

转载 2006年06月05日 16:37:00
本篇文章讨论了一种设计P2P网络应用程序的简单方法。

   尽管有许多P2P网络不需要索引服务器或中央服务器,各客户机之间可以互相直接通讯,但下面的图1还是显示了P2P网络的基本工作原理,一般来说,P2P概念中包含一台中央索引服务器,这台服务器并不存储有任何文件,它只存储有登录到该网络上的所有用户的信息、客户端的IP地址以及用户提供的供共享的文件,客户机和服务器使用简单的命令通过报路连接进行通讯。

   当客户端A想要查找P2P网络上其他客户端提供共享的文件时,系统会执行下面的操作:

    ·客户端A以自己的用户名登录到索引服务器上。

    ·客户端A向服务器注册自己想提供给其他用户共享的文件,以便其他用户能够查找到这些文件。

    ·客户端A向服务器发出申请,查找与一定的输入模式相匹配的文件。

    ·索引服务器在其数据库中搜索给定的文件名,并将搜索到的如下的结果返回给客户端A:

     ·提供该文件的客户端,例如客户端B。

     ·该用户的IP地址。

     ·它搜索到的文件名。



   一旦客户端A选择了下载选项,客户端A就使用搜索返回的IP地址与客户端B建立连接。

    ·一旦成功地建立起一个连接,就可以通知对方开始发送文件了。

    ·下载完成后,应当向索引服务器注册你得到的共享文件的拷贝。

   这样的P2P网络可以用来共享任何类型的文件,它既可以用在局域网上,也可以作在互联网上。


(图1)
   C#语言由于其对网络功能良好的支持,特别是内置地支持TCPListener和TCPClient这二个类,使得利用它开发P2P应用程序变得非常容易。下面就是一个使用C#开发的P2P应用的例子:

public MyTcpListener(int port) : base(port)
{

}
public void StopMe()
{
if ( this.Server != null )
{
this.Server.Close();
}
}
}

public class Transfer
{
MyTcpListener tcpl;

public Transfer()
{
OptionsLoader ol = new OptionsLoader();
int port = 8081;
if (ol.Port > 0)
{
port = ol.Port;
}
else
{
port = 8081;
}

this.tcpl = new MyTcpListener(port);
}

public void TransferShutdown()
{
tcpl.StopMe();
}

public void ListenForPeers()
{
try
{

Encoding ASCII = Encoding.ASCII;

tcpl.Start();

while (true)
{
// 在有连接之前,Accept将处于阻塞状态
Socket s = tcpl.AcceptSocket();
NetworkStream DataStream = new NetworkStream(s);

String filename;
Byte[] Buffer = new Byte[256];
DataStream.Read(Buffer, 0, 256);
filename = Encoding.ASCII.GetString(Buffer);
StringBuilder sbFileName = new StringBuilder(filename);
StringBuilder sbFileName2 = sbFileName.Replace("/", "//");
FileStream fs = new FileStream(sbFileName2.ToString(), FileMode.Open, FileAccess.Read);
BinaryReader reader = new BinaryReader(fs);
byte[] bytes = new byte[1024];
int read;
while((read = reader.Read(bytes, 0, bytes.Length)) != 0)
{
DataStream.Write(bytes, 0, read);
}
reader.Close();
DataStream.Flush();
DataStream.Close();
}
}
catch(SocketException ex)
{
MessageBox.Show(ex.ToString());
}
}

public void DownloadToClient(String server, string remotefilename, string localfilename)
{
try
{
TcpClient tcpc = new TcpClient();
Byte[] read = new Byte[1024];

OptionsLoader ol = new OptionsLoader();
int port = 0;
if (ol.Port > 0)
{
port = ol.Port;
}
else
{
// 缺省的端口号,可以设置为使用的端口号
port = 8081;
}


// 尝试与服务器连接
IPHostEntry IPHost = Dns.Resolve(server);
string []aliases = IPHost.Aliases;
IPAddress[] addr = IPHost.AddressList;

IPEndPoint ep = new IPEndPoint(addr[0], port);
tcpc.Connect(ep);

// 获得流对象
Stream s = tcpc.GetStream();
Byte[] b = Encoding.ASCII.GetBytes(remotefilename.ToCharArray());
s.Write( b, 0, b.Length );
int bytes;
FileStream fs = new FileStream(localfilename, FileMode.OpenOrCreate);
BinaryWriter w = new BinaryWriter(fs);

// 读取流对象,并将其转换为ASCII码
while( (bytes = s.Read(read, 0, read.Length)) != 0)
{
w.Write(read, 0, bytes);
read = new Byte[1024];
}

tcpc.Close();
w.Close();
fs.Close();
}
catch(Exception ex)
{
throw new Exception(ex.ToString());
}
}
}
}

简单编程(二十一)计数排序法

实现如下的排序算法:有一种简单的排序方法叫计数排序法,这种排序算法对一个待排序的数组进行排序,并将排序结果放到另一个新的数组中。计数排序算法针对待排序数组中的每个数据,扫描待排序的数组一趟,统计待排序...
  • zzc1510334836
  • zzc1510334836
  • 2014年12月16日 16:34
  • 939

在windows中,如何实现一个自己的浏览器

首先,标题是吹牛的,与360安全浏览器相比,我这根本就是不入流,好了,废话就不说了,现在就让我们来看看应该如何实现吧      1. 使用的IDE是VS2013.      2. 建立一个win32项...
  • u014660247
  • u014660247
  • 2016年04月15日 03:49
  • 388

字符串压缩的一些算法

应用中,经常需要将字符串压缩成一个整数,即字符串散列。比如下面这些问题:(摘自JULY的博客  http://blog.csdn.net/v_july_v/ ) (1)搜索引擎会通过日志文件把用户每...
  • coloriy
  • coloriy
  • 2015年08月11日 13:57
  • 468

数据库设计方法

数据库设计方法目前可分为四类:直观设计法、规范设计法、计算机辅助设计法和自动化设计法。 其中,新奥尔良法是目前公认的比较完整和权威的一种规范设计法。新奥尔良法将数据库设计分成需求分析(分析用户需求)、...
  • minwang593
  • minwang593
  • 2013年10月08日 08:51
  • 1095

zoho使用心得

zoho是一个不错的Paas平台,对比使用salesforce,我觉得zoho更加的人性化,使用起来更加简单方便。 一.Zoho介绍 Zoho成立于1996年,致力于在线办公的研究,是全球第一大在...
  • Annie_lin
  • Annie_lin
  • 2016年06月14日 10:45
  • 870

《人工智能:一种现代的方法》总结 第二章

第二章 智能Agent 这一章主要讨论了Agent的各个方面,给读者一个初步的了解。...
  • AchildFromBUAA
  • AchildFromBUAA
  • 2017年03月27日 22:56
  • 509

C#窗体程序--简单文本编辑器

建立一个窗体文件,实现对文件的编辑保存和对txt文件的打开 界面设计: 程序源代码://form1.cs using System; using System.Collections.Ge...
  • xu_jin_shan
  • xu_jin_shan
  • 2017年10月20日 16:40
  • 257

简单工厂,工厂方法,抽象工厂 三种设计模式的区别和实例

简单工厂: 一个产品抽象类,可以派生很多具体产品类。 一个具体工厂类,可以创建多种具体的产品实例。 工厂方法: 一个抽象产品类,可以派生很多具体产品类。 一个抽象工厂类,可以派生很多...
  • bububu2012
  • bububu2012
  • 2015年07月09日 20:23
  • 209

设计模式学习的几点建议

如如何才能更好地抓住设计思想和本质? 深入理解和多加实践。建议大家的一种模式学习流程如下:先通过一些生活实例引入某种设计模式,然后学习该模式的动机、定义和结构,再学习一两个使用该模式的典型实例,接下...
  • LZQ19931007
  • LZQ19931007
  • 2016年04月12日 14:42
  • 1151

计算器的简单工厂和工厂方法

设计模式这本书学了一多半了,心里也迷糊迷糊的,不过这在怎么迷糊也得总结啊,先从第一个简单工厂开始吧。简单工厂模式是进入设计模式世界的第一个模式,他也告诉了我们面向对象设计时的法则。首先简单工厂模式告诉...
  • wgp15732622312
  • wgp15732622312
  • 2015年11月22日 14:16
  • 639
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:本篇文章讨论了一种设计P2P网络应用程序的简单方法
举报原因:
原因补充:

(最多只允许输入30个字)