##项目名称:校招助手
######使用技术:
CGI技术、socket编程
######开发环境:
Linux,C ,vim,gcc,gdb
######代码地址:
https://gitee.com/zhoudandandandanzhou/review/tree/master/6_http
######网络传输协议:
TCP
###功能介绍:
主要面向找工作的人群,目的在对用户的申请职位信息做备份和管理的功能
用户注册登录之后,可以添加申请职位情况,其中包含公司名称,职位名称,申请时间,备注
我们以表格是形式向用户展示申请职位详情,当某条申请情况进度变化的时候,用户可以进行修改或删除该条申请信息
###服务器框架整体设计思想:
采用多线程处理多个用户的请求
根据用户的请求可以区分出GET请求和POST请求。
对于不带参数的GET请求,解析出资源路径后直接返回要访问的页面,解析错误返回404。
对于GET请求带参数的和POST请求都交给CGI程序处理:
创建匿名管道,用于父子进程之间通信
创建子进程,标准输入输出重定向(因为CGI程序对语言的要求比较低),修改环境变量,给CGI程序提供参数。
子进程进行程序替换后,CGI程序完成相应的业务逻辑处理,将结果通过管道传给父进程
父进程构造相应,返回给客户端
###CGI处理业务部分
新用户先进行注册,注册成功之后,每次需要在数据库中进行查询该用户名和密码是正确
当登录成功之后,用户就可以进行添加自己的申请信息了
因为每个公司一般只能申请一个岗位,每次添加信息时需要查询是否已经存在
当添加信息成功之后,可以选择继续添加信息,或者返回查看自己的信息
当用户的申请进度有变化时,可以在自己的信息表上进行修改和删除
####数据库部分:
一张user表用来存储用户个人信息
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| user | CREATE TABLE `user` (
`name` varchar(32) NOT NULL,
`password` varchar(64) NOT NULL,
PRIMARY KEY (`name`)
) ENGINE=MyISAM AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 |
+-------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------+
一张info表用来存储用户的申请职位信息
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table |
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| info | CREATE TABLE `info` (
`user_name` varchar(64) NOT NULL DEFAULT '',
`company_name` varchar(128) NOT NULL DEFAULT '',
`job` varchar(128) DEFAULT NULL,
`date` text,
`status` text,
PRIMARY KEY (`user_name`,`company_name`)
) ENGINE=MyISAM AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 |
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
功能展示
http://139.224.135.126:9094/job_info/index/index.html
测试部分:
对项目进行功能测试、性能测试、界面测试、安全性测试、易用性测试、兼容性测试
涵盖正常情况和异常情况
使用 gtest 单元测试框架对代码进行单元测试
使用 loadrunner 对项目进行性能测试,对用户进行登录注册事件,添加申请信息事件进行测试
涵盖负载测试、压力测试、并发测试、可靠性测试、大数据量测试
分析测试结果中的点击率,事务响应时间,吞吐量等性能指标。
######项目总结:
在实现过程中自己更加理解了GET请求和POST请求的特点和使用场景,对TCP协议有了更深层次的了解,掌握错误码的应用。
对编写多线程程序更加熟练,对程序替换的原理和应用也更加熟练
对数据库的基本操作更加熟练
通过一个项目,使自己更加体会到软件的生命周期的整个过程,各个阶段可能会出现不同的问题,需要将一些零零散散的知识点串起来。
附加我自己爬取对面学校的就业信息部分
http://139.224.135.126:9094/job/file/1.html