QT界面程序经过网路与普通的linux应用程序进行数

有时候会遇到QT界面程序经过网路与普通的linux应用程序进行数据传送的情况:(UDP协议,非TCP协议)
 
个人感觉比管道、共享内存、信号量、消息队列好用
 
Qt udp_client
 
1.我们新建Qt4 GuiApplication,工程名为“udpSender”,选中QtNetwork模块,Base class选择QWidget。
 
2.我们在widget.ui文件中,往界面上添加一个Push Button,进入其单击事件槽函数。 
 
 
3.我们在widget.h文件中更改。
 
添加头文件:#include <QtNetwork>
 
添加private私有对象:QUdpSocket *sender;
 
4.我们在widget.cpp中进行更改。
 
在构造函数中添加:sender = new QUdpSocket(this);
 
void Widget::on_pushButton_clicked() {
 
    QByteArray datagram = “hello world!”;
 
  sender->writeDatagram(datagram.data(),datagram.size(),
 
                        QHostAddress("192.168.1.10"),8888); //ip为目标机ip
 
}
 
这里我们定义了一个QByteArray类型的数据报datagram,其内容为“hello world!”。然后我们使用QUdpSocket类的writeDatagram()函数来发送数据报,这个函数有四个参数,分别是数据报的内容,数据报的大小,主机地址和端口号。对于数据报的大小,它根据平台的不同而不同,但是这里建议不要超过512字节。对于端口号,它是可以随意指定的,但是一般1024以下的端口号通常属于保留端口号,所以我们最好使用大于1024的端口,最大为65535。我们这里使用了8888这个端口号,一定要注意,在下面要讲的服务器程序中,也要使用相同的端口号。

应用程序:udp_server.c
 
#include <stdlib.h>
 #include <stdio.h>
 #include <errno.h>
 #include <string.h>
 #include <unistd.h>
 #include <netdb.h>
 #include <sys/socket.h>
 #include <netinet/in.h>
 #include <sys/types.h>
 #include <arpa/inet.h>
 

#define SERVER_PORT 8888
 #define MAX_MSG_SIZE 1024
 

void udps_respon(int sockfd)
 {
 struct sockaddr_in addr;
 int addrlen,n;
 char msg[MAX_MSG_SIZE];
 

while(1)
 {  /* 从网络上读,并写到网络上 */
 bzero(msg,sizeof(msg)); // 初始化,清零
 addrlen = sizeof(struct sockaddr);
 n=recvfrom(sockfd,msg,MAX_MSG_SIZE,0,(struct sockaddr*)&addr,&addrlen); // 从客户端接收消息
 msg[n]=0;//将收到的字符串尾端添加上字符串结束标志
 /* 显示服务端已经收到了信息 */
 fprintf(stdout,"Server have received %s",msg); // 显示消息
 }
 }
 

int main(void)
 {
 int sockfd;
 struct sockaddr_in addr;
 

/* 服务器端开始建立socket描述符 */
 sockfd=socket(AF_INET,SOCK_DGRAM,0);
 if(sockfd<0)
 {
 fprintf(stderr,"Socket Error:%s\n",strerror(errno));
 exit(1);
 }
 

/* 服务器端填充 sockaddr结构 */
 bzero(&addr,sizeof(struct sockaddr_in));
 addr.sin_family=AF_INET;
 addr.sin_addr.s_addr=htonl(INADDR_ANY);
 addr.sin_port=htons(SERVER_PORT);
 

/* 捆绑sockfd描述符 */
 if(bind(sockfd,(struct sockaddr *)&addr,sizeof(struct sockaddr_in))<0)
 {
 fprintf(stderr,"Bind Error:%s\n",strerror(errno));
 exit(1);
 }
 

udps_respon(sockfd); // 进行读写操作
 close(sockfd);
 } 

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/3958300e474bd0c5a68b2f46f33e425b.html