void aes_box_encrypt(char* source_string, char* des_string, int size)//负责数据加密

{

int iLoop = 0;

int iLen =0;

char buf[1024];

AES_KEY aes;

unsigned char key[AES_BLOCK_SIZE];

unsigned char iv[AES_BLOCK_SIZE];

if(NULL == source_string || NULL == des_string)

{

return;

}

//Generate own AES Key

for(iLoop = 0; iLoop < 16; iLoop++)

{

key[iLoop] = 32 + iLoop;

}

// Set encryption key

for (iLoop=0; iLoop0)

printf("接收消息成功:'%s',共%d个字节的数据\n", buf, len);

else

printf("消息接收失败!错误代码是%d,错误信息是'%s'\n", errno, strerror(errno));

}

void Directory(char* path, SSL* ssl, struct dirent *ptr)//目录处理

{

char *base = NULL;

base = path;

strcat(ptr->d_name,"/");

char* e = (char*)malloc(strlen(base) + strlen(ptr->d_name) + 1);

strcpy(e,base);

strcat(e,ptr->d_name);

bool ret = readfile(e, ssl, ptr);

}

bool Document(char* Path, SSL *ssl,struct dirent *ptr)//真正发送log文件

{

char a[1024];

int fd = 0;

memset(a,'\0', sizeof(a));

memset(buffer,'\0', sizeof(buffer));

memset(buffer1,'\0', sizeof(buffer1));

strcpy(a, Path);

strcat(a, ptr->d_name);

fd = open(a, O_RDONLY);

read(fd, buffer,sizeof(buffer));//发送两次数据,第一次是文件名,第二次是文件内容

int len1 = SSL_write(ssl, ptr->d_name, strlen(ptr->d_name));

printf("document name is:%s\n", ptr->d_name);

if (len1 <= 0) {

printf("消息'%s'发送失败!错误代码是%d,错误信息是'%s'\n", buffer, errno, strerror(errno));

return false;

}

else

printf("消息发送成功,共发送了%d个字节!\n", len1);

aes_box_encrypt(buffer, buffer1, sizeof(buffer));

int len = SSL_write(ssl, buffer1, strlen(buffer1));

if (len <= 0) {

printf("消息'%s'发送失败!错误代码是%d,错误信息是'%s'\n", buffer, errno, strerror(errno));

return false;

}

else

printf("消息发送成功,共发送了%d个字节!\n", len);

close(fd);

return true;

}

DIR* readFileList(char *basePath)//打开目录,opendir配合readdir使用

{

DIR *dir;

struct dirent *ptr;//readdir

if ((dir=opendir(basePath)) == NULL)

{

printf("Open path error\n");

exit(1);

}

return dir;

}

bool readfile(char* Path,SSL *ssl,struct dirent *ptr)//文件或者目录处理

{

DIR *dir = readFileList(Path);

while ((ptr=readdir(dir)) != NULL)

{

if(strcmp(ptr->d_name,".")==0 || strcmp(ptr->d_name,"..")==0) ///current dir OR parrent dir

continue;

else if(ptr->d_type == 8) //document

{

printf("path is:%s\n",Path);

Document(Path, ssl, ptr);

}

else if(ptr->d_type == 4)//directory

{

Directory(Path, ssl, ptr);

}

}

return true;

}

bool Sendlog(SSL* ssl, char* buf)//发送log文件

{

if(strcmp(buf, "getlog") == 0)

{

struct dirent *ptr;

char *basePath = NULL;

basePath = "./log/";

readfile(basePath, ssl, ptr);

}

Shutdown(ssl);

}

void ShowCerts(SSL * ssl)//验证显示证书

{

X509 *cert;

char *line;

cert = SSL_get_peer_certificate(ssl);

// SSL_get_verify_result()是重点,SSL_CTX_set_verify()只是配置启不启用并没有执行认证,调用该函数才会真证进行证书认证

// 如果验证不通过,那么程序抛出异常中止连接

if(SSL_get_verify_result(ssl) == X509_V_OK){

printf("证书验证通过\n");

}

if (cert != NULL) {

printf("数字证书信息:\n");

line = X509_NAME_oneline(X509_get_subject_name(cert), 0, 0);

printf("证书: %s\n", line);

free(line);

line = X509_NAME_oneline(X509_get_issuer_name(cert), 0, 0);

printf("颁发者: %s\n", line);

free(line);

X509_free(cert);

}

else

printf("无证书信息!\n");

}

linux 文件 加密传输,服务端和客户端之文件加密传输相关推荐

  1. linux远程日志rsyslog服务端和客户端安装(亲测)--自定义接收日志格式

    linux远程日志rsyslog服务端和客户端安装 用rsyslog的缘由:  1.防止系统崩溃无法获取系统日志分享崩溃原因,用rsyslog可以把日志传输到远程的日志服务器上  2.使用rsyslo ...

  2. 服务端和客户端之文件加密传输

    1.前言 1.1 why? 闲来无事,自己研究了一下服务端与客户端之间的文件传输,主要是服务端创建套接字开启监听并等待客户端的连接(TCP),在TCP协议上,为了安全我使用了TLS1.2进行加密通信( ...

  3. LINUX环境下VNC服务端与客户端配置

    公司开发原来都是用的Xmanager软件,但近期爆出该软件存在后门漏洞问题,安防部门要求停止使用老版本的Xmanager进行升级或改用开源VNC软件,因此在网上查看了一些配置说明,特整理如下: VNC ...

  4. Java服务端向客户端写文件_java实现客户端向服务器发送文件

    本文实例为大家分享了java实现客户端向服务器发送文件的具体代码,供大家参考,具体内容如下 服务器源代码: import java.io.BufferedReader; import java.io. ...

  5. 二阶段补充:文件上传服务端处理,后端文件上传、前端两种文件上传方式

    1.文件上传 2.后端文件上传 两种方案: 兼容性较好的commons-fileupload,支持所有版本的Servlet,即所有版本的Tomcat 优点: 兼容性 缺点 需要外部jar,比较麻烦.代 ...

  6. linux syslog日志转发服务端、客户端配置

    syslog服务器 1.#开启远程UDP模块 sed -ri "s/^#(.*imudp)/\1/" /etc/rsyslog.conf sed -ri "s/^#(.* ...

  7. Java中Socket通信-服务端和客户端双向传输字符串实现

    场景 什么是socket 在计算机通信领域,socket 被翻译为"套接字",它是计算机之间进行通信的一种约定或一种方式.通过 socket 这种约定,一台计算机可以接收其他计算机 ...

  8. 使用C++的Socket实现从客户端到服务端,服务端到客户端传输文件

    使用: (1)首先运行服务端,待服务端运行起来: (2)最后运行客户端,输入要传输文件到哪个目标机器的IP地址: (3)输入传输文件的路径及文件(完成的路径),其中包含文件的类型,也就是后缀需要包含( ...

  9. C# Socket服务端与客户端通信(包含大文件的断点传输)

    步骤: 一.服务端的建立 1.服务端的项目建立以及页面布局 2.各功能按键的事件代码 1)传输类型说明以及全局变量 2)Socket通信服务端具体步骤:   (1)建立一个Socket   (2)接收 ...

最新文章

  1. HDU1217(Bellman-ford和Floyd两种算法)
  2. Idea快速生成War包
  3. bugku web基础$_POST
  4. 解决Nacos无法连接Mysql8.0+的问题(坑爹的阿里官方文档,已无力吐槽)
  5. CISCO路由器、交换机密码恢复
  6. 2021-08-13servlet 原理及注意事项
  7. B站粉丝数显示器,播放数、获赞数失效解决。
  8. Flash 原版官网下载
  9. RL Python练习
  10. 植物大战僵尸阳光修改
  11. 游戏开发记录--敌人追寻玩家
  12. 从外包公司到今日头条offer,帮你突破瓶颈
  13. 【19周-星耀】FASTER!FASTER!FASTER!
  14. freeipa证书相关的一些命令
  15. java cookie设置注意事项
  16. 制作多维度分组交叉销售统计表
  17. 黑苹果NVIDIA显卡驱动程序【WebDriver-378.05.05.25f16 +支持 macOS 10.12.6 Sierra (16G2016)版本】
  18. 离散数学班委竞选代码实现
  19. iOS仿写有妖气漫画、视频捕获框架、启动页广告页demo、多种动画效果等源码
  20. 用U盘重装Win7系统方法

热门文章

  1. python字符串三种常用的方法或函数_python中字符串常用的函数
  2. python 多层包多模块_python Modules模块操作
  3. 通俗易懂,嵌入式Linux驱动基础
  4. 生日快乐程序_祝肖战1005生日快乐-用R给他画个蛋糕爱心吧
  5. android申请权限一次性申请多个,Android 批量申请权限
  6. Mac OS上用item2连接CentOS7
  7. CTF刷题网站汇总(包括本地可以自己搭建的)(1)
  8. SecureCRT 设置和修改
  9. Java线程池理解及用法
  10. JQuery快速入门-选择器