2024/4/23 作业

1、tcp

int main(int argc, const char *argv[])
{
    // 创建流式套接字
    int sfd = socket(AF_INET , SOCK_STREAM, 0);
    if(sfd < 0)
    {
        fprintf(stderr,"__%d__",__LINE__);
        perror("socket");
        return -1;
    }
    printf("创建流式套接字成功 sfd=%d __%d__\n",sfd,__LINE__);

    //允许端口号被快速重复使用
    int reuse = 1;
    if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
    {                                                                          
        fprintf(stderr, "line:%d  ", __LINE__);
        perror("setsockopt");
        return -1;

    }
    
    // 填充服务器的地址信息结构体,真实的地址信息结构提根据地址族制定
    // AF_INET ---> man 7 ip
    struct sockaddr_in sin;
    sin.sin_family       = AF_INET;         // 必须填AF_INET
    sin.sin_port         = htons(PORT);     // 端口号的网络字节序 1024~49151
    sin.sin_addr.s_addr  = inet_addr(IP);   // 服务器要运行的主机的IP的网络地址
    
    // 绑定服务器自身的地址信息---> 必须绑定
    if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin)) < 0)
    {
        fprintf(stderr,"__%d__",__LINE__);
        perror("bind");
        return -1;
    }
    printf("服务器地址绑定成功 __%d__\n",__LINE__);

    // 将套接字设置为自动监听状态
    if(listen(sfd,128) < 0)
    {
        fprintf(stderr,"__%d__",__LINE__);
        perror("listen");
        return -1;
    }
    printf("自动监听状态设置成功 __%d__\n",__LINE__);

    struct sockaddr_in cin;  // 存储客户端信息的
    socklen_t addrlen = sizeof(cin);
    // 从已经完成链接队列的队头获取一个客户端的信息,生成一个新的文件描述符
    // accept(sfd,NULL,NULL);
    int newfd = accept(sfd,(struct sockaddr*)&cin,&addrlen);
    if(newfd < 0)
    {
        fprintf(stderr,"__%d__",__LINE__);
        perror("accept");
        return -1;
    }
    printf("客户端信息接收成功 __%d__\n",__LINE__);

    char buf[128];
    ssize_t res;
    while(1)
    {
        // 接收
        bzero(buf,sizeof(buf));
        res = recv(newfd, buf, sizeof(buf), 0);
        if(res < 0)
        {
            fprintf(stderr,"__%d__",__LINE__);
            perror("recv");
            return -1;
        }
        else if(0 == res)
        {
            printf("客户端下线\n");
            break;
        }
        printf("客户端:%d\n客户端发送内容:%s\n ",newfd,buf);
        // 发送
        strcat(buf,"*_*");
        if(send(newfd,buf,sizeof(buf),0) < 0)
        {
            fprintf(stderr,"__%d__",__LINE__);
            perror("send");
            return -1;
        }
        printf("服务器发送成功\n");
    }
    // 关闭文件描述符
    close(newfd);
    close(sfd);
    return 0;
}

#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <string.h>
#include <unistd.h>

#define PORT 8888
#define IP "192.168.1.5"
int main(int argc, const char *argv[])
{
    //创建流式套接字文件
    int sfd = socket(AF_INET,SOCK_STREAM,0);
    if(sfd<0)
    {
        fprintf(stderr,"line:%d",__LINE__);
        perror("scoket");
        return -1;
    }
    printf("创建流式套接字成功 sfd=%d __%d__\n",sfd,__LINE__);
    //允许端口号被快速重复使用
    int reuse = 1;
    if(setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)
    {
        fprintf(stderr, "line:%d  ", __LINE__);
        perror("setsockopt");
        return -1;
    }
    //填充服务器的地址信息结构体,真实的地址信息结构体根据地址族制定
    //AF_INET--->man 7 IP
    struct sockaddr_in sin;
    sin.sin_family  = AF_INET;     //必须填AF_INET;
    sin.sin_port    = htons(PORT);//端口号的网络字节序 1024~49151
    sin.sin_addr.s_addr=inet_addr(IP);//服务器要运行的主机的IP的网络地址
                                    //ifconfig 查找本机的IP地址
    //绑定服务器自身的地址信息--->>必须绑定
    if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0)
    {
        fprintf(stderr,"line:%d",__LINE__);
        perror("bind");
        return -1;
    }
    printf("bind success __%d__\n",__LINE__);
    //将套接字设置为被动监听状态
    if(listen(sfd,17)<0)
    {
        fprintf(stderr,"line:%d ",__LINE__);
        perror("listen");
        return -1;
    }
    printf("listen success __%d__\n",__LINE__);
    struct sockaddr_in cin; //存储客服端信息的
    socklen_t addrlen = sizeof(cin);
    //会从已完成连接队列的队头获取一个客服端的信息,生成一个新的文件描述符
    //accept(sfd,NULL,NULL);
    int newfd = accept(sfd,(struct sockaddr*)&cin,&addrlen);
    if(newfd<0)
    {
        fprintf(stderr,"line:%d",__LINE__);
        perror("accept");
        return -1;
    }
    printf("[%s:%d]客户端连接成功 newsfd=%d __%d__\n",\
            inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),newfd,__LINE__);
    char buf[128];
    ssize_t res;
    while(1)
    {
        bzero(buf,sizeof(buf));
        //接收
        res=recv(newfd,buf,sizeof(buf),0);
        if(res<0)
        {
            fprintf(stderr,"line:%d",__LINE__);
            perror("recv");
            return -1;
        }
        else if(0==res)
        {
            printf("[%s:%d]客服端下线 newfd=%d__%d__\n",\
                    inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),newfd,__LINE__);
            break;
        }
            printf("[%s:%d]客服端连接成功 newfd=%d %s__%d__\n",\
                inet_ntoa(cin.sin_addr),ntohs(cin.sin_port),newfd,buf,__LINE__);
        //发送
        strcat(buf,"*_*");
        if(send(newfd,buf,sizeof(buf),0)<0)
        {
            fprintf(stderr,"line:%d ",__LINE__);
            perror("send");
            return -1;
        }
        printf("send success __%d__\n",__LINE__);
    }
    //关闭文件描述符
    close(newfd);
    close(sfd);
    return 0;
}
 

2、udp

#include<stdio.h>

#include <sys/types.h>

#include <sys/socket.h>

#include <arpa/inet.h>

#include <string.h>

#include <unistd.h>

#include <stdlib.h>

#define CLI_PORT 8888

#define CLI_IP "192.168.124.14"

int main(int argc, const char *argv[])

{

    //创建报式套接字

    int sfd = socket(AF_INET,SOCK_DGRAM,0);

        if(sfd<0)

        {

            fprintf(stderr,"line:%d ",__LINE__);

            perror("socket");

            return -1;

        }

    printf("创建报式套接字成功,sfd=%d __%d__\n",sfd,__LINE__);

    //允许端口号被快速重复使用

    int  reuse = 1;

    if(setsockopt(sfd,SOL_SOCKET,SO_REUSEADDR,&reuse,sizeof(reuse))<0)

    {

        fprintf(stderr,"line:%d ",__LINE__);

        perror("setsockopt");

        return -1;

    }

    //填充服务器的地址信息结构体,真实的地址信息结构体根据地址族制定

    //AF_INET ---> man 7 IP

    struct sockaddr_in sin;

    sin.sin_family = AF_INET; //必须填AF_INET

    sin.sin_port   = htons(CLI_PORT); //客户端要绑定的端口号

    sin.sin_addr.s_addr=inet_addr(CLI_IP); //客户端绑定的IP地址

    //ifconfig查找本机的IP地址

    //绑定服务器自身的地址信息--->必须绑定

    if(bind(sfd,(struct sockaddr*)&sin,sizeof(sin))<0)

    {

        fprintf(stderr,"line:%d ",__LINE__);

        perror("bind");

        return -1;

    }

    printf("bind success __%d__\n",__LINE__);

    char buf[128]="";

    struct sockaddr_in cin;

    socklen_t addrlen=sizeof(cin);

    while(1)

    {

        bzero(buf,sizeof(buf));

        //接收

        if(recvfrom(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,&addrlen)<0)

        {

            fprintf(stderr,"line:%d ",__LINE__);

            perror("bind");

            return -1;

        }

        printf("[%s:%d] : %s __%d__\n",\

                inet_ntoa(cin.sin_addr),htons(cin.sin_port),buf,__LINE__);

        //发送--->谁发给我,我发还给谁

        strcat(buf,"*_*");

        if(sendto(sfd,buf,sizeof(buf),0,(struct sockaddr*)&cin,sizeof(cin))<0)

        {

            fprintf(stderr,"line:%d ",__LINE__);

            perror("bind");

            return -1;

        }

        printf("发送成功\n");

    }

   

    close(sfd);

    return 0;

}

#include <stdio.h>

#include <sys/types.h>

#include <sys/socket.h>

#include <arpa/inet.h>

#include <netinet/in.h>

#include <string.h>

#include <unistd.h>

#include <stdlib.h>


 

#define SER_PORT 8888            

#define SER_IP "192.168.124.14"

#define CLI_PORT 6666

#define CLI_IP "192.168.124.14"

int main(int argc, const char *argv[])

{

    // 创建流式套接字

    int cfd = socket(AF_INET , SOCK_DGRAM, 0);

    if(cfd < 0)

    {

        fprintf(stderr,"__%d__",__LINE__);

        perror("socket");

        return -1;

    }

    printf("创建流式套接字成功 cfd=%d __%d__\n",cfd,__LINE__);

    //允许端口号被快速重复使用

    int reuse = 1;

    if(setsockopt(cfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) < 0)

    {                                                                          

        fprintf(stderr, "line:%d  ", __LINE__);

        perror("setsockopt");

        return -1;

    }

    // 填充客户端的地址信息

    struct sockaddr_in cin;

    cin.sin_family         = AF_INET; // 必须填充AF_INET

    cin.sin_port           = htons(CLI_PORT); // 客户端绑定的端口号1024~49151

    cin.sin_addr.s_addr    = inet_addr(CLI_IP); //客户端绑定的IP号

    //ifconfig查找本机的IP地址

    //绑定服务器自身的地址信息--->必须绑定

    if(bind(cfd,(struct sockaddr*)&cin,sizeof(cin))<0)

    {

        fprintf(stderr, "line:%d  ", __LINE__);

        perror("bind");

        return -1;

    }

    printf("bind [%s:%d] success__%d__\n",CLI_IP,CLI_PORT,__LINE__);

    /

   

    //填充服务器的地址信息结构体,给sendto函数使用

    //指定要将数据包发给谁

    //AF_INET---man 7 ip

    struct sockaddr_in sin;

    sin.sin_family         = AF_INET; // 必须填充AF_INET

    sin.sin_port           = htons(SER_PORT); // 服务器绑定的端口号

    sin.sin_addr.s_addr    = inet_addr(SER_IP); //服务器绑定的IP号

   

    char buf[128]="";

    struct sockaddr_in rcvaddr;

    socklen_t addrlen = sizeof(rcvaddr);  // 存储数据包发送方的地址信息

    while(1)

    {

        bzero(buf,sizeof(buf));

        //发送

        printf("请输入发送内容:\n");

        fgets(buf,sizeof(buf),stdin);

        buf[strlen(buf)-1] = '\0';

        //将数据发送给服务器

        if(sendto(cfd,buf,sizeof(buf),0,(struct sockaddr*)&sin,sizeof(sin)) < 0)

        {

            fprintf(stderr,"line:%d ",__LINE__);

            perror("sendto");

            return -1;

        }

        printf("客户端发送成功\n");

        bzero(buf,sizeof(buf));

        //接收

        if(recvfrom(cfd, buf, sizeof(buf), 0,(struct sockaddr*)&rcvaddr,&addrlen)<0)

        {

            fprintf(stderr,"line:%d__",__LINE__);

            perror("recvfrom");

            return -1;

        }

        printf("%s:%d]:%s  %d__\n",\

                inet_ntoa(rcvaddr.sin_addr),htons(rcvaddr.sin_port),buf,__LINE__);

    }

    // 关闭文件描述符

    close(cfd);

    return 0;

}

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值