linux 文件 加密传输,服务端和客户端之文件加密传输
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 文件 加密传输,服务端和客户端之文件加密传输相关推荐
- linux远程日志rsyslog服务端和客户端安装(亲测)--自定义接收日志格式
linux远程日志rsyslog服务端和客户端安装 用rsyslog的缘由: 1.防止系统崩溃无法获取系统日志分享崩溃原因,用rsyslog可以把日志传输到远程的日志服务器上 2.使用rsyslo ...
- 服务端和客户端之文件加密传输
1.前言 1.1 why? 闲来无事,自己研究了一下服务端与客户端之间的文件传输,主要是服务端创建套接字开启监听并等待客户端的连接(TCP),在TCP协议上,为了安全我使用了TLS1.2进行加密通信( ...
- LINUX环境下VNC服务端与客户端配置
公司开发原来都是用的Xmanager软件,但近期爆出该软件存在后门漏洞问题,安防部门要求停止使用老版本的Xmanager进行升级或改用开源VNC软件,因此在网上查看了一些配置说明,特整理如下: VNC ...
- Java服务端向客户端写文件_java实现客户端向服务器发送文件
本文实例为大家分享了java实现客户端向服务器发送文件的具体代码,供大家参考,具体内容如下 服务器源代码: import java.io.BufferedReader; import java.io. ...
- 二阶段补充:文件上传服务端处理,后端文件上传、前端两种文件上传方式
1.文件上传 2.后端文件上传 两种方案: 兼容性较好的commons-fileupload,支持所有版本的Servlet,即所有版本的Tomcat 优点: 兼容性 缺点 需要外部jar,比较麻烦.代 ...
- linux syslog日志转发服务端、客户端配置
syslog服务器 1.#开启远程UDP模块 sed -ri "s/^#(.*imudp)/\1/" /etc/rsyslog.conf sed -ri "s/^#(.* ...
- Java中Socket通信-服务端和客户端双向传输字符串实现
场景 什么是socket 在计算机通信领域,socket 被翻译为"套接字",它是计算机之间进行通信的一种约定或一种方式.通过 socket 这种约定,一台计算机可以接收其他计算机 ...
- 使用C++的Socket实现从客户端到服务端,服务端到客户端传输文件
使用: (1)首先运行服务端,待服务端运行起来: (2)最后运行客户端,输入要传输文件到哪个目标机器的IP地址: (3)输入传输文件的路径及文件(完成的路径),其中包含文件的类型,也就是后缀需要包含( ...
- C# Socket服务端与客户端通信(包含大文件的断点传输)
步骤: 一.服务端的建立 1.服务端的项目建立以及页面布局 2.各功能按键的事件代码 1)传输类型说明以及全局变量 2)Socket通信服务端具体步骤: (1)建立一个Socket (2)接收 ...
最新文章
- HDU1217(Bellman-ford和Floyd两种算法)
- Idea快速生成War包
- bugku web基础$_POST
- 解决Nacos无法连接Mysql8.0+的问题(坑爹的阿里官方文档,已无力吐槽)
- CISCO路由器、交换机密码恢复
- 2021-08-13servlet 原理及注意事项
- B站粉丝数显示器,播放数、获赞数失效解决。
- Flash 原版官网下载
- RL Python练习
- 植物大战僵尸阳光修改
- 游戏开发记录--敌人追寻玩家
- 从外包公司到今日头条offer,帮你突破瓶颈
- 【19周-星耀】FASTER!FASTER!FASTER!
- freeipa证书相关的一些命令
- java cookie设置注意事项
- 制作多维度分组交叉销售统计表
- 黑苹果NVIDIA显卡驱动程序【WebDriver-378.05.05.25f16 +支持	macOS 10.12.6 Sierra (16G2016)版本】
- 离散数学班委竞选代码实现
- iOS仿写有妖气漫画、视频捕获框架、启动页广告页demo、多种动画效果等源码
- 用U盘重装Win7系统方法