版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
PAGE基于.NET的自動閱卷考試系統(tǒng)設(shè)計(jì)【摘要】隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,教學(xué)方式發(fā)生了很大的變化。傳統(tǒng)的教學(xué)考試方式已漸漸無法適應(yīng)社會的發(fā)展,它要求有新的考試方式來適應(yīng)新的教學(xué)方式。網(wǎng)絡(luò)化考試系統(tǒng)在很多領(lǐng)域都已經(jīng)有所應(yīng)用,但在計(jì)算機(jī)類考試中較為鮮見,特別是帶閱卷功能的考試系統(tǒng)。本系統(tǒng)利用.NET技術(shù),采用C#語言來實(shí)現(xiàn)應(yīng)用程序的設(shè)計(jì)和功能的實(shí)現(xiàn),數(shù)據(jù)庫則采用SQLSERVER2000來設(shè)計(jì)。這是一個(gè)基于B/S(瀏覽器/服務(wù)器模式)架構(gòu)的系統(tǒng)。本文介紹了自動閱卷考試系統(tǒng)的社會需求、發(fā)展前景和系統(tǒng)的主要功能,對各個(gè)功能模塊進(jìn)行了詳細(xì)的介紹。關(guān)鍵詞:B/S(瀏覽器/服務(wù)器模式),反射,.NET,自動閱卷
AutomaticScoringExaminationSystemBasedOn.NETAbstractWiththedevelopmentofnetworktechnology,teachingmethodshavetakengreatchanges.Examinationofthetraditionalteachingmethodsaregraduallyunabletoadapttothedevelopmentofsociety,itrequiresanewexaminationofwaystoadapttothenewteachingmethods.Networkexaminationsystemhavebeenusedinmanyareas,butinthecomputerexaminationisuncommon,especiallywithautomaticscoringfunctionoftheexaminationsystem.Thissystemused.NETTechnologyandC#languagetoachievetheapplicationofthedesignandfunctionalityoftherealizetion.ThedatabaseisusedSQLSERVER2000todesign;ThissystemisbasedonB/S(browser/servermodel)structure.Inthispaper,itIntroducedtheSocialneeds、developmentprospectsandmainfunctionoftheautomaticscoringexaminationsystem,ofcoursecarriedoutadetailedintroductionofthevariousfunctionalmodules.Keywords:B/S(browser/servermodel),reflection,.NET,automaticscoring
目錄1. 背景介紹 11.1. 網(wǎng)絡(luò)考試的背景介紹 11.1.1. 網(wǎng)絡(luò)考試系統(tǒng)的社會需求 11.1.2. 目前已有的考試系統(tǒng)的優(yōu)、缺點(diǎn) 11.2. 選擇考試系統(tǒng)的原因 21.3. 設(shè)計(jì)目標(biāo) 22. 基于.NET的自動閱卷考試系統(tǒng)概述 32.1. 用戶需求簡介 32.1.1. 功能需求 32.1.2. 性能需求 32.1.3. 可靠性和可用性需求 32.2. 工作過程 32.3. 系統(tǒng)特點(diǎn) 33. 設(shè)計(jì)中要解決的問題 53.1. 用戶權(quán)限 53.2. 考卷的設(shè)置 53.3. 自動閱卷的實(shí)現(xiàn) 53.4. 考試時(shí)間控制問題 54. 總體設(shè)計(jì) 64.1. 系統(tǒng)設(shè)計(jì) 64.1.1. 設(shè)計(jì)目標(biāo) 64.1.2. 開發(fā)環(huán)境 64.1.3. 開發(fā)語言 64.1.4. 開發(fā)工具 64.1.5. 后臺數(shù)據(jù)庫 64.1.6. 運(yùn)行環(huán)境 64.2. 數(shù)據(jù)庫需求設(shè)計(jì) 64.2.1. 系統(tǒng)流程圖 64.2.2. 系統(tǒng)E-R圖 84.2.3. 數(shù)據(jù)庫中的表 84.2.4. 數(shù)據(jù)庫中的視圖 124.3. 系統(tǒng)總體構(gòu)架設(shè)計(jì) 144.3.1. 系統(tǒng)層次結(jié)構(gòu)圖 144.3.2. 系統(tǒng)流程圖 145. 系統(tǒng)主要功能模塊設(shè)計(jì) 185.1. 登陸模塊 185.2. 注冊模塊 185.3. 學(xué)生模塊 185.4. 教師模塊 185.5. 重點(diǎn)、難點(diǎn)代碼設(shè)計(jì) 195.5.1. 時(shí)間控制的實(shí)現(xiàn) 195.5.2. 自動閱卷的實(shí)現(xiàn) 215.6. 實(shí)現(xiàn)界面 306. 系統(tǒng)實(shí)現(xiàn)技術(shù) 366.1. B/S模式 366.2. 反射 366.3. SqlHelper 387. 性能測試與分析 407.1. 測試目的和原則 407.1.1. 測試的目的 407.1.2. 測試的原則 407.2. 測試環(huán)境與測試條件 407.2.1. 測試環(huán)境 407.2.2. 測試條件 407.3. 測試實(shí)例的研究與選擇 407.4. 實(shí)例測試結(jié)果 427.5. 性能分析 42結(jié)束語 43謝辭 43參考文獻(xiàn) 43基于.NET的自動閱卷考試系統(tǒng)-PAGE70-基于.NET的自動閱卷考試系統(tǒng)隨著網(wǎng)絡(luò)技術(shù)的發(fā)展,教學(xué)方式發(fā)生了很大的變化。傳統(tǒng)的教學(xué)考試方式已漸漸無法適應(yīng)社會的發(fā)展,它要求有新的考試方式來適應(yīng)新的教學(xué)方式。網(wǎng)絡(luò)化考試系統(tǒng)在很多領(lǐng)域都已經(jīng)有所應(yīng)用,但在計(jì)算機(jī)類考試中較為鮮見,特別是帶閱卷功能的考試系統(tǒng)。研究這個(gè)系統(tǒng),重點(diǎn)在于考卷的自動生成和批閱,特別是對于主觀填空題和編程題。充分利用在大學(xué)所學(xué)的知識和現(xiàn)有的網(wǎng)絡(luò)科技技術(shù)進(jìn)行研究,加深、鞏固已學(xué)知識,接觸、學(xué)習(xí)新的知識,提高技能,希望能通過研究增強(qiáng)實(shí)踐經(jīng)驗(yàn),減輕老師的負(fù)擔(dān),節(jié)約資源,同時(shí)對自己進(jìn)行考核,為步入社會做準(zhǔn)備。背景介紹網(wǎng)絡(luò)考試的背景介紹隨著計(jì)算機(jī)網(wǎng)絡(luò)技術(shù)的突飛猛進(jìn)及教育網(wǎng)絡(luò)化的不斷推進(jìn),傳統(tǒng)的考試模式表現(xiàn)出一些弊端,比如繁雜的試卷收發(fā)、投入相當(dāng)人力的閱卷等。在相當(dāng)程度上,這些工作可以完全或部分交由計(jì)算機(jī)完成。在線考試系統(tǒng)指利用計(jì)算機(jī),通過計(jì)算機(jī)網(wǎng)絡(luò)實(shí)現(xiàn)對學(xué)生的考核。與傳統(tǒng)的考試模式相比,它極大限度排除了人為因素的作用,保證了考試的客觀、公正;通常考生在考試之后,即可得到考試成績;而且通過計(jì)算機(jī)閱卷,通過事先設(shè)計(jì)好的答案,使得閱卷具有高效性、可靠性、公平性。尤其在應(yīng)用考試系統(tǒng)對計(jì)算機(jī)有關(guān)知識的考核中,除了理論知識之外,還可以考查考生的實(shí)際動手操作能力。網(wǎng)絡(luò)考試系統(tǒng)是一個(gè)基于數(shù)據(jù)庫和計(jì)算機(jī)網(wǎng)絡(luò)的在線實(shí)時(shí)測試系統(tǒng),包括考生管理系統(tǒng)、考試系統(tǒng)、題庫系統(tǒng)、閱卷系統(tǒng)、考試管理系統(tǒng)等。該系統(tǒng)可以在被允許的任何地點(diǎn)、時(shí)間進(jìn)行在線實(shí)時(shí)考試。具有信息量大、效率高、管理方便、考試客觀公正等優(yōu)點(diǎn),教學(xué)人員可以很容易地從考試結(jié)果中獲得教學(xué)反饋信息。網(wǎng)絡(luò)考試系統(tǒng)的社會需求考試是教學(xué)效果測量的重要手段。傳統(tǒng)的考試方式是以紙為媒介的,它要求教師印試卷、安排考試、監(jiān)考,收集試卷,評改試卷,這是一個(gè)漫長而復(fù)雜的過程,越來越不適應(yīng)現(xiàn)代化教學(xué)的需要.近年來,隨著計(jì)算機(jī)技術(shù)和網(wǎng)絡(luò)技術(shù)的不斷進(jìn)步和飛速發(fā)展,依托計(jì)算機(jī)技術(shù)的在線考試方式或網(wǎng)上考試方式的研究一直在進(jìn)行之中,目前在線考試方式在駕照考試和英語考試等領(lǐng)域已付諸實(shí)施,而對于計(jì)算機(jī)類考試的系統(tǒng)則比較少見,特別是帶有自動改卷功能的考試系統(tǒng)。隨著計(jì)算機(jī)科學(xué)技術(shù)和網(wǎng)絡(luò)的發(fā)展,傳統(tǒng)等教學(xué)方式很難適應(yīng)需求,它要求一種新的教學(xué)方式,而網(wǎng)絡(luò)化教育方式順勢而生?;?NET的網(wǎng)上考試系統(tǒng)正是實(shí)施網(wǎng)絡(luò)化教育的一個(gè)重要組成部分,它可以利用網(wǎng)絡(luò)的無限空間,隨時(shí)隨地對學(xué)生進(jìn)行考試,利用數(shù)據(jù)庫使考試過程得到簡化.考試過程中試卷的生成和批改都由計(jì)算機(jī)完成,其目標(biāo)是實(shí)現(xiàn)考試的無紙化、標(biāo)準(zhǔn)化和學(xué)生成績管理的網(wǎng)絡(luò)化和自動化。目前已有的考試系統(tǒng)的優(yōu)、缺點(diǎn)網(wǎng)絡(luò)考試系統(tǒng)是近年來的一個(gè)熱點(diǎn)。隨著網(wǎng)絡(luò)的發(fā)展,大家都希望可以充分利用現(xiàn)代化技術(shù)減輕工作量,實(shí)現(xiàn)自動化管理。以往的許多網(wǎng)絡(luò)考試系統(tǒng)實(shí)現(xiàn)了考試環(huán)節(jié)中的大部分工作,已經(jīng)可以很完美的投入使用,其安全性、擴(kuò)充性、準(zhǔn)確性、便捷性都得到了充分的體現(xiàn)。其中,選擇題、判斷題等客觀題的自動閱卷、學(xué)生信息的管理、考卷的組織等功能模塊做的非常不錯(cuò)。對于主觀題如填空題、編程題、簡答題,絕大多數(shù)只實(shí)現(xiàn)了考試而為實(shí)現(xiàn)批閱的功能,未實(shí)現(xiàn)全部自動化。這使得教師在系統(tǒng)批閱完客觀題后還要手動批閱主觀題,不能很好的節(jié)約人力、物力,使得資源無法充分利用。主觀題的閱卷有人為的參與,存在主觀因素,沒辦法保證考試的公平、公正。選擇考試系統(tǒng)的原因因?yàn)橐酝目荚囅到y(tǒng)存在一定的缺陷,未完成主觀題的閱卷部分,而一個(gè)完整的含主觀題自動閱卷的考試系統(tǒng)被迫切需求。此設(shè)計(jì)在原有考試系統(tǒng)的基礎(chǔ)上突破、創(chuàng)新,增加主觀填空題、程序題的自動閱卷功能。應(yīng)用C#語言中的反射知識可以實(shí)現(xiàn)簡單的程序體的修改。選擇該開發(fā)系統(tǒng),具有創(chuàng)新性、可行性、需要性,其科學(xué)性也不言而喻。設(shè)計(jì)目標(biāo)本設(shè)計(jì)的目的是設(shè)計(jì)一套完整的考試系統(tǒng),實(shí)現(xiàn)考卷的自動生成、試卷管理、查看考生考試結(jié)果、學(xué)生考試、自動閱卷等功能,增加主觀題中填空題和編程題的自動閱卷功能。實(shí)現(xiàn)考試的無紙化、標(biāo)準(zhǔn)化和學(xué)生成績管理的網(wǎng)絡(luò)化和自動化。小結(jié)由上所知,網(wǎng)絡(luò)考試系統(tǒng)是科學(xué)技術(shù)發(fā)展的必然要求,具有很大的社會需求。而現(xiàn)有的用于計(jì)算機(jī)學(xué)科的網(wǎng)絡(luò)需考試系統(tǒng)不完善,缺少主觀題自動閱卷功能,這些證明基于.NET的自動閱卷考試系統(tǒng)是正確的選擇。
基于.NET的自動閱卷考試系統(tǒng)概述用戶需求簡介基于.NET的自動閱卷考試系統(tǒng)是一個(gè)面向計(jì)算機(jī)類學(xué)科的考試系統(tǒng),它與其他其他考試系統(tǒng)的區(qū)別在于它增加了主觀填空題、編成題的自動閱卷功能。它應(yīng)用C#語言開發(fā),以.NET為平臺,采用B/S(瀏覽器/服務(wù)器)模式,用戶分為兩種:普通用戶和管理員用戶(admin)。學(xué)生屬普通用戶,教師屬管理員用戶。他們擁有的權(quán)限有所不同,學(xué)生只能進(jìn)行考試和修改密碼;教師可以根據(jù)自己所教授的課程新建科目、管理題庫,還可以設(shè)置試卷、查看學(xué)生的考試結(jié)果。通過對頁面的操作對數(shù)據(jù)庫進(jìn)行讀寫操作。功能需求該系統(tǒng)要求實(shí)現(xiàn)題庫管理、班級管理、學(xué)生答題、試卷組織、自動閱卷等功能,教師能夠查看學(xué)生的考試成績及答題情況,在試卷投入使用前能想進(jìn)行測試、查看考卷的整體情況,學(xué)生能自行修改自己的密碼。性能需求學(xué)生在做完程序題后,需上傳exe文件,然后連同試卷其它部分的答案一起提交,此過程必須在2分鐘內(nèi)完成。安全性有所保障,學(xué)生密碼由學(xué)生本人設(shè)置,以防他人冒用其帳號進(jìn)行考試。可靠性和可用性需求系統(tǒng)能正常運(yùn)行,在100人以內(nèi)同時(shí)登錄時(shí)不發(fā)生錯(cuò)誤,其所有功能在運(yùn)行時(shí)不發(fā)生故障。工作過程基于.NET的自動閱卷考試系統(tǒng)采用B/S(瀏覽器/服務(wù)器)模式,客戶無需安裝客戶端,只要有瀏覽器就可以使用。在登陸頁面,如果已注冊的用戶,更具自己的帳號、密碼就可以進(jìn)去系統(tǒng),根據(jù)用戶權(quán)限進(jìn)入不同的頁面;如果是還未注冊的用戶則比需先按注冊按鈕進(jìn)行注冊后才可以進(jìn)入系統(tǒng)。一般用戶(學(xué)生)登陸系統(tǒng)后,根據(jù)User.js跳轉(zhuǎn)到一般用戶主頁面,其中具有修改密碼、考試、退出三個(gè)功能,用戶可以自行對其進(jìn)行操作;管理員用戶(教師)登陸系統(tǒng)后,根據(jù)Admin.js跳轉(zhuǎn)到用戶主頁面,里面有科目管理、試卷管理、各種題目管理、答題測試、查看考試結(jié)果功能模塊,教師根據(jù)需要進(jìn)行操作。學(xué)生用戶的考試功能模塊只有在教師設(shè)置了考卷后才能進(jìn)行,學(xué)生打完考卷后須自行提交,并上傳程序題的代碼和exe文件。系統(tǒng)將根據(jù)學(xué)生上傳的考卷答題進(jìn)行批閱,得出每一題的成績和總成績。系統(tǒng)特點(diǎn)基于.NET的自動閱卷考試系統(tǒng)支持按權(quán)限對系統(tǒng)進(jìn)行操作,即不同類型的用戶擁有相異的權(quán)限:考試和管理。主要是在首頁通過兩種不同的方式進(jìn)入相異的操作界面,其主要特點(diǎn)體現(xiàn)在以下兩個(gè)個(gè)方面:①自主調(diào)用數(shù)據(jù)庫;②自主管理數(shù)據(jù)庫。自主調(diào)用數(shù)據(jù)庫即允許用戶能自由地從數(shù)據(jù)庫中選題、生成試卷。自主管理數(shù)據(jù)庫指一般用戶具有添加、修改數(shù)據(jù)的權(quán)力,實(shí)現(xiàn)數(shù)據(jù)庫的可擴(kuò)充性和開放性。而admin用戶則另具有刪除數(shù)據(jù)的權(quán)力如對題目的刪除、試卷的刪除、科目的刪除等,從而達(dá)到了系統(tǒng)數(shù)據(jù)統(tǒng)一性和一致性的目的。小結(jié)基于.NET的自動閱卷考試系統(tǒng)它采用B/S(瀏覽器/服務(wù)器)模式,是面向計(jì)算機(jī)學(xué)科的考試系統(tǒng)。用戶進(jìn)入界面就可進(jìn)行操作,內(nèi)部與數(shù)據(jù)庫相關(guān)的步驟對用戶透明,他是一個(gè)簡單的、易操作的、實(shí)用的系統(tǒng)。
設(shè)計(jì)中要解決的問題用戶權(quán)限不同類型的用戶擁有不同的權(quán)限,這要求在設(shè)計(jì)時(shí)考慮不同權(quán)限用戶的操作頁面。比如學(xué)生可以答題、查看某些信息,但是不具有刪除等權(quán)限;教師、管理員在具有對題庫、試卷等的增、刪、改操作權(quán)限??季淼脑O(shè)置考卷的設(shè)置是考試系統(tǒng)的一個(gè)重要部分,它包括試卷的基本信息和題型設(shè)置。如何進(jìn)行組卷及題型數(shù)目的控制成了試卷設(shè)置的一大難點(diǎn)。此外,對于設(shè)置那份考卷用于考試也是一個(gè)值得考慮的問題。自動閱卷的實(shí)現(xiàn)自動閱卷十本系統(tǒng)的重中之重??陀^題的自動閱卷比較容易實(shí)現(xiàn),運(yùn)用匹配的方法就可以完成。主觀題中,對于填空題,則運(yùn)用匹配的方式來進(jìn)行判斷正確與否;程序題則運(yùn)用C#中反射的技術(shù)來實(shí)現(xiàn)??荚嚂r(shí)間控制問題時(shí)間控制是學(xué)生考試系統(tǒng)一個(gè)很重要的組成部分。一直以來的考試都有規(guī)定在一定的時(shí)間內(nèi)完成,否則考試就失去了它本身的意義。所以,在設(shè)計(jì)系統(tǒng)時(shí)需好好考慮時(shí)間控制的問題。
總體設(shè)計(jì)系統(tǒng)設(shè)計(jì)設(shè)計(jì)目標(biāo)設(shè)計(jì)一套完整的考試系統(tǒng),實(shí)現(xiàn)考卷的自動生成、試卷管理、查看考生考試結(jié)果、學(xué)生考試、自動閱卷等功能,增加主觀題中填空題和編程題的自動閱卷功能。開發(fā)環(huán)境硬件環(huán)境:PC機(jī)軟件環(huán)境:WindowsXP、MicrosoftVisualStudio2005、SQLServer2000、IIS開發(fā)語言開發(fā)語言使用VisualC#開發(fā)工具M(jìn)icrosoftVisualStudio2005、SQLServer2000后臺數(shù)據(jù)庫后臺數(shù)據(jù)庫使用SQLServer2000,其可管理和處理大批量的考試數(shù)據(jù),并具有較高的可靠性。運(yùn)行環(huán)境硬件環(huán)境:PC機(jī)軟件環(huán)境:WindowsXP、www、InternetExplorer數(shù)據(jù)庫需求設(shè)計(jì)數(shù)據(jù)庫是系統(tǒng)的重要組成部分,是系統(tǒng)的核心和基礎(chǔ)。它把系統(tǒng)中大量的數(shù)據(jù)按一定的模型組織起來、提供存儲、維護(hù)、檢索數(shù)據(jù)的功能,使系統(tǒng)可以方便、及時(shí)、準(zhǔn)確地從數(shù)據(jù)庫中獲取所需的信息。SQLServer2000是一個(gè)常用的數(shù)據(jù)庫開發(fā)軟件,SQL語言本身是一個(gè)綜合的、功能極強(qiáng)同時(shí)又簡捷易學(xué)的語言,用它開發(fā)的軟件數(shù)據(jù)結(jié)構(gòu)化、獨(dú)立性高、共享性高、冗余度低、易擴(kuò)充。在本設(shè)計(jì)中,應(yīng)用了數(shù)據(jù)庫中的基本表和視圖,應(yīng)用程序?qū)@些基本表和視圖進(jìn)行操作。系統(tǒng)流程圖0層圖1層圖教師模塊流程圖:學(xué)生答題模塊流程圖:系統(tǒng)E-R圖數(shù)據(jù)庫中的表基本表是本身獨(dú)立存在的表,在SQL中一個(gè)關(guān)系就對應(yīng)一個(gè)基本表。一個(gè)或多個(gè)基本表對應(yīng)一個(gè)存儲文件。用戶建立一個(gè)基本表后,可以對它進(jìn)行增加、修改、查詢、刪除等操作。本設(shè)計(jì)中涉及到以下基本表,建立于數(shù)據(jù)庫WebExam中。具體如下所示:1、用戶信息表(User)列名數(shù)據(jù)類型長度是否主鍵允許空說明StudentIDbigInt8是不允許學(xué)生編號Namevarchar50否不允許用戶名Passwdvarchar50否不允許用戶密碼Typevarchar50否不允許用戶類型StudentNamevarchar50否允許學(xué)生姓名2、班級信息表(class)列名數(shù)據(jù)類型長度是否主鍵允許空說明ClassIDInt4是不允許班級編號ClassNamevarchar50否不允許班級名稱StudentCountInt4否允許班級學(xué)生數(shù)IsDeletedBit1否不允許是否刪除3、科目信息表(CourseInfo)列名數(shù)據(jù)類型長度是否主鍵允許空說明CourseIDInt4是不允許科目編號CourseNameNvarchar50否不允許科目名稱IsDeletedBit1否允許是否刪除試卷信息表(Paper)列名數(shù)據(jù)類型長度是否主鍵允許空說明PaperIDInt4是不允許試卷編號NameVarchar50否不允許試卷名稱CourseIDInt4否允許科目編號UsedBit1否允許是否用于考試IsDeletedBit1否允許是否刪除CurrencyBit1否允許是否公有ExamTimeInt4否不允許考試時(shí)間長度5、試卷-試題表(PaperData)字段名數(shù)據(jù)類型長度主鍵允許空說明PaperDataIDInt4是不允許試題編號PaperIDInt4否不允許試卷編號TypeInt4否允許試題類型QuestionIDInt4否允許題目編號ScoreInt4否允許分?jǐn)?shù)6、單項(xiàng)選擇題信息表(Single)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號QuestionDesVarchar800否不允許題目內(nèi)容Answer1Varchar100否不允許備選答案1Answer2Varchar100否不允許備選答案2Answer3Varchar100否允許備選答案3Answer4Varchar100否允許備選答案4RightAnswerInt2否不允許正確答案CourseIDInt4否允許科目編號ScoreInt1否允許分?jǐn)?shù)IsDeletedBit1否允許是否刪除CurrencyBit1否允許是否公有7、單項(xiàng)選擇題答案表(SingleAnswer)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號PaperDataIDInt4否不允許試題編號StudentIDbigInt8否不允許學(xué)生編號AnswerChar10否不允許學(xué)生答案8、多項(xiàng)選擇題信息表(More)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號QuestionDesVarchar800否不允許題目內(nèi)容Answer1Varchar100否不允許備選答案1Answer2Varchar100否不允許備選答案2Answer3Varchar100否允許備選答案3Answer4Varchar100否允許備選答案4RightAnswerInt4否不允許正確答案CourseIDInt4否允許科目編號ScoreInt4否允許分?jǐn)?shù)IsDeletedBit1否允許是否刪除CurrencyBit1否允許是否公有9、多項(xiàng)選擇題答案表(MoreAnswer)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號PaperDataIDInt4否不允許試題編號StudentIDbigInt8否不允許學(xué)生編號AnswerInt4否不允許學(xué)生答案10、判斷題信息表(Judge)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號QuestionDesVarchar800否不允許題目內(nèi)容RightAnswerBit1否不允許正確答案CourseIDInt4否允許科目編號ScoreInt4否允許分?jǐn)?shù)IsDeletedBit1否允許是否刪除CurrencyBit1否允許是否公有11、判斷題答案表(JudgeAnswer)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號PaperDataIDInt4否不允許試題編號StudentIDbigInt8否不允許學(xué)生編號AnswerBit1否不允許學(xué)生答案12、填空題信息表(Space)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號QuestionDesVarchar800否不允許題目內(nèi)容Answer1Varchar100否不允許第一空答案Answer2Varchar100否允許第二空答案Answer3Varchar100否允許第三空答案Answer4Varchar100否允許第四空答案CourseIDInt4否允許科目編號ScoreInt4否允許分?jǐn)?shù)IsDeletedBit1否允許是否刪除CurrencyBit1否允許是否公有13、填空題答案表(SpaceAnswer)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號PaperDataIDInt4否不允許試題編號StudentIDInt4否不允許學(xué)生編號Answer1Nvarchar100否不允許第一空答案Answer2Nvarchar100否允許第二空答案Answer3Nvarchar100否允許第三空答案Answer4Nvarchar100否允許第四空答案14、程序題信息表(Program)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號QuestionDesVarchar800否不允許題目內(nèi)容RightAnswerVarchar100否不允許正確答案CourseIDInt4否允許科目編號ScoreInt4否允許分?jǐn)?shù)IsDeletedBit1否允許是否刪除CurrencyBit1否允許是否公有15、程序題答案表(ProgramAnswer)字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號PaperDataIDInt4否不允許試題編號StudentIDbigInt8否不允許學(xué)生編號AnswerInt4否不允許學(xué)生答案16、ProgramPath表字段名數(shù)據(jù)類型長度主鍵允許空說明QuestionIDInt4是不允許題目編號PaperIDInt4否不允許試卷編號Pathvarchar100否不允許路徑17、StudentScore表字段名數(shù)據(jù)類型長度主鍵允許空說明PaperIDInt4是不允許試卷編號StudentIDbigInt8否不允許學(xué)生編號CourseIDInt4否不允許科目編號ScoreInt4否不允許學(xué)生成績18、ExamTime表字段名數(shù)據(jù)類型長度主鍵允許空說明IDInt4是不允許編號StudentIDbigInt8否不允許學(xué)生編號PaperIDInt4否不允許試卷編號TimeLongInt8否不允許考試時(shí)間數(shù)據(jù)庫中的視圖視圖是從一個(gè)或幾個(gè)基本表導(dǎo)出的表。它本身不獨(dú)立存儲在數(shù)據(jù)庫中,即數(shù)據(jù)庫中只存放視圖的定義而不存放視圖對應(yīng)的數(shù)據(jù),這些數(shù)據(jù)仍存放在導(dǎo)出視圖的基本表中,他是一個(gè)虛表。所以,當(dāng)基本表中的數(shù)據(jù)庫發(fā)生變化時(shí),從視圖中查詢出的數(shù)據(jù)也隨之改變。視圖與基本表在概念上是相同的,用戶可以在視圖上進(jìn)行和基本表一樣的查詢操作,也可以再定義視圖。本設(shè)計(jì)中根據(jù)需要建立了以下視圖,這些視圖將在下面一一列出:1、JudgeView視圖,由PaperData和Judge兩個(gè)基本表導(dǎo)出,Type=3,IsDeleted=0。列名導(dǎo)出表列名導(dǎo)出表PaperDataIDPaperDataPaperIDPaperDataQuestionIDPaperDataQuestionDesJudgeRightAnswerJudge2、MoreView視圖,由PaperData和More兩個(gè)基本表導(dǎo)出,Type=2,IsDeleted=0。列名導(dǎo)出表列名導(dǎo)出表PaperDataIDPaperDataPaperIDPaperDataQuestionIDPaperDataQuestionDesMoreAnswer1MoreAnswer2MoreAnswer3MoreAnswer4MoreRightAnswerMore3、PaperProgramView視圖,由Paper和ProgramPath兩個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表PaperIDPaperPathProgramPathNamePaper(別名:PaperName)3、ProgramAnswerView視圖,由PaperData和Program兩個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表QuestionIDProgramRightAnswerProgramPaperDataIDPaperDataScorePaperData4、ProgramView視圖,由PaperData、Program、ProgramPath和Paper四個(gè)基本表導(dǎo)出,Type=5。列名導(dǎo)出表列名導(dǎo)出表PaperDataIDPaperDataPaperIdPaperDataQuestionIDPaperDataQuestionDesProgramPathProgramPathName(PaperName)Paper5、SingleView視圖,由PaperData和Single兩個(gè)基本表導(dǎo)出,Type=1,IsDeleted=0。列名導(dǎo)出表列名導(dǎo)出表PaperDataIDPaperDataPaperIDPaperDataQuestionIDPaperDataQuestionDesSingleAnswer1SingleAnswer2SingleAnswer3SingleAnswer4SingleRightAnswerSingle6、SpaceView視圖,由PaperData和Space兩個(gè)基本表導(dǎo)出,Type=4,IsDeleted=0。列名導(dǎo)出表列名導(dǎo)出表PaperDataIDPaperDataPaperIDPaperDataQuestionIDPaperDataQuestionDesSpaceAnswer1SpaceAnswer2SpaceAnswer3SpaceAnswer4SpaceRightAnswerSpace7、StudentJudgeView視圖,由PaperData、Paper、Judge、JudgeAnswer和Users五個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表StudentIDUsersPaperIDPaperStudentNameUsersPaperNamePaperTypePaperDataScorePaperDataPaperDataIDJudgeAnswer8、StudentMoreView視圖,由PaperData、Paper、More、MoreAnswer和Users五個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表StudentIDUsersPaperIDPaperStudentNameUsersPaperNamePaperTypePaperDataScorePaperDataPaperDataIDMoreeAnswer9、StudentProgramView視圖,由PaperData、Paper、ProgramAnswer和Users四個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表StudentIDProgramAnswerPaperIDPaperDatarStudentNameUsersPaperNamePaperTypePaperDataScoreProgramAnswerPaperDataIDPaperData10、StudentSingleView視圖,由PaperData、Paper、Single、SingleAnswer和Users五個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表StudentIDUsersPaperIDPaperStudentNameUsersPaperNamePaperTypePaperDataScorePaperDataPaperDataIDPaperData11、StudentSpaceView視圖,由PaperData、Paper、Space、SpaceAnswer和Users五個(gè)基本表導(dǎo)出。列名導(dǎo)出表列名導(dǎo)出表StudentIDUsersPaperIDPaperStudentNameUsersPaperNamePaperTypePaperDataScorePaperDataPaperDataIDSpaceAnswer12、StudentView視圖,由Users基本表導(dǎo)出,Type=user,IsDeleted=0。列名導(dǎo)出表列名導(dǎo)出表StudentIDUsersClassIDUsersStudentNameUsersIsDeletedUsers系統(tǒng)總體構(gòu)架設(shè)計(jì)目前開發(fā)網(wǎng)絡(luò)考試系統(tǒng)的模式通常有兩種:一種是B/S(瀏覽器/服務(wù)器)模式,另一種是C/S(客戶/服務(wù)器)模式。傳統(tǒng)的C/S結(jié)構(gòu)是指若干客戶端連接一個(gè)服務(wù)端,通過這樣的交互方式來進(jìn)行工作。這就需要分別編寫服務(wù)器端和客戶端軟件,且客戶機(jī)需要安裝客戶端軟件,給以后的維護(hù)帶來很大麻煩。在這樣的方式下,受到限制的因素很多,比如不同網(wǎng)段下的客戶端與服務(wù)器連接會非常麻煩等。而B/S結(jié)構(gòu)是指瀏覽器/服務(wù)器模式。在這種方式下,程序的設(shè)計(jì)只需在服務(wù)器端就可以完成,客戶機(jī)只要有瀏覽器便可正常工作。B/S帶來的最大好處就是不受地域限制,只要網(wǎng)絡(luò)是連通的,并且在系統(tǒng)維護(hù)時(shí)只要在服務(wù)器端進(jìn)行,不需要分發(fā)到每個(gè)客戶機(jī),實(shí)現(xiàn)客戶端零維護(hù),大大節(jié)省了人力、物力、時(shí)間、費(fèi)用。系統(tǒng)層次結(jié)構(gòu)圖系統(tǒng)流程圖學(xué)生做答模塊流程圖用戶登錄管理模塊流程圖試卷管理模塊流程圖題庫管理模塊流程圖小結(jié)本章是對系統(tǒng)設(shè)計(jì)目標(biāo)、開發(fā)語言、工具,運(yùn)行環(huán)境、后臺數(shù)據(jù)庫、數(shù)據(jù)庫設(shè)計(jì)、系統(tǒng)框架的簡單介紹。并詳細(xì)介紹了系統(tǒng)數(shù)據(jù)庫基本表和視圖的設(shè)計(jì)。
系統(tǒng)主要功能模塊設(shè)計(jì)登陸模塊每個(gè)用戶要進(jìn)入系統(tǒng)都必須先到登陸模塊。在此頁面,如果你已經(jīng)注冊了帳號和密碼,那么可以直接輸入帳號、密碼登陸,如果之前未注冊過,則必須先注冊,然后再登陸。Admin用戶(如教師)直接用指定的帳號登陸,學(xué)生的帳號即為學(xué)號。注冊模塊Admin用戶無需注冊,只有Users用戶需要注冊。在注冊界面,用戶選擇自己的班級和學(xué)號,并填上自己的真實(shí)姓名和登陸用的密碼按“確定”進(jìn)行注冊。學(xué)號唯一,若與別人相同則無法注冊。學(xué)生模塊學(xué)生在登陸的時(shí)候,根據(jù)其用戶類型,跳轉(zhuǎn)到由user.js控制的學(xué)生用戶的首頁面。當(dāng)你進(jìn)入時(shí)會顯示“用戶名你好,歡迎進(jìn)入…”以“welcome”及字樣。密碼修改模塊用戶如果需要修改自己的用戶密碼,可以點(diǎn)擊上面的“修改密碼”按鈕,跳轉(zhuǎn)到密碼修改界面,只要重新輸入新密碼,確認(rèn)一下就可以了。答題模塊學(xué)生等入后,到了考試時(shí)間就要開始答題。按“答題”按鈕就可以進(jìn)入答題頁面。學(xué)生考試完畢或者考試時(shí)間到了以后,要按“提交”按鈕提交考卷。對于程序題要上傳程序文件(EXE)和源碼文件(RAR)。教師模塊教師在登陸的時(shí)候,根據(jù)其用戶類型,跳轉(zhuǎn)到由admin.js控制的管理者用戶的首頁面。當(dāng)你進(jìn)入時(shí)和學(xué)生用戶一樣,會顯示“用戶名你好,歡迎進(jìn)入…”以“welcome”及字樣。和學(xué)生用戶不同的是由admin.js控制的操作功能模塊的不同。下面將一一列出了管理者所能操作的模塊:班級管理模塊在班級管理模塊中,老師可以看到各班的人數(shù)和班級成員,還可以對班級進(jìn)行增加、刪除等操作??颇抗芾砟K每個(gè)教師根據(jù)自己所教授的課程添加科目,如果你所教的科目已經(jīng)有其他老師添加過了,那么你可以和其他老師共用一個(gè),或者在添加科目時(shí)加上標(biāo)記以示區(qū)別。如數(shù)據(jù)庫,可以用數(shù)據(jù)庫04、數(shù)據(jù)庫05以作區(qū)分。試卷管理模塊在選題界面,首先顯示的是各門的科目名稱。按科目后面相對應(yīng)的“增加”按鈕即可跳轉(zhuǎn)到試卷設(shè)置頁面,再次輸入試卷的名稱,并對整份試卷的結(jié)構(gòu)進(jìn)行設(shè)置,分?jǐn)?shù)的分布、各題型數(shù)量的分布??偡值陀诨虺?00分時(shí)總分?jǐn)?shù)顯示呈紅色以示警告。設(shè)置好后按“確定”按鈕進(jìn)入選題界面,選好題后按“添加到試卷中”按鈕向數(shù)據(jù)庫提交數(shù)據(jù),一份考卷也就設(shè)置完成了,也可以按“返回”按鈕重新對考卷進(jìn)行設(shè)置。如果對之前設(shè)置的考卷不滿意,有需要修改的地方,你可以按“編輯”按鈕進(jìn)入考卷設(shè)置界面,再到選題界面,直到滿意為止。要將一份考卷用于當(dāng)前考試時(shí),只要按前面“用于考試”按鈕即可,在上面會顯示“當(dāng)前考試試卷為:當(dāng)前考試用考卷名”。選擇題管理模塊進(jìn)入選擇題管理界面,選擇科目,頁面將顯示出此科目目前已有的選擇題題目和對應(yīng)的正確答案,單項(xiàng)選擇在前,多項(xiàng)選擇在后。用戶可按上方的“添加單選題”、“添加多選題”添加題目,也可以按題目相后面對應(yīng)的“編輯”按鈕對題目進(jìn)行修改,也可以刪除題目。題目的添加和編輯頁面是同一個(gè)頁面,對題干、備選答案和正確答案進(jìn)行設(shè)置,按確認(rèn)添加成功。在添加、編輯頁面有一個(gè)“公共”的復(fù)選框,如果選中這個(gè)框,則在其他科目也將顯示著題題目,也可對其進(jìn)行其它操作。但選題和多選題的添加、編輯界面的不同之處在于正確答案設(shè)置處,單選題用的是單選框(radio),而多選題用的是復(fù)選框(Checkbox)。填空題管理模塊進(jìn)入填空題管理界面,選擇科目,頁面將顯示出此科目目前已有的填空題題目和對應(yīng)的正確答案。用戶可按上方的“添加填空題”添加題目,也可以按題目后面相對應(yīng)的“編輯”按鈕對題目進(jìn)行修改,也可以刪除題目。題目的添加和編輯頁面是同一個(gè)頁面,對題干和正確答案進(jìn)行設(shè)置,按確認(rèn)添加成功。在添加、編輯頁面有一個(gè)“公共”的復(fù)選框,如果選中這個(gè)框,則在其他科目也將顯示著題題目,也可對其進(jìn)行其它操作。值得提出的是,因?yàn)樵O(shè)計(jì)的關(guān)系,每題填空題的空格限制在四個(gè)以內(nèi)。判斷題管理模塊進(jìn)入判斷題管理界面,選擇科目,頁面將顯示出此科目目前已有的判斷題題目和對應(yīng)的正確答案。用戶可按上方的“添加斷題題”添加題目,也可以按題目后面相對應(yīng)的“編輯”按鈕對題目進(jìn)行修改,也可以刪除題目。題目的添加和編輯頁面是同一個(gè)頁面,對題干和正確答案進(jìn)行設(shè)置,按確認(rèn)添加成功。在添加、編輯頁面有一個(gè)“公共”的復(fù)選框,如果選中這個(gè)框,則在其他科目也將顯示著題題目,也可對其進(jìn)行其它操作。程序題管理模塊進(jìn)入程序題管理界面,選擇科目,頁面將顯示出此科目目前已有的程序題題目和對應(yīng)的正確答案。用戶可按上方的“添加程序題”添加題目,也可以按題目后面相對應(yīng)的“編輯”按鈕對題目進(jìn)行修改,也可以刪除題目。題目的添加和編輯頁面是同一個(gè)頁面,對題干和正確答案進(jìn)行設(shè)置,按確認(rèn)添加成功。在添加、編輯頁面有一個(gè)“公共”的復(fù)選框,如果選中這個(gè)框,則在其他科目也將顯示著題題目,也可對其進(jìn)行其它操作。答題測試模塊當(dāng)教師設(shè)置未能考卷后可以對這份考卷進(jìn)行答題測試,但是之前要將這份考卷設(shè)置為當(dāng)前考試試卷,否則會顯示其他設(shè)置為考試的考卷,如果目前沒有考試試卷則跳出“請選擇試卷”消息框,然后跳轉(zhuǎn)到試卷管理頁面選擇當(dāng)前考試試卷。測試答題完后,可按“查看答案”看看自己的答題情況,如果你答對了題目的下方將顯示“恭喜你,答對了!”,反之則顯示正確答案。查看考試結(jié)果模塊學(xué)生考試完成后,教師可以若要了解其情況,即可到這個(gè)頁面查看。首先要選擇班級科目、試卷名稱、班級,點(diǎn)擊“查看”進(jìn)入,下面既有學(xué)生這份考卷各題得分和試卷總分。想看某位學(xué)生的答題情況點(diǎn)擊其后面的“查看”按鈕即可。重點(diǎn)、難點(diǎn)代碼設(shè)計(jì)時(shí)間控制的實(shí)現(xiàn)時(shí)間控制是學(xué)生考試系統(tǒng)一個(gè)很重要的組成部分。一直以來的考試都有規(guī)定在一定的時(shí)間內(nèi)完成,否則考試就失去了它本身的意義。在本系統(tǒng)中,應(yīng)用一個(gè)label控件來實(shí)現(xiàn)時(shí)間的倒計(jì)時(shí)。學(xué)生進(jìn)入系統(tǒng)第一次考某份考卷點(diǎn)擊“答題”按鈕時(shí),把當(dāng)前時(shí)間寫入ExamTime表中。與此同時(shí),讀取ExamTime表中相應(yīng)的TimeLong的值(第一次開始考試的時(shí)間)和Paper表中ExamTime的值(考試規(guī)定時(shí)長),將讀取的TimeLong的值放在DateTime的結(jié)構(gòu)體中名為beginTime;再將這個(gè)時(shí)間加上試卷的考試時(shí)長得到最遲交卷的時(shí)間,也將它存放在DateTime結(jié)構(gòu)體中,名為endTime。將當(dāng)前時(shí)間放在另一個(gè)DateTime的結(jié)構(gòu)體名為dtNow,考生當(dāng)前考試剩余時(shí)間為:endTime-dtNow,這個(gè)結(jié)果是一個(gè)TimeSpan結(jié)構(gòu)(其實(shí)際格式為:hh:mm:ss),將它顯示在label控件上。實(shí)現(xiàn)代碼如下所示:{doubletimeLong=double.Parse(paper.GetExamTime(ID).ToString());ExamBiz.ExamTimeexamTime=newSTGROUP.ExamBiz.ExamTime();DateTimebeginTime=DateTime.Parse(examTime.GetStudentExamTime(ID,userid).ToString());DateTimedt=DateTime.Now;DateTimeendTime=beginTime.AddMinutes(timeLong);TimeSpantimeSpan=endTime.Subtract(dt);if(endTime<=dt){lbExamTime.Text="0:00:00";}elselbExamTime.Text=timeSpan.ToString();}時(shí)間的倒計(jì)時(shí)和刷新部分是通過腳本來實(shí)現(xiàn)的,在考試結(jié)束前3分鐘將彈出提交提示,具體代碼如下:倒計(jì)時(shí)實(shí)現(xiàn)代碼:<scriptlanguage=javascript> varh=2; varm=0; vars=0; functionwindow.onload() { vardiv=window.parent.document.getElementById('ifmContent'); div.style.height=document.body.scrollHeight+10; vartm=document.getElementById("lbExamTime").innerText; h=parseInt(tm.split(":")[0]);m=parseInt(tm.split(":")[1]);s=parseInt(tm.split(":")[2]); } functionshowTime() { if(h==0&&m==0&&s==0) { flag=false; return; } if(h==0&&m==3&&s==0) { alert('考試時(shí)間只剩最后三分鐘,請檢查考卷并在剩余時(shí)間內(nèi)提交!') } s--; if(s<0) { s=59; m--; } if(m<0) { m=59; h--; } document.getElementById("lbExamTime").innerText=h+":"+(m<10?("0"+m):m)+":"+(s<10?("0"+s):s); }</script>時(shí)間刷新實(shí)現(xiàn)代碼,每1000ms做showTime這個(gè)函數(shù)一次。<scripttype="text/javascript">t=setInterval("showTime()",1000);</script>自動閱卷的實(shí)現(xiàn)自動閱卷功能是本系統(tǒng)有別于其他考試系統(tǒng)的地方,是本系統(tǒng)的重點(diǎn)。自動閱卷包括客觀題和主觀題,客觀題和主觀題中的填空題采用匹配的方式,如果匹配得到兩個(gè)是相同的,則正確;主觀題中的變成體則采用C#中的反射技術(shù)來實(shí)現(xiàn)。1、客觀題和填空題部分:這些題型題目的正確答案在添加題目的時(shí)候一起被寫入數(shù)據(jù)庫相應(yīng)的題庫表中,如單選題的在Single表中,判斷題的在Judge表中,考生所作的答案都存放在數(shù)據(jù)庫中的所有*Answer表中,如單選題在SingleAnswer表中,判斷題在JudgeAnswer表中。將*Answer表中的答案與題庫表中的正確答案相匹配,一樣的說明正確,則把相應(yīng)的信息如:PaperID、StudentID、PaperDataID、Score、Type等在視圖Student*View中輸出。再把PaperID、StudentID相同的Score的值相加,就可以得到指定考卷、考生類型為Type值的得分。具體實(shí)現(xiàn)代碼如下所示:ExamBiz.Useruser=newSTGROUP.ExamBiz.User();ExamBiz.Identityidentity=newExamBiz.Identity(User.Identity.Name);longuserid=identity.UserID;foreach(DataGridItemdgindgSingle.Items){RadioButtonListrblTemp=(RadioButtonList)dg.FindControl("rblAnswer");LabellbPaperDataID=(Label)dg.FindControl("PaperDataID");intPaperDataID=int.Parse(lbPaperDataID.Text);ExamBiz.SingleAnswerSingleAnswer=newSTGROUP.ExamBiz.SingleAnswer();stringtemp=rblTemp.SelectedValue;SingleAnswer.InsertSingleAnswer(PaperDataID,userid,rblTemp.SelectedValue);}foreach(DataGridItemdgindgMore.Items){CheckBoxListcblTemp=(CheckBoxList)dg.FindControl("cblAnswer");LabellbPaperDataID=(Label)dg.FindControl("PaperDataID");intPaperDataID=int.Parse(lbPaperDataID.Text);ExamBiz.MoreAnswerMoreAnswer=newSTGROUP.ExamBiz.MoreAnswer();stringtemp="";foreach(ListItemliincblTemp.Items){if(li.Selected)temp+="1";elsetemp+="0";}MoreAnswer.InsertMoreAnswer(PaperDataID,userid,int.Parse(temp));}foreach(DataGridItemdgindgJudge.Items){CheckBoxcbTemp=(CheckBox)dg.FindControl("cbAnswer");LabellbPaperDataID=(Label)dg.FindControl("PaperDataID");intPaperDataID=int.Parse(lbPaperDataID.Text);ExamBiz.JudgeAnswerJudgeAnswer=newSTGROUP.ExamBiz.JudgeAnswer();inttemp=0;if(cbTemp.Checked)temp=1;elsetemp=0;JudgeAnswer.InsertJudgeAnswer(PaperDataID,userid,temp);}foreach(DataGridItemdgindgSpace.Items){LabelPaperDataID=(Label)dg.FindControl("PaperDataID");intSpacePaperDataID=int.Parse(PaperDataID.Text);TextBoxtbSpace1=(TextBox)dg.FindControl("tbSpace1");stringspace1=tbSpace1.Text;TextBoxtbSpace2=(TextBox)dg.FindControl("tbSpace2");stringspace2=tbSpace2.Text;TextBoxtbSpace3=(TextBox)dg.FindControl("tbSpace3");stringspace3=tbSpace3.Text;TextBoxtbSpace4=(TextBox)dg.FindControl("tbSpace4");stringspace4=tbSpace4.Text;ExamBiz.SpaceAnswerSpaceAnswer=newSTGROUP.ExamBiz.SpaceAnswer();SpaceAnswer.InsertSpaceAnswer(SpacePaperDataID,userid,space1,space2,space3,space4);}2、編程題部分:反射式C#中的一種技術(shù),它的具體功能將在下面一節(jié)進(jìn)行介紹。編程題閱卷采用反射方法來實(shí)現(xiàn)。在本系統(tǒng)中,編程題分為兩類,一類是由輸入輸出的(按結(jié)果),一類是沒有輸出結(jié)果的(按過程),這兩種不同的題型要用不同的閱卷方法。它通過對上傳的exe文件進(jìn)行反射操作來實(shí)現(xiàn),現(xiàn)用反射得到exe的類、方法和屬性,對于按結(jié)果的,則調(diào)用其方法,傳入正確答案里的參數(shù),將其返回結(jié)果與正確答案的結(jié)果相對比,一樣,說明正確;對于按過程的,則同時(shí)對exe文件和正確答案進(jìn)行反射操作,將兩邊結(jié)果進(jìn)行匹配,和正確答案反射出來的一樣,說明正確。此題得分=答對個(gè)數(shù)/全部問題數(shù)*此題總分,最后的正樹部分將是此題的得分。反射操作部分代碼:publicAssProgram(stringassemblyName,stringstrFunInfo,outstringErrMsg,int_flag){try{//加載程序集assembly=Assembly.LoadFrom(assemblyName);}catch(Exceptione){ErrMsg=e.Message;return;}ErrMsg="";//獲得程序集里面的所有類types=assembly.GetTypes();FunInfo=strFunInfo;FunInfo=FunInfo.ToLower();flag=_flag;}分解函數(shù)信息privatestring[]AnalyzeFunInfo(){FunInfo=FunInfo.Replace("<br>",";");FunInfo=FunInfo.Replace(";;",";");FunInfo=FunInfo.Replace(";{;","{");FunInfo=FunInfo.Replace(";};","");if(flag==0){string[]Funs=FunInfo.Split(newchar[]{';','(',')'});for(inti=0;i<Funs.Length;i++){Funs[i]=Funs[i].Trim(newchar[]{'=',''});}returnFuns;}elseif(flag==1){string[]Funs=FunInfo.Split(newchar[]{';','{'});intc=0,f=0,a=0;for(inti=0;i<Funs.Length;i++){if(Funs[i].Contains("class")){if(Funs[i].Contains("public"))sClass[c].consType=1;elseif(Funs[i].Contains("protected"))sClass[c].consType=2;elseif(Funs[i].Contains("private"))sClass[c].consType=3;elseif(Funs[i].Contains("static"))sClass[c].consType=4;elsesClass[c].consType=3;string[]temp=Funs[i].Split(newchar[]{''});sClass[c].className=temp[temp.Length-1];c++;}elseif(Funs[i].Contains("(")&&Funs[i].Contains(")")){if(Funs[i].Contains("public"))sFunc[f].consType=1;elseif(Funs[i].Contains("protected"))sFunc[f].consType=2;elseif(Funs[i].Contains("private"))sFunc[f].consType=3;elseif(Funs[i].Contains("static"))sFunc[f].consType=4;elsesFunc[f].consType=3;string[]temp=Funs[i].Split(newchar[]{'('});string[]temp2=temp[0].Split(newchar[]{''});sFunc[f].funName=temp2[temp2.Length-1];sFunc[f].funType=temp2[temp2.Length-2];f++;}else{if(Funs[i].Contains("public"))sAttr[a].consType=1;elseif(Funs[i].Contains("protected"))sAttr[a].consType=2;elseif(Funs[i].Contains("private"))sAttr[a].consType=3;elseif(Funs[i].Contains("static"))sAttr[a].consType=4;elsesAttr[a].consType=3;string[]temp=Funs[i].Split(newchar[]{''});sAttr[a].attrName=temp[temp.Length-1];sAttr[a].attrType=temp[temp.Length-2];a++;}}returnFuns;}elsereturnnull;}遍歷整個(gè)程序集:publicobject[]DoAssembly(){string[]Funs=AnalyzeFunInfo();object[]FunsReturn=newobject[Funs.Length];for(intr=0;r<FunsReturn.Length;r++){FunsReturn[r]=false;}intj=0;if(flag==0){for(inti=0;i<Funs.Length;i++){foreach(Typetypeintypes){//從類中獲得方法集信息MethodInfo[]methods=type.GetMethods(flags);StringBuilderfailureExcuses=newStringBuilder();//遍歷方法集foreach(MethodInfominmethods){try{if(Funs[i].ToLower()==m.Name.ToLower()){string[]args=Funs[i+1].Split(newchar[]{','});FunsReturn[j]=AttemptMethod(type,m,args).ToString();FunsReturn[j+1]=Funs[i+2];if(FunsReturn[j].ToString()==Funs[i+2])FunsReturn[j+2]=true;elseFunsReturn[j+2]=false;i+=3;j+=3;}}catch(CustomExceptione){failureExcuses.Append(e.Message+"\n");continue;}}}}}elseif(flag==1){foreach(Typetypeintypes){//從類中獲得方法集信息MethodInfo[]methods=type.GetMethods(flags);StringBuilderfailureExcuses=newStringBuilder();PropertyInfo[]propertys=type.GetProperties(flags);intc=0,f=0;if(sClass[c].className!=null){if(type.Name.ToLower()==sClass[c].className){FunsReturn[c]=true;}elseFunsReturn[c]=false;c++;}//遍歷方法集foreach(MethodInfominmethods){for(f=0;f<sFunc.Length;f++){if(sFunc[f].funName!=null){if(sFunc[f].funName.ToLower()==m.Name.ToLower()&&sFunc[f].funType==m.ReturnType.Name.ToString().ToLower()){FunsReturn[f+c]=true;break;}elseif(FunsReturn[f+c]==null||!((bool)FunsReturn[f+c]))FunsReturn[f+c]=false;}}}foreach(PropertyInfopinpropertys){for(inta=0;a<sAttr.Length;a++){if(sAttr[a].attrName!=null){if(sAttr[a].attrName.ToLower()==p.Name.ToLower()&&sAttr[a].attrType==p.PropertyType.Name.ToString().ToLower()){FunsReturn[a+f+c-1]=true;a++;}elseif(FunsReturn[a+f+c-1]==null||!((bool)FunsReturn[a+f+c-1]))FunsReturn[a+f+c-1]=false;}}}}}returnFunsReturn;}測試方法的返回值privatestaticObjectAttemptMethod(Typetype,MethodInfomethod,string[]args){//獲得實(shí)例所反射的方法的參數(shù)集ParameterInfo[]param=method.GetParameters();
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度個(gè)人二手車買賣合同車輛交易信息保密合同
- 二零二五年度水庫漁業(yè)養(yǎng)殖資源整合與開發(fā)合同3篇
- 2025版農(nóng)村集體建設(shè)用地土地承包經(jīng)營權(quán)租賃合同3篇
- 2025年度新能源設(shè)備承攬加工合同4篇
- 二零二五年度新能源儲能系統(tǒng)安裝服務(wù)合同模板2篇
- 2025版大型企業(yè)食堂原材料集中采購合同模板2篇
- 二零二五年度度假酒店房間長期住宿合同模板3篇
- 2025材料買賣供應(yīng)合同
- 2025減虧包干合同范文
- 2025版押一付三酒店分租合同模板參考2篇
- 湖北省黃石市陽新縣2024-2025學(xué)年八年級上學(xué)期數(shù)學(xué)期末考試題 含答案
- 硝化棉是天然纖維素硝化棉制造行業(yè)分析報(bào)告
- 央視網(wǎng)2025亞冬會營銷方案
- 《00541語言學(xué)概論》自考復(fù)習(xí)題庫(含答案)
- 《無砟軌道施工與組織》 課件 第十講雙塊式無砟軌道施工工藝
- 2024新版《藥品管理法》培訓(xùn)課件
- 《阻燃材料與技術(shù)》課件 第7講 阻燃橡膠材料
- 爆炸物運(yùn)輸安全保障方案
- 電力安全工作規(guī)程(完整版)
- 借名買車的協(xié)議書范文范本
- 江蘇省南京市2025屆高三學(xué)業(yè)水平調(diào)研考試數(shù)學(xué)試卷(解析版)
評論
0/150
提交評論