windows环境下C语言socket编程

最近由于实验需要,要求写一个c程序与java程序通信的软件,为了测试首先写了一个windows环境下c语言的socket(tcp)通信程序。

首先socket通信的步骤:


   图一     socket通信步骤(转载)


                                            图二 三次握手协议(转载)


  图三    三次握手协议(转载)

代码  服务器端

    #include <winsock2.h>
    #include <windows.h>
    #pragma comment(lib,"ws2_32.lib")
     
    int main(int argc, char* argv[])
    {
        //初始化WSA
        WORD sockVersion = MAKEWORD(2, 2);
        WSADATA wsaData;
        if (WSAStartup(sockVersion, &wsaData) != 0)
        {
            return 0;
        }
     
        //创建套接字
        SOCKET slisten = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
        if (slisten == INVALID_SOCKET)
        {
            printf("socket error !");
            return 0;
        }
     
        //绑定IP和端口
        struct sockaddr_in sin;
        sin.sin_family = AF_INET;
        sin.sin_port = htons(8888);
        sin.sin_addr.S_un.S_addr = INADDR_ANY;
        if (bind(slisten, (LPSOCKADDR)&sin, sizeof(sin)) == SOCKET_ERROR)
        {
            printf("bind error !");
        }
     
        //开始监听
        if (listen(slisten, 5) == SOCKET_ERROR)
        {
            printf("listen error !");
            return 0;
        }
     
        //循环接收数据
        SOCKET sClient;
        struct sockaddr_in remoteAddr;
        int nAddrlen = sizeof(remoteAddr);
        //char revData[255];
        printf("等待连接...\n");
        sClient = accept(slisten, (SOCKADDR *)&remoteAddr, &nAddrlen);
        while (1)
        {
            char revData[255];
            //printf("等待连接...\n");
            //sClient = accept(slisten, (SOCKADDR *)&remoteAddr, &nAddrlen);
            if (sClient == INVALID_SOCKET)
            {
                printf("accept error !");
                continue;
            }
            printf("接受到一个连接:%s \r\n", inet_ntoa(remoteAddr.sin_addr));
     
            //接收数据
            int ret = recv(sClient, revData, 255, 0);
            //printf(ret);
            if (ret > 0)
            {
                revData[ret] = 0x00;
                printf(revData);
            }
            //发送数据
            char * sendData = "你好,TCP客户端!\n";
            send(sClient, sendData, strlen(sendData), 0);
        }
            closesocket(sClient);
        closesocket(slisten);
        WSACleanup();
        return 0;
    }

代码   客户端

    #include <winsock2.h>
    #include <windows.h>
    #pragma comment(lib,"ws2_32.lib")
    #include <STDIO.H>
    int main(int argc, char* argv[])
    {
        WORD sockVersion = MAKEWORD(2, 2);
        WSADATA data;
        if (WSAStartup(sockVersion, &data) != 0)
        {
            return 0;
        }
     
        SOCKET sclient = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
        if (sclient == INVALID_SOCKET)
        {
            printf("invalid socket !");
            return 0;
        }
     
        struct sockaddr_in serAddr;
        serAddr.sin_family = AF_INET;
        serAddr.sin_port = htons(8888);
        serAddr.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");
        if (connect(sclient, (struct sockaddr *)&serAddr, sizeof(serAddr)) == SOCKET_ERROR)
        {
            printf("connect error !");
            closesocket(sclient);
            return 0;
        }
        for (int i = 0; i < 1000; i++)
        {
     
            char * sendData = "csi接收  二进制文件未解析\n";
            send(sclient, sendData, strlen(sendData), 0);
            char recData[255];
            /*int ret = recv(sclient, recData, 255, 0);
            if (ret > 0)
            {
        
                recData[ret] = 0x00;
                //printf(recData);
                printf("%d%s",i,recData);
            }
            */
        }
        closesocket(sclient);
        WSACleanup();
        return 0;
    }

后续会给出c程序与java程序通信的例子。


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384913.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

进程控制块(PCB)

进程控制块PCB 我们知道&#xff0c;每个进程在内核中都有一个进程控制块&#xff08;PCB&#xff09;来维护进程相关的信息&#xff0c;Linux内核的进程控制块是task_struct结构体。 /usr/src/linux-headers-3.16.0-30/include/linux/sched.h文件中可以查看struct task_struct…

网络层攻击防御

网络层攻击防御 网络层攻击防御主要分为以下三类&#xff1a; TCP类报文攻击防御 UDP类报文攻击防御 ICMP类报文攻击防御 TCP类报文攻击防御 TCP正常的交互过程&#xff1a; 图&#xff1a;TCP正常交互过程 在TCP/IP协议中&#xff0c;TCP协议提供可靠的连接服务&#xff0c…

Linux之环境变量

常见环境变量 按照惯例&#xff0c;环境变量字符串都是namevalue这样的形式&#xff0c;大多数name由大写字母加下划线组成&#xff0c;一般把name的部分叫做环境变量&#xff0c;value的部分则是环境变量的值。环境变量定义了进程的运行环境&#xff0c;一些比较重要的环境变量…

环境变量操作函数

getenv获取环境变量值的函数&#xff1b; setenv改变或者添加环境变量函数&#xff1b; unsetenv 取消环境变量&#xff1b; &#xff08;可以在终端上man 函数名来获取详细的函数信息&#xff09; #include<stdio.h> #include<stdlib.h> #include<string.h>…

Makefile(三)

在平时使用中&#xff0c;可以使用以下的makefile来编译单独的代码 src $(wildcard *.c) obj $(patsubst %.c, %.o, $(src))CC gcc CFLAGS -Wall -gall:$(target)$(target):%:%.c$(CC) $< -o $ $(CFLAGS).PHONY: clean all clean:-rm -rf $(target) 使用方法就是make 后…

位运算(C++)

C输出十六进制 #include<iostream> #include<iomanip> using namespace std;int main() {int a 60;int b 13;int c a &b;cout << "a : hex "<<hex << a << endl;cout << "b : hex "<<hex <<…

数学函数(C/C++)

C中包含头文件<math.h> C包含头文件<cmath> 函数 double cos&#xff08;double&#xff09; 该函数返回弧度角&#xff08;double型&#xff09;的余弦 double tan&#xff08;double&#xff09; 该函数返回弧度角&#xff08;double型&#xff09;的正切…

数据类型(C++)

不同系统会有不同差异&#xff1a; 类型 位(byte) 范围 char 1 -128—127 or 0 – 255 unsigned char 1 0 – 255 signed int 1 -128—127 int 4 -2^31 – 2^32-1 unsigned int 4 0 – 2^32 signed int 4 -2^31 – 2^32-1 short int 2 2^15 – 2^15-1 …

日期与时间(C/C++)

C继承了C语言用于日期和时间操作的结构和函数&#xff0c;使用之前程序要引用<ctime>头文件 有四个与时间相关的类型:clock_t、time_t、size_t、和tm。类型clock_t、size_t、和time_t能够把系统时间和日期表示为某种整数。 结构体tm把时间和日期以C结构的形式保存&#x…

标准输入输出(C++)

输入输出流函数&#xff08;模板&#xff09; #include<iostream> #include<iomanip> using namespace std; int main() {cout << setiosflags(ios::left|ios::showpoint); //设左对齐cout.precision(5); //设置除小数…

拷贝函数和构造函数

类的构造函数&#xff1a; 类的构造函数是类的一种特殊的成员函数&#xff0c;它会在每次创建类的新对象时执行。 构造函数的名称与类的名称是完全相同的&#xff0c;并且不会返回任何类型&#xff0c;也不会返回void。 构造函数可用于为某些成员变量初始值。 默认的构造函数是…

拷贝构造函数

拷贝构造函数是一种特殊的构造函数&#xff0c;它在创建对象时&#xff0c;使用的是同一类中之前创建的对象来初始化新创建的对象。拷贝构造函数通常用于&#xff1a; l 通过使用另一个同类型的对象来初始化新创建的对象&#xff1b; l 复制对象把它作为参数传递给函数&#…

Linux进程通信之管道

进程间完成数据传递需要借助操作系统提供的特殊的方法&#xff0c;比如&#xff1a;文件、管道、信号、共享内存、消息队列、套接字、命名管道等。但现在常用的进程间通信方式有&#xff1a; 管道 – 使用最简单 pipe 管道一般读写行为 FIFO&#xff08;有名管道&#xff09;&a…

Linux进程通信之文件

父子进程共享打开的文件描述符------使用文件完成进程间通信. /*** fork_share_fd.c***/ #include <stdio.h> #include <unistd.h> #include <string.h> #include <stdlib.h> #include <fcntl.h> #include <sys/wait.h>int main(void) {in…

dup2函数

将当前系统中的进程信息打印到文件中 命令行&#xff1a;ps aux > out 将ps得到的信息重定向到out文件中 使用dup2文件在程序中完成。 int dup2(int oldfd,int newfd); /*** dup2.c ***/ #include<stdio.h> #include<fcntl.h> #include<unistd.h> #includ…

wait()函数

wait()函数&#xff1a;回收僵尸进程 父进程调用wait函数可以回收子进程终止信息。该函数有三个功能&#xff1a; 1&#xff09; 阻塞等待子进程退出 2&#xff09; 回收子进程残留资源 3&#xff09; 获取子进程结束状态&#xff08;退出原因&#xff09; /*** zoom_test.c **…

waitpid()函数

waitpid函数 作用同于wait&#xff0c;但可指定pid进程清理&#xff0c;可以不阻塞。 pid_t waitpid(pid_t pid,int *status,int options);成功&#xff1a;返回清理掉的子进程ID&#xff1b;失败&#xff1a;-1&#xff08;无子进程&#xff09; 特殊参数和返回情况&#xff1…

孤儿进程、僵尸进程

孤儿进程&#xff1a;父进程先于子进程结束&#xff0c;则子进程成为孤儿进程&#xff0c;子进程的父进程成为init进程&#xff0c;称为init进程领养孤儿进程。 /*** orphan.c ***/ #include <stdio.h> #include <unistd.h> #include <sys/wait.h>int main(v…

友元函数

类的友元函数是定义在类外部&#xff0c;但有权访问类的所有私有成员和保护成员。尽管友元函数的原型有在类的定义中出现过&#xff0c;但友元函数并不是成员函数。 友元可以是一个函数&#xff0c;该函数被称为友元函数&#xff1b;友元也可以是一个类&#xff0c;该类被称为友…

this指针

在C中&#xff0c;每一个对象都能够通过this指针来访问自己的地址。this指针是所有成员函数的隐含参数。因此&#xff0c;在成员函数内部&#xff0c;它可以用来指向调用对象。 友元函数是没有this指针的&#xff0c;因为友元不是类的成员&#xff0c;只有成员函数才有this指针…