安全文件传输分析

在main()主函数里:

1、初始化客户端最大连接数。MaxClientNum = InitMaxClientNum();

2、将文件admin.txt(记录管理员的信息)和user.txt(记录用户的信息) 放入Admin[1024] 和 User[1024]数组中以便以后验证管理员和用户的登录信息。

3、管理员登录, 对输入的名字和密码判断是否在已经注册了的admin.txt 文件里。

4、登录成功后创建两个线程:

      第一个线程执行菜单显示的函数mainMenu();

      第二个线程执行主处理函数mainThread();

5、线程池的使用

     先创建一组线程(如20个),每个线程都执行相同的处理函数process(),在process()函数里先执行pthread_cond_wait() 使其所在的线程先等待,等到收到其他线程(mainThread() 所在的线程)发来的唤醒信号pthread_cond_signal() 后开始执行相应的处理功能。当相应的操作结束以后,并不是结束该线程,而是使用goto 语句跳转到pthread_cond_wait()处使该线程继续等待下一个任务的到来,这就实现了线程池。

6、在process()开始执行后先解析从客户端发来的数据包,根据客户端不同的请求作出不同的应答包,并发送给客户端。因此,客户端和服务器要协商好一个数据包格式,是两者用这种格式的数据包来通信。这里定义如下:

struct FilePackage
{
	char cmd;             //操作命令
	int  filesize;        //每次传输数据包大小
	int  ack;               // 标志位
	char username[50];     //客户端用户名
	char filename[125];    //传输文件名
	char buf[1024];        //传输文件的元数据
};

这里的服务器设置为并发服务器,是的多个用户可以同时与服务器通信。

 

你可能感兴趣的:(安全文件传输分析)