DSP应用实例(一)--轻松实现BT多点下载

发表于:2007-07-01来源:作者:点击数: 标签:
DSP应用实例(一)--轻松实现BT多点下载 BitTorrent----简称"BT"下载,是现在最流行的下载方式,它的主要特点就是多IP下载,一个文件可以从多个IP被同时下载,使下载速度达到极限。 在这个数据包里提供了一个标准的DSPSpider类,使用该类可以轻松实现BitTorren

                      DSP应用实例(一)--轻松实现BT多点下载
                     
       BitTorrent----简称"BT"下载,是现在最流行的下载方式,它的主要特点就是多IP下载,一个文件可以从多个IP被同时下载,使下载速度达到极限。
      在这个数据包里提供了一个标准的DSPSpider类,使用该类可以轻松实现BitTorrent多点下载。在采用BitTorrent和FlashGet下载时,需要预先对磁盘进行扫描生成整个文件的索引后,才会正式开始下载文件,当文件很大时,文件的创建时间会较长,使系统像死机了一样,实际是在创建文件。DSPSpider采用了更先进的方式,在下载文件前无需对磁盘进行扫描,文件采用动态创建,随着下载的完成度而逐步增加,并且下载过程中不需要额外创建任何附加的文件。这次发布的为debug版,正式版中将包含有更多、更完善的功能。
    
    只需在窗体中响应以下7个消息,就可以轻松实现BT多点下载。
    1   MSG_RECVSECT            接收方消息
        接收到了一部分数据,每接收到一部分数据时,就会向指定窗体发送该消息。
        必需调用DSPSpider.OnUpdateSect(wParam,lParam),该函数将返回当前已经下载的字节个数。
        wParam  --  指向DSPSpider::_FILEDETAIL结构的指针
        lParam    --  当前接收到的字节数
       
    2   MSG_SENDCOMPLETE        接收方消息
        接收过程中止,原因可能是文件已全部下载或下载被中止。
        必需调用DSPSpider.OnSendComplete(wParam,lParam),该函数将返回一个数字,如果返回1,则表示文件已经全部下载完成;如果返回2,则表示文件还没有下载完,但是所有线程已经终止,原因可能是传送方终止或接收方终止或下载过程中出现了错误。关于线程中止的具体原因,可以通过调用DSPSpider::GetCompleteInfo(lParam,str)函数得到错误的具体原因。
        wParam  --  指向DSPSpider::_FILEDETAIL结构的指针
        lParam    --  错误的原因
       
    3   MSG_SETFILENAMESIZE     接收方消息
        传送当前接收的文件的大小,文件名,可以在这里设定显示,该消息只在开始时发送一次
        wParam  --  指向DSPSpider::_FILEDETAIL结构的指针
        DSPSpider.GetProgressStep()得到步长
        DSPSpider.GetCurrSize()得到文件的当前的长度
       
    4   MSG_SHOWPROMPT          接收方消息
        显示提示信息,在文件的接收过程中,会不断地发送该消息,传递当前接收过程的状态
        wParam  --  低16位,消息的ID。高16位的低8位,当前的下载线程个数;高16位的高8位,当前的下载线程中休眠线程的个数。
        lParam    --  如果不为0,则表示连接方的IP地址的字符串表示
       
    5   MSG_ASSIGNNEWSECT       接收方消息      这是一个必需响应的消息
        在该消息中直接调用DSPSpider.OnAssignNewSect(wParam,lParam)函数。
       
    6   MSG_CREATERECVTHREAD    接收方消息      这是一个必需响应的消息
        在该消息中直接调用DSPSpider.OnCreateRecvThread(wParam,lParam)函数。
       
    7   MSG_GETFILENAME         传送方消息      这是一个必需响应的消息
        当接收到一个传送请求时,根据接收方传递的文件名,决定需要传送的文件名。
        wParam  --  指向DSPSpider::_FILEDETAIL结构的指针
        在响应该消息时,调用DSPSpider::SetFilename(wParam,strPathname),该函数将设置传送文件的名字,包含路径名。   
       
       
                            DSPSpider中的结构说明
                           
    _SENDTHREADPARAM结构,建立监听线程时所需要传递的结构。
        pCWnd       --  接收消息的窗体,如果是传递给监听线程的参数,则该窗体必需响应MSG_GETFILENAME消息。
        bInternet     --  是否是Internet应用,true表示Internet应用;false表示局域网应用


    _FILEDETAIL结构,在响应DSPSpider的消息中会传递的结构
        strPathname  --  包含路径的文件名,这个变量是只读的,不能改变
        strFilename   --  不包含路径的文件名,这个变量是只读的,不能改变
        dwFilesize    --  当前文件的字节个数
        nFileID        --  文件的ID,用来标识唯一的文件,只作为参考值,如不想设定ID,可设置为0
        bRun           --  是否继续接收或传送,该值为true时,表示继续;为false时,表示中止当前过程
        hwnd          --  接收消息的窗体的句柄
       
       
       
                            DSPSpider中的属性和函数说明
       
    类型:属性
    定义:DWORD m_dwErrorCode
    描述:错误代码,在出现错误时,该变量保存了错误代码,说明错误的原因
   
    类型:属性
    定义:bool m_bExistQuery
    描述:文件存在时是否询问重写,如果值为false,则表示文件名存在时,不再下载该文件,而是结束。
   
    类型:属性
    定义:bool m_bCrc
    描述:是否要进行校验。为true时,表示要进行CRC校验;false时,则不进行CRC校验
   
    类型:属性
    定义:bool m_bInternet
    描述:是否是Internet应用。为true时,表示数据要转换为网络序处理;为false时,表示数据为字节序处理
   
    类型:静态方法
    定义:static void SetFilename(WPARAM wParam,CString& strPathname)
    描述:在响应MSG_GETFILENAME消息时,调用该方法,设置要传送的文件的包含路径的文件名。
   
    类型:静态方法
    定义:static bool GetCompleteInfo(int which,CString& str)
    描述:在响应MSG_SENDCOMPLETE消息中,可以调用该方法,得到过程中止的原因的文字描述。
    参数:which --  MSG_SENDCOMPLETE消息中的lParam参数
              str       --  保存文字描述的字符串
    返回:true     --  文件已经全部下载完成
              false     --  文件还未下载完成,下载过程被中止
         
    类型:静态方法
    定义:static UINT ListenThread(LPVOID lpData)
    描述:监听线程
    参数:lpData    --  指向DSPSpider::_SENDTHREADPARAM结构的指针
                结构中的pCWnd参数,保存了响应MSG_GETFILENAME消息的窗体的指针
                结构中的bInternet参数,表示监听端口号是网络序还是字节序
                结构中的pFunc参数,表示处理监听响应的函数的指针
               
    类型:消息处理函数
    定义:LRESULT OnSendComplete(WPARAM wParam, LPARAM lParam)
    描述:在响应MSG_SENDCOMPLETE的消息中,必需调用该方法。
   
    类型:消息处理函数
    定义:LRESULT OnUpdateSect(WPARAM wParam, LPARAM lParam)
    描述:在响应MSG_RECVSECT的消息中,必需调用该方法。
   
    类型:消息处理函数
    定义:LRESULT OnAssignNewSect(WPARAM wParam, LPARAM lParam)
    描述:在响应MSG_ASSIGNNEWSECT的消息中,必需调用该方法。
   
    类型:消息处理函数
    定义:LRESULT OnAbort(WPARAM wParam, LPARAM lParam)
    描述:当接收方想在接收过程中中止整个接收过程时,调用该方法。
    参数:wParam    --  值为0
              lParam       --  值为0
    返回:0         --  表示接收过程正准备中止,但接收线程还未全部中止
              1         --  表示接收过程已经全部中止
         
    类型:消息处理函数
    定义:LRESULT OnCreateRecvThread(WPARAM wParam, LPARAM lParam)
    描述:在响应MSG_CREATERECVTHREAD的消息中,必需调用该方法
   
    类型:方法
    定义:void  SafeRelease()
    描述:安全释放资源,该方法在DSPSpider对象注销前应保证被调用一次
   
    类型:方法
    定义:BOOL  AddIP(const char *lpSrvIP,WORD wPort,WORD nPriority=0)
    描述:增加一个可以用来下载的IP
    参数:lpSrvIP   --  可以下载文件的IP或域名
              wPort     --  IP的监听端口号
              nPriority  --  加权值,加权值越小,将优先下载。
    返回:true        --  正确添加。IP可以被重复增加,重复增加同一个IP,表示同时从该IP创建多个线程下载
              false       --  该IP错误,无法得到正确的IP地址
    特点:所有的IP按优先权排序,采用二分法插入。一个IP只能创建一个线程。
   
    类型:方法
    定义:void  RemoveIP(const char *lpSrvIP)
    描述:取消一个用来下载的IP
    参数:lpSrvIP   --  可以下载文件的IP或域名
   
    类型:方法
    定义:BOOL  RunSpider(const char* lpFilename,const char* lpPathname,HWND hWnd,BYTE byThreadCount,int nFileID=0);
    描述:准备采用多线程接收一个文件
    参数:lpFilename        --  要下载的文件名,不包含路径名
              lpPathname       --  要下载的文件名,包含路径名
              hWnd               --  响应接收方消息的窗体的句柄
              byThreadCount --  需要同时下载的线程的个数
              nFileID             --  文件的ID
         
    类型:方法
    定义:DWORD GetProgressStep()
    描述:得到步进的步长
   
    类型:方法
    定义:DWORD GetCurrSize()
    描述:得到当前已经下载的长度

 

    源程序下载:


原文转自:http://www.ltesting.net