《面向对象课程设计人才招聘网站的设计与实现.doc》由会员分享,可在线阅读,更多相关《面向对象课程设计人才招聘网站的设计与实现.doc(26页珍藏版)》请在三一办公上搜索。
1、*实践教学* 兰州理工大学计算机与通信学院2011年秋季学期面向对象课程设计题 目:人才招聘网站的设计与实现专业班级: 姓 名: 学 号: 指导教师: 成 绩: 目 录摘要2第1章 绪论3 1.1课题的背. 4 1.2系统设计思想5第2章 需求分析. .6 2.1 系统基本情况描述6 2.2 系统流程图 7第3章 系统设计.8 3.1 系统功能模块设计.8 3.2 调试分析.9总结与体会.11致谢12参考文献13附录 源程序.14摘 要现今,由于社会对学术、技术要求的提高以及教育改革、高等学校年年扩招等原因,大学毕业生已经远离了毕业“包分配”、“不愁嫁”的日子。由此,找工作的方式在二十一世纪也
2、发生着丰富的变化,相对于漫无目的的四处寻找用人单位和奋战于拥挤的各种大型招聘会,网络人才与招聘系统能提供最及时、最丰富的招聘信息。通过该题目的设计、开发,使学生初步得到数据库开发的训练,全面培养软件开发过程中的分析、设计、编码、测试及文档规范书写的能力,得到软件开发的综合训练,提高解决实际问的能力。关键字:人才招聘;信息管理;系统分析绪 论1.1 课题背景人才招聘网站的设计和实现系统是用于招聘人员和业务管理的计算机信息系统,系统包括宏观决策和业务管理两个部分,服务对象包括工作单位、招聘人员和其所担任的职务。人才招聘网站系统服从于人员信息管理的总体规划,系统建设坚持一体化的设计思想,与就业服务系
3、统、医疗保险系统、失业保险系统等统一标准,协调建设。随着我国信息管理制度改革的进一步深入,特别一些大型企业和公司,业务量急剧增长,管理日趋完善。一些地区建立了计算机信息管理系统,对于深化改革、规范管理、提高业务工作效率等产生了积极的促进作用。目前已有相当一部分城市开始使用计算机进行前台业务处理,一些较发达的城市实现了全市联网。但由于各地的经济状况不同,系统建设的规模、水平差异也较大。系统建设面临的主要问题有:现有的信息系统已无法更好地满足业务处理和管理决策的更高要求;缺乏各个行业应有的标准和指导信息,有时候建设的信息系统,不能更好及时的将一些最新信息展现给人才消费者,这从一定程度上造成硬件和系
4、统软件的浪费,应用软件重复开发现象比较普遍,网络互联困难;缺乏组织与人员保证,这种状况严重制约着各地信息系统建设和发展。 qFSOUXb 随着每个企业公司体系中所包含的内容、层次、范围和目标日趋扩大和复杂化,工作量和数据处理量将呈现大幅度的增长趋势,公司管理部门所承担的管理工作变得越来越繁重,特别是实行个人帐户管理以后,不仅管理数据成倍增长,而且每笔数据都涉及到职工和单位的实际利益,不允许有半点差错。一个完善的系统或手工操作方式将实现新形式下的招聘工作目标,确保招聘工作的顺利进行和人员信息的管理。1.2 系统设计思想人才招聘网站系统服从于公司和企业信息管理系统的总体规划,系统建设坚持一体化的设
5、计思想,结合着国家政策和对息系统建设的规定进行实施。本系统按以下原则进行:(1)实用性:人才招聘网站系统作为应用系统,以满信息管理工作的业务需求为首要目标,避免盲目追求最新技术。(2)可靠性:采用稳定可靠的成熟技术,保证系统长期安全运行。系统中的硬、软件及信息资源要满足可靠性设计要求。(3)先进性:在实用性的前提下,尽可能跟踪国内外先进的计算机硬软件技术、信息技术及网络通信技术,使系统具有较高的性能价格比。采用先进的体系结构和技术发展的主流产品,保证整个系统高效运行。(4)开放性:技术上立足于长远发展,坚持选用开放性系统。(5)安全性:遵循有关信息安全标准,具有必要的安全保护和保密措施,以及对
6、计算机犯罪和病毒的防范能力,确保数据永久安全。(6)可扩充性:应充分考虑到联网用户增加和业务扩展的情况,留有必要的扩充能力及接口。(7)可维护性:应用软件开发的模块化程度高,对不同的管理方式的适应能力强,软件维护方便。(8)易操作性:贯彻面向最终用户的原则,建立友好的用户界面,操作简单,直观灵活,易于学习掌握。在人才招聘网站系统中,数据库无疑是其核心部分。由于该系统具有一定的复杂性,这就必然要求数据库在数据的提交、管理等方面能够充分满足实际业务的处理需求,因此对数据库的选择提出了下列严格的要求: |pej jfv !K| (1)可靠性。在保障可用性基础上,考虑到系统运行的环境比较复杂,处理量巨
7、大,所以必须保证系统核心数据库的稳定、可靠、安全运行,以提高整个系统的抗干扰能力。 uh4F4 3a=3WG (2)安全性:对于不宜公开的信息,必须能够通过数据库设定安全等级和查阅权限,并在数据库中对重要数据进行加密存储,以保证数据的安全性。而且数据库还必须提供方便的数据备份功能。以减轻系统维护人员的工作量。 tI3gG 第2章 需求分析2.1 系统基本情况描述人才招聘网站系统是以招聘单位的业务为背景,通过调研、分析现有的管理模式和已有的管理软件,建立系统模型,以实际为基础进行设计的。该系统属于B/S结构,B/S结构的主要特点是分布性强、维护方便、开发简单且共享性强、总体拥有成本低。用户通过浏
8、览器向分布在网络上的许多服务器发出请求,服务器对浏览器的请求进行处理,将用户所需信息返回到浏览器。数据请求、加工、结果返回以及动态网页生成、对数据库的访问和应用程序的执行等工作全部由Web Server完成。该系统包括六大模块:招聘者档案管理、招聘职位管理、信息查询、报表统计和打印、系统维护。2.2 系统流程图系统流程图是用图形的方式表现出招聘者和企业公司相互了解时的业务处理流程,具体图示如下系统流程图。职位发布简历管理首页删除用户修改用户信息用户信息增加用户用户列表用户管理预览试题删除列表修改列表增加试题试题详细信息试题列表工作取向问卷价值取向问卷删除答案增加答案题目详细信息查询试题删除试题
9、增加试题题目列表题库管理查看试卷答案应聘者申请表面试完成等待面试未发通知应聘者列表职位列表面试管理回复信息打印简历查看试卷答案应聘者申请表应聘者列表职位列表简历管理删除职位停止招聘修改职位增加职位职位详细信息查询职位职位列表职位发布用户管理知识库管理面试管理问卷管理第3章 系统设计3.1 系统功能模块设计系统功能:1.新闻系统:添加、修改、删除文章、文章置顶、Flash文章系统。2.投票系统:添加、修改、删除投票。3.求职系统:个人会员注册后可以修改自己的基本资料、添加、修改、删除、管理求职信息信息、投递简历、收藏企业、接收企业的招聘信息等。4.招聘系统:企业注册后可修改基本资料、添加、修改、
10、删除、管理企业招聘信息、接收个人的求职简历、收藏个人信息、财务明细、点卡充值、发布管理猎头信息等。5.广告系统:支持矩形横幅 、弹出窗口 、随屏移动、固定位置、漂浮移动、文字代码,同时支持JPG、SWF、GIF、文本、代码和页面,并自动生成JS代码文件。6.后台系统:管理企业、个人的求职(招聘)信息、基本资料信息、新闻系统、投票系统、友情链接管理、数据库管理等7.管理员功能:1、)系统设置:基本信息设置,经营信息设置,地区设置,行业设置,企业套餐4、)界面设置:选择模板,当前模板库管理,数据调用。设置,企业审核设置,首页幻灯管理,友情连接管理,安全管理。2、)数据管理:求职者管理,企业管理,职
11、位管理,广告管理。3、)资讯管理:资讯类型管理,资讯管理。5、)系统管理:管理员管理,静态页面从新生成,修改密码。3.2 调试分析1.招聘系统登录界面 2.会员信息管理3.在线求职招聘信息4.信息验证总结与体会:在这次的课程设计过程中,我们学到的不仅是知识,我们还认识到许多事情。这次设计使我的编程水平提高了一大步,使我充分的认识到合作的可贵。由于这次设计主要涉及到数据结构中的链表结构,我们学到了学到了不少关于数据链表的知识,对链表的操作有了进一步的了解。这次设计对我的综合能力是一次很好的锻炼,但是我必须承认自己的能力和知识还很肤浅。所以今后我的学习道路还是很漫长的。最后,在这里由于我们水平有限
12、,加之时间短暂,故人才招聘网站的设计和实现系统中还有许多不足之处,请老师批评指正,我会在以后的制作中不断改进,不断完善。致谢:本人在此向所有关心我们的及帮助我们的老师和同学们致以最真诚的感谢。在本次毕业设计中,我从指导老师-*老师身上学到了很多东西。他认真负责的工作态度,严谨的治学精神和深厚的理论水平都使我收益匪浅。他无论在理论上还是在实践中,都给与我们很大的帮助,使我们得到很大的提高,这对于我们以后的工作和学习都有一种巨大的帮助,在此感谢他耐心的辅导。总之,我们有了这么一个机会来检验我们自己的学习成果及学习能力。在李老师的指点下,我的人才招聘网站的设计和实现系统的设计就清楚了很多,并最终顺利
13、的设计好了。参考文献1初小璐完全掌握SQL Server 2000 M 机械工业出版社,20042Jeraod V.Post.数据库管理系统(英文版.第三版)美清华大学出版社,2006.13张海藩.软件工程导论M.北京:清华大学出版社,1998.14谢希仁.计算机网络(第二版)M.北京:电子工业出版社,2003.6 5戴志诚,赵国峰.JSP信息化系统建设案例M.北京:人民邮电出版社,2006.126成晓静,毕靖.网页设计三剑客完全学习手册M.北京:中国电力出版社,2004.117赵强.精通JSP编程M.北京:电子工业出版社,2006.38萨师煊,王珊.数据库系统概论M.北京:高等教育出版社,2
14、002.29张海藩,李劲,谢兆阳.SQL Server2000数据库设计与系统管理M.北京:清华大学出版社,2000.910刘禾,蔡锋.Web数据库假设技巧M.北京:科技技术出版社,1999.411徐建波. Internet与Web设计教程M.北京:中国矿业大学出版社,2000.1212于书举,许向众.数据库设计与开发教程M.北京:电子工业出版社,2003.1113安海忠,李文斌,林旭新.商业网站建设与管理M.北京:人民交通出版社,2006.814T.Umeda and S.Hagiwara.web-based database for EPR centers in semiconductor
15、sJ.BPhysica B:Condensed Matter,3(7),249-252,2006.315Yih-Ling Hedley,Muhammad Younas.Sampling,information extraction and summarisation of Hidden Web databasesJ.Data & Knowledge Engineering,In Press,Uncorrected Proof,Available online 10 March 2006.2源程序#include #include #include #include #include using
16、 namespace std;public class DBConnect private Statement stmt=null; private ResultSet rs=null; public DBConnect()tryClass.forName(com.microsoft.jdbc.sqlserver.SQLServerDriver); catch(java.lang.ClassNotFoundException e)System.err.println(opendb():+e.getMessage(); public ArrayList executeQuery(SQLServe
17、rDataSource source,String strSql) throws SQLException Connection con=null; rs=null; ArrayList ArrayRs=new ArrayList(); try con=source.getConnection(); stmt=con.createStatement(); rs=stmt.executeQuery(strSql); ResultSetMetaData rsmd=rs.getMetaData(); int numberOfColumns = rsmd.getColumnCount(); if(!A
18、rrayRs.isEmpty() ArrayRs.clear(); while(rs.next() ArrayList arrlist1=new ArrayList(); for(int j=1;j0) mit(); else con.rollback(); catch(Exception e) System.out.println(update error:+e.getMessage(); finally if (stmt != null) stmt.close(); if (con != null&!con.isClosed() con.close(); return j; public
19、int executeDelete(SQLServerDataSource source,String strSql) throws SQLExceptionConnection con=null; rs=null;int j=0; try con=source.getConnection(); stmt=con.createStatement(); con.setAutoCommit(false); j=stmt.executeUpdate(strSql); if(j0) mit(); con.rollback(); catch(Exception e) System.out.println
20、(Delete error:+e.getMessage(); finally if (stmt != null) stmt.close(); if (con != null&!con.isClosed() con.close(); return j; import org.apache.struts.action.ActionErrors;import org.apache.struts.action.ActionForm;import org.apache.struts.action.ActionMapping;public class SubmitAnswerForm extends Ac
21、tionForm / - Instance Variables/* 职位名称 */private String JobName;/* 职位发布日期 */private String PubDate;/* 职位发布结束日期 */private String EndDate;/* 职位描述 */private String Description;/* 职位要求 */private String Requirements;/* 招聘人数 */private int JobNum;/ - Methodspublic ActionErrors validate(ActionMapping mappin
22、g,HttpServletRequest request) 。public void reset(ActionMapping mapping, HttpServletRequest request) 。public String getJobName() return JobName;/* * 赋值 JobName. * */public void setJobName(String JobName) this.JobName = JobName;/* * 返回 PubDate. * */public String getPubDate() return PubDate;/* * 赋值 Pub
23、Date. * */public void setPubDate(String PubDate) this.PubDate = PubDate;/* * 返回 EndDate. * */public String getEndDate() return EndDate;/* * 赋值 EndDate. * */public void setPubDate(String EndDate) this.EndDate = EndDate;public String getDescription() return Description;/* * 赋值 Description. * */public
24、void setDescription(String Description) this.Description = Description;/* * 返回 Requirements. * */public String getRequirements() return Requirements;/* * 赋值 Requirements. * */public void setRequirements(String Requirements) this.Requirements = Requirements;/* * 返回 JobNum. * */public int getJobNum()
25、return JobNum;/* * 赋值 JobNum.public void setJobNum(int JobNum) this.JobNum = JobNum;public ActionForward execute(ActionMapping mapping, ActionForm form,HttpServletRequest request,HttpServletResponse response) / 获取新增加的职位信息DynaActionForm AddJobForm = (DynaActionForm) form;String JobName = (String) Add
26、JobForm.get(JobName);String PubDate = (String) AddJobForm.get(PubDate);String EndDate = (String) AddJobForm.get(EndDate);String Description = (String) AddJobForm.get(Description);String Requirements = (String) AddJobForm.get(Requirements);Integer JobNum=(Integer)AddJobForm.get(JobNum);HttpSession se
27、ssion = request.getSession();Vector JobList = new Vector();ServletContext context = servlet.getServletContext();DataSource dataSource = (DataSource) context.getAttribute(Constants.DATASOURCE_KEY);DB db = new DB(dataSource);/ 将职位基本信息封装到员工类型的对象try Job job = new Job();job.setJobName(JobName);job.setPub
28、Date(PubDate);job.setEndDate(EndDate);job.setDescription(Description);job.setRequirements(Requirements);job.setJobNum(JobNum.intValue();/ 将增加的职位信息加入到对应的数据库if (job.addJob(db,JobName,PubDate,EndDate,Description,Requirements,JobNum.intValue()db.close(); catch (Exception e) e.printStackTrace();return (m
29、apping.findForward(toaddjob);public class Job / 与职位信息相关的基本属性和方法public int JobID;public int JobNum;public String JobName;public String PubDate;public String EndDate;public String Description;public String Requirements;public Job() public String getDescription() return Description;public void setDescr
30、iption(String Description) this.Description = Description;public String getEndDate() return EndDate;public void setEndDate(String EndDate) this.EndDate = EndDate;public int getJobID() return JobID;public void setJobID(int JobID) this.JobID = JobID;public String getJobName() return JobName;public voi
31、d setJobName(String JobName) this.JobName = JobName;待添加的隐藏文字内容3/ 职位招聘人数public int getJobNum() return JobNum;public void setJobNum(int JobNum) this.JobNum = JobNum;/ 职位发布日期public String getPubDate() return PubDate;public void setPubDate(String PubDate) this.PubDate = PubDate;/ 职位要求属性public String get
32、Requirements() return Requirements;public void setRequirements(String Requirements) this.Requirements = Requirements;public static Vector jobSearch(DB db, String JobName, String PubDate, String EndDate) throws Exception Vector JobList = new Vector();ResultSet rs;String strSql = null;strSql = select
33、* from JobList where JobName like % + JobName + %+ and PubDate like % + PubDate + %+ and EndDate like % + EndDate + %;rs = db.OpenSql(strSql);while (rs.next() Job job = new Job();job.setJobID(rs.getInt(JobID);job.setJobName(rs.getString(JobName);job.setPubDate(rs.getString(PubDate);job.setEndDate(rs.getString(EndDate);job.setDescription(rs.getString(Description);job.setRequirements(rs.getString(Requirements);job.setJobNum(rs.getInt(JobNum);JobList.add(job);System.out.println(nnnnnnnnnn,+rs.getString(JobName);return JobList;public static Vector getJobList(DB db)throws Exception