使用c++实现网络编程并传输密文

1.实验内容及原理

使用c/c++进行网络编程,实现两台电脑之间的信息传输

2.实验环境

(实验拓扑、节点介绍)

 

3.程序概要设计(或使用的工具介绍)

虚拟实验平台、VS编程软件、Xftp传输工具

4.实验步骤、实验结果、分析

一:编写两端代码

发送端代码(client.cpp)


#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <netdb.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <string>
#include <iostream>
using namespace std;

int main(int argc, char* argv[])
{
    if (argc != 3)
    {
        printf("Using:./client ip port\nExample:./client 127.0.0.1 5005\n\n"); return -1;
    }

    // 第1步:创建客户端的socket。
    int sockfd;
    if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket"); return -1; }

    // 第2步:向服务器发起连接请求。
    struct hostent* h;
    if ((h = gethostbyname(argv[1])) == 0)   // 指定服务端的ip地址。
    {
        printf("gethostbyname failed.\n"); close(sockfd); return -1;
    }
    struct sockaddr_in servaddr;
    memset(&servaddr, 0, sizeof(servaddr));
    servaddr.sin_family = AF_INET;
    servaddr.sin_port = htons(atoi(argv[2])); // 指定服务端的通信端口。
    memcpy(&servaddr.sin_addr, h->h_addr, h->h_length);
    if (connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) != 0)  // 向服务端发起连接清求。
    {
        perror("connect"); close(sockfd); return -1;
    }

    char buffer[1024];

    // 第3步:与服务端通信,发送一个报文后等待回复,然后再发下一个报文。
    char a[100]={0};
    cout << "please enter the key:";
    cin.getline(a, 100);
    cout << "the key is:"<<a;
    int i = 0;
    for (i = 0; i < 100; i++)
    {
        a[i] += 5;
    }
        int iret;
        strcpy(buffer, a);
 //       memset(buffer, 0, sizeof(buffer));
        cout << buffer << endl;
        if ((iret = send(sockfd, buffer, strlen(buffer), 0)) <= 0) // 向服务端发送请求报文。
        {
            perror("send"); //break;
        }
//        printf("%s\n", buffer);

        memset(buffer, 0, sizeof(buffer));
        if ((iret = recv(sockfd, buffer, sizeof(buffer), 0)) <= 0) // 接收服务端的回应报文。
        {
            printf("iret=%d\n", iret); //break;
        }
        printf("receive:%s\n", buffer);


    // 第4步:关闭socket,释放资源。
    close(sockfd);
}

接收端代码(servers.cpp)


#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>
#include <netdb.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <string>
#include <iostream>
using namespace std;

int main(int argc, char* argv[])
{
    if (argc != 2)
    {
        printf("Using:./server port\nExample:./server 5005\n\n"); return -1;
    }

    // 第1步:创建服务端的socket。
    int listenfd;
    if ((listenfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket"); return -1; }

    // 第2步:把服务端用于通信的地址和端口绑定到socket上。
    struct sockaddr_in servaddr;    // 服务端地址信息的数据结构。
    memset(&servaddr, 0, sizeof(servaddr));
    servaddr.sin_family = AF_INET;  // 协议族,在socket编程中只能是AF_INET。
    servaddr.sin_addr.s_addr = htonl(INADDR_ANY);          // 任意ip地址。
    //servaddr.sin_addr.s_addr = inet_addr("192.168.190.134"); // 指定ip地址。
    servaddr.sin_port = htons(atoi(argv[1]));  // 指定通信端口。
    if (bind(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) != 0)
    {
        perror("bind"); close(listenfd); return -1;
    }

    // 第3步:把socket设置为监听模式。
    if (listen(listenfd, 5) != 0) { perror("listen"); close(listenfd); return -1; }

    // 第4步:接受客户端的连接。
    int  clientfd;                  // 客户端的socket。
    int  socklen = sizeof(struct sockaddr_in); // struct sockaddr_in的大小
    struct sockaddr_in clientaddr;  // 客户端的地址信息。
    clientfd = accept(listenfd, (struct sockaddr*)&clientaddr, (socklen_t*)&socklen);
    printf("client(%s)has connect.\n", inet_ntoa(clientaddr.sin_addr));

    // 第5步:与客户端通信,接收客户端发过来的报文后,回复ok。
    char buffer[100];
    cout << "the receive key is:";
    while (1)
    {
        int iret;
        memset(buffer, 0, sizeof(buffer));
        if ((iret = recv(clientfd, buffer, sizeof(buffer), 0)) <= 0) // 接收客户端的请求报文。
        {
            printf("iret=%d\n", iret); break;
        }
        int i = 0;
        for(i=0;i<100;i++)
        {
            buffer[i] -= 5;
        }
        printf("%s\n", buffer);

        strcpy(buffer, "ok");
        if ((iret = send(clientfd, buffer, strlen(buffer), 0)) <= 0) // 向客户端发送响应结果。
        {
            perror("send"); break;
        }
        printf("cent:%s\n", buffer);
    }

    // 第6步:关闭socket,释放资源。
    close(listenfd); close(clientfd);
}

二:将编写好的代码通过xftp软件传输到两端的虚拟机中。

打开接收端虚拟机运行代码,选择合适的端口,我这里使用的是5001。

 

随后进入等待阶段,等待数据传入。

三:打开发送端虚拟机,同样运行编写好的cpp文件并输入要访问的ip地址和端口

这样就可以输入要传输的密码了。

四:输入密码并传输

 

 这时收到接收端返回的ok说明传输成功。

 

在接收端也可以看见已经被解密的密文。

求赞求赞求赞,日常求赞

 

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

呆呆水獭_(:_」∠)_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值