基于UDT connect连接通信以及文件传输--服务端
网上与UDT相关的资料不多,与UDT相关的源码例子更少。最近在接触UDT,也是因为缺少相关的资料,导致学习起来甚感痛苦。下面将我自己这两天弄出来的代码贴出来,希望对在寻找相关资料的童鞋有一定的帮助。与服务端相对应的客户端在另一篇博文中
SERVER端
- #include <iostream>
- #include "udt.h"
- #include <io.h>
- #pragma comment(lib,"ws2_32.lib")
- using namespace std;
- #define MAXLEN 4096
- int main(int argc,char *argv[])
- {
- if ((argc != 4))
- {
- cout<<"Use: appserver.exe server_port client_ip client_port"<<endl;
- return 0;
- }
- //startup
- //这里是对UDT的启动记性初始化操作
- if (UDT::ERROR == UDT::startup())
- {
- cout<<"startup: "<<UDT::getlasterror().getErrorMessage()<<endl;
- }else{
- cout<<"startup suc..."<<endl;
- }
- //socket
- //像声明一个普通的socket一样声明一个UDTSOCKET
- UDTSOCKET serv = UDT::socket(AF_INET, SOCK_DGRAM, 0);
- if (UDT::ERROR == serv)
- {
- cout<<"socket: "<<UDT::getlasterror().getErrorMessage()<<endl;
- }else{
- cout<<"client suc..."<<endl;
- }
- //声明udp socket,这里是udp的哈,不是udt
- int sersocket = socket(AF_INET,SOCK_DGRAM,0);
- if (SOCKET_ERROR == sersocket)
- {
- cout<<"udp socket error!"<<endl;
- }else{
- cout<<"clientsocket suc..."<<endl;
- }
- //为了能够在局域网中直接进行处理,先默认设置两个
- sockaddr_in my_addr,client_addr;
- my_addr.sin_family = AF_INET;
- my_addr.sin_port = htons(atoi(argv[1]));
- my_addr.sin_addr.s_addr = INADDR_ANY;
- memset(&(my_addr.sin_zero), '\0', 8);
- bind(sersocket,(struct sockaddr*)&my_addr,sizeof(my_addr));
- client_addr.sin_family = AF_INET;
- client_addr.sin_port = htons(atoi(argv[3]));
- client_addr.sin_addr.s_addr = inet_addr(argv[2]);
- //client_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
- memset(&(client_addr.sin_zero), '\0', 8);
- int mss = 1052;//最大传输单位
- //设置收发缓冲区大小 接收限时 和地址重用
- if( !( UDT::ERROR != (UDT::setsockopt(serv, 0, UDT_SNDBUF, new int(32000), sizeof(int)))
- && UDT::ERROR != (UDT::setsockopt(serv, 0, UDP_RCVBUF, new int(32000), sizeof(int)))
- && UDT::ERROR != (UDT::setsockopt(serv,0,UDT_REUSEADDR,new int(1),sizeof(int)))
- && UDT::ERROR != (UDT::setsockopt(serv, 0, UDT_RENDEZVOUS, new bool(true), sizeof(bool))))
- && UDT::ERROR != (UDT::setsockopt(serv, 0, UDT_MSS, &mss, sizeof(int)) ))
- {
- cout<<"udt socket: "<<UDT::getlasterror().getErrorMessage()<<endl;
- UDT::close(serv);
- return 0;
- }
- //这里是直接将udp的接口绑定在udt的接口之上,如果不这样做的话是没法使用UDT中的SOCK_DGRAM的
- if (UDT::ERROR == UDT::bind2(serv,sersocket))
- {
- cout<<"udt bind2:"<<UDT::getlasterror().getErrorMessage()<<endl;
- return 0;
- }else{
- cout<<"bind2 suc"<<endl;
- }
- //这里也是关键部分,与client端对应的connect操作,就是相互之间的打洞处理
- if (UDT::ERROR == UDT::connect(serv, (sockaddr*)&client_addr, sizeof(client_addr)))
- {
- cout << "connect: " << UDT::getlasterror().getErrorMessage();
- UDT::close(serv);
- return 0;
- }else{
- cout<<"connetc suc"<<endl;
- }
- //这里已经可以正常接收了,接收从client发过来的filename,目的是用于本地的文件创建
- char filename[100];
- if (UDT::ERROR == UDT::recvmsg(serv, filename, 100))
- {
- cout << "recv:" << UDT::getlasterror().getErrorMessage() << endl;
- return 0;
- }
- cout <<"filename: "<< filename <<endl;
- //使用FILE进行文件操作,关于文件的相关操作这里不详述了,实在不懂的可以留言
- FILE *fp;
- char localfile[100];
- memset(localfile,0,sizeof(localfile));
- strcpy(localfile,"d:\\");
- strcat(localfile,filename);
- if((fp = fopen(localfile,"w+"))==NULL)
- {
- cout<<filename<<" open failure!"<<endl;
- return 0;
- }
- fclose(fp);
- fp = fopen(localfile,"wb");
- char data[MAXLEN];
- int len=0,package=0,filelen=0;
- UDT::TRACEINFO trace;
- UDT::perfmon(serv,&trace);
- while(1)
- {
- //前面部分打开文件后,这里就是循环接收文件并保存
- memset(data,0,sizeof(data));
- len = UDT::recvmsg(serv, data, MAXLEN);
- filelen += len;
- //cout<<"filelen = "<<filelen<<endl;
- if (strncmp("quit",data,4)==0)
- {
- cout<<data<<endl;
- fclose(fp);
- break;
- }else
- {
- package ++;//record recv all the packages
- }
- fwrite(data,len,1,fp);
- }
- fclose(fp);
- fp = fopen(localfile,"rb");
- fseek(fp,0,SEEK_END);//move to the end
- filelen = ftell(fp)
- fseek(fp,0,SEEK_SET);
- cout<<"filesize = "<<filelen<<endl;
- UDT::perfmon(serv,&trace);
- cout << "speed = " << trace.mbpsRecvRate << "Mbits/sec" << endl;
- cout<<"recv all the packages: "<<package<<endl;
- fclose(fp);
- UDT::close(serv);
- UDT::cleanup();
- return 1;
- }
运行效果截图:
基于UDT connect连接通信以及文件传输--服务端的更多相关文章
- 基于UDT connect连接通信以及文件传输--客户端
上面一篇文章中提出了服务端的,其实这里没有严格意义的服务端和客户端之分,因为我在代码中是基于UDP的,不存在服务端与客户端,两个都是对等的,只是我这里进行一下简单的区分而已.在这里,客户端所进行的主要 ...
- secureCRT连接服务器和文件传输( 一步搞定)
1.在百度云盘存有此工具,获取到后解压执行即可,如下2 连接目标服务器 192.xxx.xx.xx 2.secureCRT连接服务器和文件传输 ,现象如下 登录后切换到root用户即可有权限操作 ...
- WCF大文件传输服务
由于项目需要,自己写一个基于WCF的大文件传输服务雏形.觉得有一定的参考价值,因此放在网上分享. 目前版本为v1.1特点如下: 1.文件传输端口为18650 2.上传和下载文件 3.支持获取文件传输状 ...
- FTP文件传输服务
FTP文件传输服务 一 .FTP 连接及传输的模式 l 控制连接:TCP21,用于发送FTP命令信息. l 数据连接:TCP 20, 用于上传下载数据. · 数据连接建立的类型: ·主动模式: 服 ...
- Python自带HTTP文件传输服务
一行命令搭建一个基于python的http文件传输服务 由于今天朋友想要一个文件,而我恰好有,因为这个文件比较大,网速不是很给力,所以想到了python自己有这么一个功能,这样不仅不需要下载其他软件, ...
- 网站优化与Cdn文件传输服务
网站优化与Cdn文件传输服务 如今互联网无处不在,其方便快捷.性质和低成本的经济特点,已经逐渐成为商务贸易.信息分发和数据交付的一个重要渠道.要想让数据的分发带来巨大的效益,那么网民的满意是唯一的办法 ...
- FTP 文件传输服务
昨晚心血来潮,尝试用python写了一个ftp文件传输服务,可以接收指令,从远程ftp服务器同步指定目录数据,最后没用上,开源出来. https://github.com/jadepeng/ftp_t ...
- httpurlconnection发送文件到服务端并接收
httpurlconnection发送文件到服务端并接收 客户端 import java.io.DataInputStream; import java.io.File; import java.io ...
- 部署基于.netcore5.0的ABP框架后台Api服务端,以及使用Nginx部署Vue+Element前端应用
前面介绍了很多关于ABP框架的后台Web API 服务端,以及基于Vue+Element前端应用,本篇针对两者的联合部署,以及对部署中遇到的问题进行处理.ABP框架的后端是基于.net core5.0 ...
随机推荐
- 30-RoutingMiddleware介绍以及MVC引入
1-构建路由 public class Startup { // This method gets called by the runtime. Use this method to add serv ...
- Spring---加载配置文件的几种方法(org.springframework.beans.factory.BeanDefinitionStoreException)
Spring中的几种容器都支持使用xml装配bean,包括:XmlBeanFactory ,ClassPathXmlApplicationContext ,FileSystemXmlApplicati ...
- 03019_过滤器Filter
1.Filter的简介 (1)Filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标资源访问前后进行逻辑处理: (2)快速入门步骤 ①编写一个过滤器的类实现Filter接 ...
- 树&二叉树&哈夫曼树
1.树 需要注意的两点:n(n>=0)表示结点的个数,m表示子树的个数 (1)n>0时,树的根节点是唯一的. (2)m>0时,子树的个数没有限制. 结点的度和树的度 (1)结点的度是 ...
- jquery跨域解决方案JSONP
1.在互联网中我们的计算机是通过IP来定位的,但是IP比较难记忆,因此通过domain name(域名)来取代IP 2.什么是跨域? (1)默认浏览器为了安全问题,禁止了xmlhttprequest跨 ...
- android版本vqmon移植IOS版
IOS交叉编译 1.android版本 vqmon已经正常运行,现需要开放IOS版本,作移植工作. 2. 注意事项: 1)ROOT权限,IOS必须越狱. 2)依赖库:pcap, ffmpeg,lib ...
- 【APUE】Chapter11 Threads
看完了APUE第三版的Chapter11 Threads,跟着书上的demo走了一遍,并且参考了这个blog(http://www.cnblogs.com/chuyuhuashi/p/4447817. ...
- JMeter学习笔记(五) 文件上传接口测试
此次测试的是上传图片接口,我把测试情况整理了一下,其他的上传文件接口都类似. 1.我通过jmeter的录制功能获取到了接口地址以及相关参数,如果有接口文档就会方便很多,此步骤就不多做说明了 2.因为上 ...
- UIAutomator2、Appium、Robotium搭建环境与框架对比
UIAutomator2.Appium.Robotium搭建环境与框架对比 一.框架介绍 Appium 特点 appium 是一个自动化测试开源工具,支持 iOS 平台和 Android 平台上的原生 ...
- leetcode 174. 地下城游戏 解题报告
leetcode 174. 地下城游戏 一些恶魔抓住了公主(P)并将她关在了地下城的右下角.地下城是由 M x N 个房间组成的二维网格.我们英勇的骑士(K)最初被安置在左上角的房间里,他必须穿过地下 ...