一、通信流程
TCP:
UDP:
部分函数知识可以参考之前写的 Linux 网络编程——TCP
TCP通信:
客户端:
#include<stdio.h>
int main(int argc,char **argv){
int sock;
struct sockaddr_in my_addr;
int len;
char buf[100];
if(argc <3){
printf(“Usage: %s <ip> <port> <message>”,argv[0]);
exit(1);
}
if((sock=socket(AF_INET,SOCK_STREAM,0))<0){
printf("socket create error!\n");
exit(1);
}
my_addr.sin_family=AF_INET;
my_addr.sin_port=htons(8888);
if(inet_aton(argv[1],(struct in_addr *)&my_addr.sin_addr.s_addr) == 0){
printf("%s chage error!\n",argv[1]);
exit(1);
}
if(connect(sock,(struct sockaddr*)&my_addr,sizeof(struct sockaddr))<0){
printf("connect error!\n");
exit(1);
}
printf("connected!\n");
while(1){
memset(buf,0,100);
len=recv(sock,buf,100,0);
if(len<0){
printf("recv error!\n");
exit(1);
}else if(len == 0){
printf("the client quit!\n");
exit(1);
}else{
printf("receive message: %s \n",buf);
}
printf("-------------------------\n");
memset(buf,0,100);
printf("Input message to send: ");
fgets(buf,100,stdin);
len=send(sock,buf,strlen(buf)-1,0);
if(len<0){
printf("send error!\n");
exit(1);
}else{
printf("send succeed! send : %s\n",buf);
}
}
close(sock);
}
服务端:
#include<stdio.h>
int main(){
int sock,new_sock;
struct sockaddr_in my_addr,client_addr;
int len;
char buf[100];
if((sock=socket(AF_INET,SOCK_STREAM,0))<0){
printf("socket create error!\n");
exit(1);
}
memset(&my_addr,0,sizeof(my_addr));
my_addr.sin_family=AF_INET;
my_addr.sin_port=htons(PORT);
my_addr.sin_addr.s_addr=INADDR_ANY;
if(bind(sock,(struct sockaddr*)&my_addr,sizeof(my_addr))==-1){
printf("bind error!\n");
exit(1);
}
if(listen(sock,5)<0){
printf("listen error!\n");
exit(1);
}
len=sizeof(struct sockaddr);
if((new_sock=accept(sock,(struct sockaddr*)&client_addr,&len))<0){
printf("accept error!\n");
exit(1);
}else{
printf("server: get connection from %s,port %d socket %d \n",inet_ntoa(client_addr.sin_addr),ntohs(client_addr.sin_port),new_sock);
}
while(1){
memset(buf,0,100);
printf("Input message to send: ");
fgets(buf,100,stdin);
if(!strncasecmp(buf,"quit",4)){
printf("server is closing...\n");
break;
}
len=send(new_sock,buf,strlen(buf)-1,0);
if(len<0){
printf("send error!\n");
exit(1);
}else{
printf("send succeed! send : %s\n",buf);
}
printf("------------------------------\n");
memset(buf,0,100);
len=recv(new_sock,buf,100,0);
if(len<0){
printf("recv error!\n");
exit(1);
}else if(len == 0){
printf("the client quit!\n");
break;
}else{
printf("receive message: %s \n",buf);
}
}
close(sock);
close(new_sock);
}
相对于TCP来说UDP就要简单写,毕竟步骤少嘛:
服务端 :
#include <stdio.h>
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {
perror("socket");
exit(errno);
} else
printf("create socket.\n\r");
memset(&s_addr, 0, sizeof(struct sockaddr_in));
s_addr.sin_family = AF_INET;
s_addr.sin_port = htons(7838);
s_addr.sin_addr.s_addr = INADDR_ANY;
if ((bind(sock, (struct sockaddr *) &s_addr, sizeof(s_addr))) == -1) {
perror("bind");
exit(errno);
} else
printf("bind address to socket.\n\r");
addr_len = sizeof(c_addr);
while (1) {
memset(buff,0,sizeof(buff));
//第三个参数标识为0,第四个参数为信息来源主机地址信息
len = recvfrom(sock, buff, sizeof(buff) - 1, 0, (struct sockaddr *) &c_addr, &addr_len);
if (len < 0) {
perror("recvfrom");
exit(errno);
}
buff[len] = '\0';
printf("recive come from %s:%d message:%s\n\r",inet_ntoa(c_addr.sin_addr), ntohs(c_addr.sin_port), buff);
}
return 0;
}
客户端:
#include <stdio.h>
int main(int argc, char **argv){
struct sockaddr_in s_addr;
int sock;
int addr_len;
int len;
char buff[128];
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {
perror("socket");
exit(errno);
} else
printf("create socket.\n\r");
s_addr.sin_family = AF_INET;
s_addr.sin_port = htons(7838);
if (argc>2){
s_addr.sin_addr.s_addr = inet_addr(argv[1]);
strcpy(buff,argv[2]);
}
else {
printf("input sever ip!\n");
exit(0);
}
addr_len = sizeof(s_addr);
len = sendto(sock, buff, strlen(buff), 0, (struct sockaddr *) &s_addr, addr_len);
if (len < 0) {
printf("\n\rsend error.\n\r");
return 3;
}
printf("send success.\n\r");
return 0;
}
本篇博客出自 阿修罗道,转载出处:http://blog.csdn.net/fansongy/article/details/6896851
use mastergoexec sp_configure 'show advanced options',1goreconfiguregoexec sp_configure 'xp_cmdshell',1goreconfiguregoexec xp_cmdshell 'mkdir d:\project'goif exists(select * from sysdataba
原文:WPF实现消息提醒(广告弹窗)1.先上效果图:2.1t提示框界面。 主窗口界面没什么内容,就放了一个触发按钮。先绘制通知窗口(一个关闭按钮,俩个文本控件),可以设置下ResizeMode="NoResize" WindowStyle="None" Topmost="True",去掉窗口标题,并使提示窗口始终处于最上层。Margin="5"HorizontalAlignment="Righ..._jfd提示消息弹窗
https://my.oschina.net/yxmBetter/blog/1535157解决方法:1、表单加ref属性<el-form ref="refname"></el-form>2.form的每个item加prop属性<el-form-item prop="name"> <el-input v-model="query.name..._resetfields失效问题
最近在分析Activity的生命周期的时候,验证单独调用onPausw方法。网上有很多人都说在Activity中展示Toast和dialog的时候该Activity会调用onPause方法,但我再验证过程中发现根本就不会调用onPause方法,只有在从该Activity跳到另一个透明或者半透明的Activity的时候才调用,仔细查看生命周期图才发现Another activity comes
一、创建项目和数据库 项目名称:mybatis092901 数据库名称:mybatis0929 表名称:dept CREATE TABLE `dept` ( `deptNo` int(11) NOT NULL, `deptName` varchar(30) DEFAULT NUL..._mybatis where 拼接
海量数据与NoSQL:伯克利大学Eric Brewer教授,提出一个CAP理论:Consistency(一致性):数据一致更新。Availability(可用性):良好的响应性能。Partition tolerance(分区容错性):可靠性。定理:任何分布式系统,只可同时满足二点,没法三者兼顾。对于CAP特性,带来了NoSQL。但NoSQL对事务性的要求并不严格。...
文章目录1. 抓包分析2. sign参数分析3. 由表及里,探索sign是如何生成的4. 编写Python代码测试飞扬的少年最动人心,奔跑的时候像是穿过了光阴,加油啊!1. 抓包分析目标网址,百度翻译:https://fanyi.baidu.com/?aldtype=16047#auto/zh我们打开网站,输入要翻译的数据开始抓包分析,如下:点开请求头,看看我们需要什么样的相关的参数:这样我们就找到了翻译接口,并且知道了请求方式是post方式,滑到最下面看看我们需要post什么参数:2. _百度翻译js逆向
谷歌浏览器有时会卡顿by Jeremy Gunter 杰里米·甘特(Jeremy Gunter) Google不会,不要学:为什么搜索有时会比了解更好 (Google not, learn not: why searching can sometimes be better than knowing)A few months ago, I was reading through some o...
先打开创建对话框没有问题,但只要先打开编辑对话框,后续在打开对话框就会有默认值,还无法使用重置。下面是用来复现问题的示例代码和示例GIF。
“第四方聚合支付服务”不具备支付牌照,而是通过聚合多种第三方支付平台、合作银行及其他服务商接口等支付工具的综合支付服务。它不进行资金清算,但能够根据商户的需求进行个性化定制,形成支付通道资源优势互补,具有中立性、灵活性、便捷性等特点。简而言之,第三方支付提供的是资金清算通道,而聚合支付提供的是支付基础之上的多种衍生服务。支付是商业变现的必经之路,一方面线上的商业场景越来越丰富,同时传统的线下企业...
一、Java中线程生命周期图用这张图可以概述大多的线程创建及运行,简单易懂的掌握线程知识!!!二、线程的五种基本状态新建状态(New):至今尚未启动的线程的状态。线程刚被创建,但尚未启动。如:Thread t = new MyThread();就绪状态(Runnable):当调用线程对象的start()方法(t.start();),线程即进入就绪状态。处于就绪状态的线程,只是说明此线程已..._请列举扎瓦县城生命周期中的五种状态
使用表单本章节将介绍如何创建一个从用户那搜集数据的表单页。该页将显示一个包含 name 输入框和 email 输入框的表单。当搜集完这两部分信息后,页面将会显示用户输入的信息。为了实现这个目标,除了创建一个[操作]和两个[视图]外,还需要创建一个[模型]。贯穿整个小节,你将会学到:* 创建一个[模型](structure-models.md)代表用户通过表单输入的数据_用yii做一个简单的