【精品】通用在线问卷调查系统的设计与实现_毕业论文设计
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
计算机系本科毕业(设计)论文
课题名称通用在线问卷调查
系统的设计与实现
专业计算机科学与技术
姓名
学号
指导教师
二零一零年六月
目录
1 引言 (2)
1.1开发背景及研究意义 (2)
1.2系统简介 (2)
1.3系统开发环境 (2)
2 需求分析 (4)
2.1用户需求描述 (4)
2.2技术可行性分析 (4)
2.3系统功能需求分析 (5)
3 系统设计 (7)
3.1系统功能设计 (7)
3.2数据库设计 (7)
4 系统实现 (12)
4.1注册登录模块的实现 (12)
4.2问卷调查模块的实现 (13)
4.3用户管理模块的实现 (14)
4.4问卷管理模块的实现 (15)
4.5问卷结果分析模块的实现 (16)
5 系统测试与维护 (18)
5.1系统测试 (18)
5.2系统维护 (19)
6 结束语 (20)
致谢 (21)
参考文献 (22)
通用在线问卷调查系统的设计与实现
摘要:随着社会和网络技术的发展,很多行业需要掌握大量的信息来了解特定的用户需求,但传统的纸制问卷调查具有片面性和局限性,而国内外较为流行的统计软件如SPSS,SAS 等,虽然具有较强的统计输出功能,但需要大量的人工操作,同时需要较深的软件相关知识,不能满足调查者需要。
为了改变这一现象,本人主要运用软件工程的指导方法,选用B/S(Broswer/Server)模式设计的方案,采用Access 2003作为数据库,使用ASP技术在Dreamwaver软件上开发出了通用在线问卷调查系统,使用该系统用户可以进行问卷浏览、问卷做答并提交等操作,管理员则可以根据调研人员的需求添加问卷,管理问卷,查看问卷统计结果,同时可以对用户进行管理,并通过设置登录控制权限以确保答卷信息的真实性和可信度 ,进而获得有参考价值的统计信息。
在线调查的通用性、开放性、方便性和灵活性,使调研人员可以足不出户就能进行相关领域的问卷调查,且不受调查地点的限制,同时也减轻被访者的答题负担,使数据的回收更及时,进而有效降低调研方面的成本和人力投入。
关键词:ASP问卷调查数据统计
Abstract:With the development of society and networking technologies, many industries need to command a lot of information to understand the specific users ' requirements.However,the traditional paper questionnaire is equipped with partiality and limitations, and there are more popular at home and abroad statistical software such as SPSS, SAS, etc. It has strong function with the statistical output, but needs significant manual operations ,simultaneously requires a deep knowledge of the software related .Consequently it can not meet the needs of investigators.In order to change this phenomenon, mainly utilizing the guiding methods of software engineering, selecting B / S (Broswer / Server)the pattern scenarios, adopting Access 2003 as a database, using ASP technology develop auniversal online survey system on the Dreamwaver software. Users who make use of the system can browse online questionnaiers,and submit the questionnaire results and do other operations.Meanwhile ,according to the needs of research staff , administrator can not only add questionnaires and manage the questionnaires, but also can view the statistical results. Besides the related information of users can also be managed by administrator, and control by setting the registry permissions in order to ensure the authenticity and
credibility of information of respondents, which was a reference value of thestatistics. Online survey of universality, openness, convenience and flexibility,enable researchers staying at home to go to the relevant field investigation.Moreover survey sites are not limited.Therefore it not only reduce the burden of the respondents answer, but also the recovery of the data is more timely.Further it reduce the cost of research and human investment. Keywords:ASP Questionnaire Survey Data Statistic
1 引言
1.1 开发背景及研究意义
当今世界,科学技术飞速发展,我国又大力提倡自主创新来加强国家竞争力,网络是伴随这一时代主题而产生的技术产物,并向社会生活的各个领域扩展。
互联网的全球覆盖、交互功能等特性给调查方法带来新的变化,传统的问卷调查以书面提出问题的方式向社会搜集资料,这种方式存在着回收难,成本高,覆盖范围小等局限性,且国内外较为流行的统计软件如SPSS,SAS等,虽然具有较强的统计输出功能,但需要大量的人工操作,同时需要较深的软件相关知识,不能满足调查者需要。
随着互联网的不断普及,使在线问卷调查迅速发展,在线调查的通用性、方便性和高效性,帮助企业或研究人员有效降低调研方面的成本和人力投入。
在线调查作为一种基于互联网平台上产生的回收信息的"快招",越来越受到许多评估研究机构和教育机构的关注、运用。
本次设计的通用问卷调查系统对问卷调查系统进行了计算机化和网络化,是一种现代化的统计方法,具有传统手工调查无可比拟的优势。
调查的整个过程高度自动化,提高了问卷调查的灵活性和调查的效率,它的应用不受时间和地域限制,统计结果具有客观性,在各行各业尤其是教育领域具有一定的应用价值。
1.2系统简介
本系统将采用Browser/Server模式设计开发,主要将包括以下模块:注册登录模块、问卷调查模块、问卷管理模块、问卷结果统计模块、用户管理模块等。
该系统的用户权限将分为两种:普通用户和管理员。
普通用户注册后只能
在前台进行一些简单的操作,比如:访问问卷、进行答题并提交等;管理员则可以对用户和管理员信息进行更新,并能对问卷及题目进行添加、删除和修改。
1.3 系统开发环境
硬件环境:①486以上微机一台,主频至少2.0G;②内存256M以上;③显卡:TNT2显示适配器;④硬盘80G以上。
软件环境:Microsoft Windows XP操作系统;Microsoft access 2003数据库软件;Dreamweaver 8[4]应用软件;Photoshop CS[14]进行图片处理软件。
2 需求分析
需求分析是软件生存周期中相当重要的一个阶段,需求分析的主要任务就是确定待开发软件的功能、性能、数据、界面等要求,在参阅、了解了相关问卷调查系统的特点和要求,并对问卷调查做了相应的调研后,本系统的总体目标是提高调查者问卷调查的灵活性和调查的效率。
2.1用户需求描述
问卷调查作为一般人所熟悉的一种调查方式,用以了解目标对象的想法。
但传统的纸制问卷调查具有片面性和局限性,而国内外较为流行的统计软件如SPSS,SAS 等,虽然具有较强的统计输出功能,但需要大量的人工操作,同时需要较深的软件相关知识,不能满足调查者需要。
为了更好地帮助调查者获取市场信息、客户信息,进而开发通用在线问卷调查系统,通过在线数据收集,利用计算机对数据进行处理和统计。
本系统要求有管理员和普通用户两种权限,管理员应能随意设定问卷的标题名称,题目及题目选项,并可以对问卷和题目进行管理,能保存相应的调查结果并能对数据进行统计,同时可以对用户的身份及其基本信息、登录控制权限等进行管理,以确保答卷信息的真实性和可信度,进而能获得有参考价值的统计信息。
用户要能进行问卷的访问、答题并提交等操作。
要求系统要简洁明了,方便实用,交互性好,尽可能使其结构化、标准化、界面美观大方等。
2.2技术可行性分析
ASP是Active Server Pages的缩写,是Microsoft公司开发的Web服务器端脚本开发环境,利用它可以与Access数据库和其它程序进行交互,从而生成动态、高效的Web应用程序[1]。
ASP使用了微软公司的ActiveX技术,封装了一些常用的组件,这些组件可以是网页的内容活动起来,这是ASP页面与传统的HTML网页的最大区别。
Access是美国Microsoft公司发布的Office软件包中的关系型数据库软件。
它具有功能灵活、易学易用、开发简单等特点,拥有广泛的用户群体[9]。
Access 是开发单机小型数据库应用系统的理想工具,可以独立开发数据库应用系统,也可以作为后台数据库与ASP等语言结合使用。
ASP和Access的完美结合可使本网站变得栩栩如生,具体表现在以下两个
方面:
1、交互性:网站管理员会根据用户的要求和选择动态地改变和响应,使用户随时可以看到界面友好的网站。
2、自动更新:无须手动的更新HTML文档,便会自动生成新的页面,可以大大节省工作量。
2.3 系统功能需求分析
通过对通用在线问卷调查系统的应用情况作全面的、详细的调查,收集关于本系统涉及的一些数据资料,基本上确定了本次系统设计和实现的目的,明确了设计本次系统的目标。
本系统是通用的在线问卷调查系统,所以应该可以有多个主题同时进行发布调查而互不干扰,且能够对问卷进行更新并可根据需要制定调查问卷的回答方式(如单选、多选、文本填空等),因此该系统应具有通用性、开放性、方便性和灵活性,其主要实现的功能应该体现在以下方面:
1、用户注册登录:为了实现系统的安全性和保密性,所以本次系统的设计应满足管理者和用户两方面的使用权限。
用户输入用户名、密码、姓名、性别、年龄、单位、职业、邮箱等信息进行注册,注册后需要管理员审核,审核通过才能在系统登录页面进行登录。
登录的时候进行用户名和密码的判断,用户名和密码匹配才能进入系统。
2、用户浏览问卷:合法用户通过系统首页的登录界面,输入用户名和密码进入系统主页,在系统主页上面可以看到所列问卷,打开问卷,这样就可以进行问卷的浏览、填写与提交等操作。
3、系统后台管理:系统后台管理共分为三个部分的管理:常规设置、问卷管理、管理员管理。
常规设置包括:系统信息配置、用户管理、友情链接管理。
问卷管理:问卷添加、问卷审核、问卷管理、题目管理、问卷统计。
管理员管理:管理员的添加和删除与密码的修改。
通用在线问卷调查系统的数据流程图如图2.1所示[15]:
图2.1“通用在线问卷调查系统”的顶级DFD
图2.2“通用在线问卷调查系统”的一级DFD
3 系统设计
3.1系统功能设计
根据用户的需求以及结合上述的功能需求分析的结果,使用面向对象的设计技术,进行系统设计。
本系统应具有如下几个功能模块:
1、注册登录模块
用户进行注册登录后才可以对问卷进行浏览做答,管理员登录后可以对后台的数据进行处理。
2、问卷调查模块
用户能够在网上进行问卷调查,支持单选、多选、自定义文本以及多种题型交叉等类型的问题,能够防止同一用户重复提交。
3、用户管理模块
可以对用户进行添加、修改、删除。
用户管理模块主要是对用户的身份及其基本信息、登录控制权限等进行管理,以确保答卷信息的真实性和可信度,进而获得有参考价值的统计信息。
4、问卷管理模块
能够对问卷进行添加、删除、修改和查询等基本管理。
5、问卷结果分析模块
对问卷结果进行统计分析,要求能对问卷数据进行查看,并根据结果生成柱状图统计表。
通过上述系统功能设计,进而画出系统功能模块设计图,系统功能模块设计如图3.1所示。
3.2数据库设计
3.2.1数据库概念结构设计
通过上述的需求和设计,得出本系统涉及到如下实体:用户信息实体、管理员信息实体、问卷实体、题目实体。
各个实体之间的联系如图3.2所示。
3.2.2 数据库逻辑结构设计
通过上面数据流分析和数据库概念结构设计,现在需要将上面的数据库概念结构模型转化为Access数据库系统所支持的实际数据模型,也就是数据库的逻辑结构。
通用在线问卷调查系统数据库中各个表的设计结果如下面表所示。
1、用户表
该表用来存放用户的基本信息。
主要字段有:用户编号(ID)、用户姓名(UserName)、用户密码(Password)、用户登录名(Uid)、性别(Sex)、工作单位(Company)、职业(Profession)、邮箱(Email)、是否审核(Flag)、注册时间(Adddate)。
如表3.1所示是用户表。
表3.1用户表
字段名数据类型可否为空是否主键
ID 自动编号否是UserName 文本否否
Password 文本否否Uid 文本否否
Sex 文本否否
Age 文本否否Company 文本否否
Profession 文本否否
Email 文本否否
Flag 数字是否
Adddate 日期/时间是否
2、管理员信息表
该表是用来存放管理员的相关信息,主要字段有:管理员ID号(Admin_id)、管理员姓名(Admin_user)、管理员密码(Admin_pass)、管理员登录名(Admin_name)、登录时间(Admin_logintime)、使用系统时间(Admin_logintimes)、登录IP(Admin_loginip)、加入时间(Admin_addtime)、电子邮件(Admin_email)、备注(Admin_info)。
如表3.2所示是管理员信息表。
表3.2管理员信息表
字段名数据类型可否为空是否主键
Admin_id 自动编号否是
Admin_user 文本否否
Admin_pass 文本否否
Admin_name 文本否否
Admin_state 是/否否否
Admin_logintime 日期/时间否否
Admin_logintimes 数字否否
Admin_loginip 文本是否
Admin_addtime 日期/时间是否
Admin_email 文本是否
3、问题信息表:
该表主要记录问卷题目与答案的相关信息。
主要字段如下:问题ID号(Question_id)、问题类型(Question_type)、问题内容(Question_content)、问题答案(Question_answer)、问题结果(Question-result)、图片(Question_img)。
如表3.3所示是问题信息表。
表3.3问题信息表
字段名数据类型可否为空是否主键
Question_id 自动编号否是
Question_type 数字否否
Question_content 备注否否
Question_answer 备注否否
Question_result 备注是否
Question_img 备注是否
4、问卷信息表
该表主要存放问卷的相关内容。
主要字段有:问卷ID号(Survey_id)、问卷标题(Survey_name)、问卷简介(Survey_description)、问卷作者(Survey_author)、问卷内容(Survey_content)、图片(Survey_img)、是否有图片(Survey_isimg)、同一IP可交(Survey_ipRepeat)、创建时间
(Survey_creatDate)、IP段开始(Survey_ipStart)、IP段结束(Survey_ipEnd)、设置密码(Survey_password)、是否公开(Survey_isOpen)、结束时间(Survey_dateOver)、是否审核(Survey_isAuditing)、访问次数(Survey_hits)、有效份数(Survey_usehits)、问卷编号(Survey_code)。
如表3.4所示是问卷信息表。
表3.4问卷信息表
字段名数据类型可否为空是否主键
Survey_id 自动编号否是
Survey_name 文本否否
Survey_descript 备注否否
Survey_author 文本否否
Survey_content 备注否否
Survey_img 文本是否
Survey_isimg是/否是否
Survey_ipRepeat 是/否是否
Survey_creatDate 日期/时间是否
Survey_ipStart 备注是否
Survey_ipEnd 备注是否
Survey_password 备注是否
Survey_isOpen 是/否是否
Survey_dateOver 日期/时间是否
Survey_isAuditing 是/否是否Survey_hits 数字是否
Survey_usehits 数字是否
Survey_code 文本是否
4 系统实现
通过对系统功能的分析与设计,明确了系统应该实现的功能模块,结合数据库的设计从而实现系统的各个功能模块。
4.1注册登录模块的实现
用户进入到系统的首页index.asp,在该页面中,需要完成用户注册,输入相关信息后,经过审核,确认为合法用户之后才可以进行登录,登录的时候进行用户名和密码的判断,用户名和密码匹配才能进入系统,否则返回。
进入系统首页便可以使用问卷调查模块,在这里,用户可以选择进一步操作,如退出登录。
登录模块界面如图4.1所示。
注册登录模块部分代码实现如下:
<%else%>
用户名<input name="uid" type="text" id="uid" size="14" maxlength="12" />
密码:
<input name="password" type="password" id="password" size="14"
maxlength="6" />
<label>
<input name="Submit" type="submit" class="STYLE3" value="登录">
</label> <a href="zc.asp">用户注册</a>
4.2问卷调查模块的实现
用户能够在网上进行问卷调查,支持单选、多选、自定义文本以及多种题型交叉等类型的问题,并且能够防止同一用户重复提交。
问卷调查模块界面如图4.2所示。
问卷调查模块主页面的部分代码实现如下:
<%
response.Write("</ul>")
response.Write("<input type=""hidden"" value="""&Question_type&"""
name=""Question_type"">")
response.Write("<div class=""button"">")
response.Write("<input type=""submit"" value=""提交问卷""
name=""submit1"">")
response.Write("<input type=""reset"" value=""重新填写"" name=""reset1"">") response.Write("</div>")
response.Write("<div class=""backIndex"">")
response.Write("<a href=""Index.asp"" target=""_self"">返回首页</a>")%>
4.3 用户管理模块的实现
可以对用户进行添加、修改、删除。
用户管理模块主要是对用户的身份及其基本信息、登录控制权限等进行管理,以确保答卷信息的真实性和可信度,进而获得有参考价值的统计信息。
用户管理模块界面如图4.3所示。
用户管理模块主页面的部分代码实现如下:
<%if request("password")<>"" then rs("password")=md5(request("password"),16)
rs("username")=request("username")
rs("sex")=request("sex")
rs("age")=request("age")
rs("company")=request("company")
rs("profession")=request("profession")
rs("email")=request("email")
rs.update
rs.close
set rs=nothing
call ShowAlert("修改用户成功","student.asp?type=edit&id="&request.QueryString("id")) end sub
%>
<title>用户信息更新</title>
<style type="text/css">
</style></head>
<body>
<% if request.QueryString("type")="del" then
conn.execute("delete from student where id="&request.QueryString("id"))
call ShowAlert("用户删除成功","student.asp")
end if%>
<% if request.QueryString("type")="" then %>
<form action="?action=inf" method="post" name="form1" target="main"
id="form1" onSubmit="javascript:return CheckForm()">
<td width="935" height="25" colspan="2" align="left" style="border-bottom: dashed 1px"><img src="images/dot_process.gif" width="7" height="7" /> 用户管理>> 用户列表 <a href="?type=add">添加用户</a></td>
IF rs.BOF=true and rs.EOF =true or rs.RecordCount=0 THEN
RESPONSE.Write"<BR><BR><BR><BR><font class='jintianshi'>
暂无相关记录...<a href=javascript:history.go(-1)><b><u>返回上一页
</u></b></a></font>" %>
4.4 问卷管理模块的实现
管理员登录后可以进入此模块,在此模块进行问卷管理,能够对问卷进行
添加、删除、修改和查询等基本管理。
问卷添加界面如图4.4(a)所示。
图4.4(a)问卷添加页面图
问卷添加主页面的部分代码实现如下:
<tr>
<th width="179">问卷添加</th>
<th width="422"> </th>
<th width="374"><span class="R">*</span> 为必填项目</th>
</tr>
<tr>
<td width="179">问卷名称:</td>
<td width="422"><input name="Survey_name" type="text" size="50"></td>
<td width="374"><span class="R">*</span> 问卷的名称,既问卷的总标题</td> </tr>
<tr>
<td width="179">问卷发起人(单位):</td>
<td width="422"><input name="Survey_author" type="text" size="50"></td>
<td width="374"><span class="R">*</span> 问卷发起人,此问卷的所有单位
</td>
</tr>
<tr>
<td width="179">问卷描述:</td>
<td width="422"><textarea rows="2" name="Survey_description" cols="40" onpropertychange="this.style.posHeight=this.scrollHeight"></textarea></td>
<td width="374"> 对此问卷的简单描述</td>
</tr>
<tr>
<td width="179">问卷结束日期:</td>
<td width="422"><input type="text" name="Survey_dateOver" readOnly="" onClick="setDay(this);" value="<%=date()+100%>"></td>
<td width="374"><span class="R">*</span> 问卷结束日期,到期后该问卷将不能接受</td>
</tr>
<tr>
<td width="179">公开此问卷调查</td>
<td width="422"><input name="Survey_isOpen" type="checkbox" value="true" checked="checked"></td>
<td width="374"><span class="R">*</span> 不公开的问卷,相当于锁定</td>
</tr>
<tr>
<td width="179">为问卷添加主题图片</td>
<div id="hidden_isImg" style="display:none;">
<iframe src="upload.asp" frameborder="0" width="420" height="40" frameborder="0" scrolling="no"></iframe>
</div> </td>
<td width="374"> 有主题图片的格式必须为.jpg</td>
</tr>
<tr>
<td width="179">设置访问IP限制</td>
问卷管理界面如图4.4(b)所示。
图4.4(b)问卷管理页面图
4.5 问卷结果分析模块的实现
对问卷结果进行统计分析,要求能对问卷数据进行查看,并根据结果生成柱状图统计表。
图4.5问卷结果统计分析页面图
问卷结果分析主页面的部分代码实现如下:
response.Write("<title>问卷---"&Survey_name&" 统计结果</title>")
response.Write("<table width=""100%"" align=""center"" cellpadding=""0"" cellspacing=""0"" id=""Survey_title"" class=""table"">")
response.Write("<tr><th colspan=""3"">")
response.Write("<div
class=""Survey_title""><span class=""large"">"&Survey_name&"</span></div>") response.Write("</th></tr>")
if not Survey_content="" then
Survey_question=split(Survey_content,",")
Survey_question_length=ubound(Survey_question)
for i=0 to Survey_question_length
response.Write("<tr>")
response.Write("<td colspan=""3"">")
response.Write((i+1)&"、")
sql="select Question_content,Question_answer,Question_result,Question_type from [Question] where Question_id="&Survey_question(i)
rs.open sql,conn,1,1
response.Write(Question_result(j)&"/"&Survey_usehits&" "&persent*1 00&"% ")
response.Write("<a
href=""ShowText.asp?Question_id="&Survey_question(i)&j&""" target=""_blank"">查看具体</a>")
response.Write("<td> </td>")
response.Write("<td><a
href=""ShowText.asp?Question_id="&Survey_question(i)&""" target=""_blank"">查看具体</a></td>")
response.Write("</tr>")
5 系统测试与维护
在系统实现之后,进入系统的测试阶段。
测试是发现并排除错误的主要手段,同时是程序开发中必不可少的阶段。
在系统设计的早期显得尤为重要,每个模块测试正确后,整个系统的调试、测试工作就会十分简单了。
5.1系统测试
5.1.1测试的步骤及内容
测试是程序的执行过程,目的在于发现错误,一个好的测试用例在于能发现至今未发现的错误。
测试的目标是想以最少的时间和人力找出系统中潜在的各种错误和缺陷。
如果成功地实施了测试,就能够发现系统中的错误。
测试的附带收获是,它能够证明系统的功能和性能与需求说明相符。
此外,实施测试收集到的测试结果数据为可靠性分析提供了依据。
因此在开发通用在线问卷调查系统时,为了使系统能够稳定运行,对系统进行了有针对性的全面测试,采取的测试步骤是:
1、单元测试:单元测试的对象是系统设计时的各个模块。
针对系统中各个功能模块进行测试,检查是否能按要求正常运行。
单元测试内容如下:
(1)用户通过注册,测试该系统是否能够按照预定的要求将用户信息写入后台数据库中,每个模块是否能够有效链接等。
(2)通过问卷调查模块,测试该系统能否正常的发送用户的调查问卷等。
(3)通过用户管理,测试该系统能否按照预定的要求对用户进行更新。
(4)通过对问卷及题目的添加,测试该系统能否正常的将问卷的相关信息录入数据库中,并显示在前台的问卷调查页面中。
(5)查看问卷结果,测试该系统能否正确地将统计结果的条形图显示出来。
2、集成测试:集成测试主要依据系统结构设计(概要设计)文档,测试的主要内容有可靠性、易用性、效率和可维护性中的相关部分,根据系统需求和设计的要求而选定。
集成测试内容如下:
(1)可靠性测试
根据系统需求和设计中提出的要求,对系统的容错性、易恢复性、错误处
理能力进行测试。
(2)易用性测试
根据系统设计中提出的要求,对系统的易理解性、易学性和易操作性进行检查和测试。
(3)性能测试
根据性能需求和设计中提出的要求,对系统的时间特性、资源特性进行测试。
3.功能测试:系统基本完成之后,为了保证运行的可靠性,基本功能是否能够达到以及是否符合需求规格中的基本要求,应对系统进行功能测试。
功能测试内容如下:
(1)系统功能是否实现,如数据库的查询、修改、删除是否正常。
(2)页面的链接是否正确。
(3)页面文字、图片显示是否正常、有无变形、色彩是否风格统一。
5.1.2测试结果
通过对系统的各功能模块的功能进行测试,得到如下结果:本系统对任务要求的功能基本上实现了,作为一个通用问卷调查系统,可以满足用户进行问卷调查的需要,但是比起其他类似的问卷调查系统,本系统在界面和某些功能设计方面,还有一些不足之处,这些不足之处有待于以后进一步的完善。
5.2 系统维护
系统的维护主要包括以下内容:
用户的维护:修改用户资料,对用户进行管理。
问卷的维护:对添加的问卷进行定期的管理和维护。