軟件體系結構課程設計報告_第1頁
軟件體系結構課程設計報告_第2頁
軟件體系結構課程設計報告_第3頁
軟件體系結構課程設計報告_第4頁
軟件體系結構課程設計報告_第5頁
已閱讀5頁,還剩17頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、精選優質文檔-傾情為你奉上軟件體系結構課程設計報告學院:揚州大學廣陵學院 班級:軟件81301班 學號: 姓名:顧秀堅2016年07月07日目錄1.背景隨著社會的不斷發展,對勞動者和技術人員的知識和能力水平的要求越來越高。考試作為衡量人的能力的重要手段之一,在現代生活中的地位進一步提高,并深入到社會的各個方面。各種各樣的學歷考試、資格證書考試層出不窮。同時,Internet技術的發展使得考試的技術手段和載體發生了革命性的變化,使得考試突破了時間和空間的限制。各大學校已經開始采用課程的上機考核方式,傳統的考試系統已經不能滿足我們了,必須要改革,因此在線考試系統應運而生了。我們在保持原有絕大部分功

2、能的前提下,不僅需發完善原有功能,加入許多新的功能,使得題目管理,上機考試,試卷評分,考試分析更加方便完善。2.開發環境硬件環境:PC機一臺,臺式電腦軟件環境:Microsoft visual studio 2010,Microsoft SQL Server 20083.系統設計3.1系統需求分析傳統考試要求老師刻試卷、印試卷、安排考試、監考、收集試卷、評改試卷、講評試卷和分析試卷。這是一個漫長而復雜的過程,已經越來越不適應現代教學的需要。基于Web的在線考試系統可以發揮網絡的優勢,建立大型、高效、共享的題庫和實現隨時隨地的考試,降低考試成本,減少人為干擾,減輕教師負擔,節約人力、物力和財力。

3、3.2數據庫需求分析針對一般考試系統的需求,設計如下所示的數據項和數據結構: 成績表信息:學號,課程名,成績題庫表信息:課程名,題號,題目,類型,分數,選項1,選項 2,選項3,選項4,解答 學生表信息:學號,姓名,密碼本系統應該建立一個穩定的后臺數據庫系統,通過該數據庫管理整個考試系統所需的信息(用戶信息、試題信息、試卷信息、考試信息等)。3.3系統可行性分析3.3.1要求與目標:n 系統的主要功能即學生管理、試卷管理、題庫管理、成績 管理等n 數據庫可并發訪問并具有較大的吞吐量n 用戶必須有登陸密碼,具有較好的安全保密性n 系統界面具有一定的人性化和美觀.n 開發成員各盡其責,有良好的合作

4、精神n 分享開發環境軟件及項目相關資料,節省項目成本并提高開發效率3.3.2可行性研究方法在學生和老師里使用問卷調查方法,完善可行性方案。確定軟件的運行平臺:win98win7xpwin2000等。在運行時可以直觀的瀏覽、查詢和掌握學生的考試情況和成績信息,解決了傳統考試中的弊端:工作量大、錯誤率高等。3.3.3決定可行性的主要因素資金充足、技術能力強、開發人員的恒心和決心、合作精神3.3.4技術可行性軟件方面,網絡化考試需要的各種軟件環境都已具備,數據庫服務器方面則有SQL Server,均能夠處理大量數據,同時保持數據的完整性并提供許多高級管理功能。其靈活性、安全性和易用性為數據庫編程提供

5、了良好的條件。因此,系統的軟件開發平臺已成熟可行。硬件方面,科技飛速發展的今天,硬件更新的速度越來越快,容量越來越大,可靠性越來越高,價格越來越低,其硬件平臺完全能滿足此系統的需要。3.3.5經濟可行性資金的流出,將來可以用帶來的效益來平衡。4.數據庫設計成績表題庫表學生表5.代碼設計5.1數據庫操作的公共類類DBHelper.csusing System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Data;using System.Data.SqlClient; publi

6、c class DBHelper public DBHelper() public static DataSet GetDataSet(string sql) SqlConnection conn = new SqlConnection(GetConnStr(); SqlDataAdapter da = new SqlDataAdapter(sql, conn); DataSet ds = new DataSet(); da.Fill(ds); return ds; public static SqlDataReader GetReader(string sql) SqlDataReader

7、dr = null; SqlConnection conn = new SqlConnection(GetConnStr(); SqlCommand cmd = new SqlCommand(sql, conn); conn.Open(); try dr = cmd.ExecuteReader(CommandBehavior.CloseConnection); catch conn.Close(); return dr; public static int ExecScalar(string sql) int ret; SqlConnection conn = new SqlConnectio

8、n(GetConnStr(); SqlCommand cmd = new SqlCommand(sql, conn); conn.Open(); try ret = (int)cmd.ExecuteScalar(); finally conn.Close(); return ret; public static int ExecSql(string sql) int ret; SqlConnection conn = new SqlConnection(GetConnStr(); SqlCommand cmd = new SqlCommand(sql, conn); conn.Open();

9、try ret = cmd.ExecuteNonQuery(); finally conn.Close(); return ret; public static String GetConnStr() return System.Configuration.ConfigurationSettings.AppSettingsDB; 5.2Web.config 5.3登錄界面Default.aspx.csusing System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.

10、UI;using System.Web.UI.WebControls;using System.Data.SqlClient;public partial class _Default : System.Web.UI.Page protected void Page_Load(object sender, EventArgs e) if (!IsPostBack) lstLesson.DataSource = DBHelper.GetDataSet(select distinct 課程名 from 題庫); lstLesson.DataTextField = 課程名; lstLesson.Da

11、taBind(); protected void LinkButton1_Click(object sender, EventArgs e) protected void InkEnter_Click(object sender, EventArgs e) string sql, stuName, stuNo, lesson; stuNo = txtNo.Text.Trim(); lesson = lstLesson.SelectedValue; sql = String.Format(select * from 學生where 學號 =0 and 密碼=1, stuNo, txtPwd.Te

12、xt.Trim(); SqlDataReader dr = DBHelper.GetReader(sql); if (!dr.Read() Response.Write(alert(登錄失敗,請檢查學號和密碼是否正確!); return; else stuName = dr姓名.ToString(); sql = String.Format(select count(*) from 成績 where 學號 = 0 and 課程名=1, stuNo, lesson); int ret = DBHelper.ExecScalar(sql); if (ret 0) Response.Write(al

13、ert(你已經參加過這門課的考試!); return; SessionstuNo = stuNo; SessionstuName = stuName; Sessionlesson = lesson; Response.Redirect(exam.aspx); protected void lstLesson_SelectedIndexChanged(object sender, EventArgs e) 5.4考試頁面ViewGrade.aspx.csusing System;using System.Collections.Generic;using System.Linq;using Sy

14、stem.Web;using System.Web.UI;using System.Web.UI.WebControls;using System.Data.SqlClient;public partial class Exam : System.Web.UI.Page protected void Page_Load(object sender, EventArgs e) if (SessionstuNo = null | SessionstuNo.ToString() = ) Response.Redirect(Default.aspx); lblLesson.Text = Session

15、lesson.ToString(); lblName.Text = SessionstuName.ToString(); lblNo.Text = SessionstuNo.ToString(); SqlDataReader dr = DBHelper.GetReader(select * from 題庫a where 課程名 = + lblLesson.Text + Order By 題號); int num = 1; while(dr.Read() Literal Literal1 = new Literal(); Literal1.Text = num.ToString() + . +

16、dr題目.ToString() + ( + dr分數.ToString() + 分); PlaceHolder1.Controls.Add(Literal1); ListControl list; if (dr類型.ToString() = 單選) list = new RadioButtonList(); else list = new CheckBoxList(); list.Items.Add(Server.HtmlEncode(dr選項1.ToString(); list.Items.Add(Server.HtmlEncode(dr選項2.ToString(); list.Items.

17、Add(Server.HtmlEncode(dr選項3.ToString(); list.Items.Add(Server.HtmlEncode(dr選項4.ToString(); PlaceHolder1.Controls.Add(list); num = num + 1; dr.Close(); protected void btnSubmit_Click(object sender, EventArgs e) string sql, answer; SqlDataReader dr = DBHelper.GetReader(select * from 題庫where 課程名 = + lb

18、lLesson.Text + Order By 題號); int j = 0; int sum = 0; while (dr.Read() ListControl list = (ListControl)PlaceHolder1.Controls2*j+1; answer = ; for (int i = 0; i list.Items.Count; i+) if (list.Itemsi.Selected) answer+=(i+1).ToString(); if (answer = dr解答.ToString() sum = sum + Convert.ToInt32(dr分數.ToStr

19、ing(); j=j+1; sql=String.Format(insert into 成績(學號,課程名,成績) values (0,1,2),lblNo.Text,lblLesson.Text,sum.ToString(); DBHelper.ExecSql(sql); Response.Redirect(viewGrade.aspx); 5.5成績顯示頁面GridView.aspx.cxusing System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.UI;using System.Web.UI.WebControls;public partial class viewGrade : System.Web.UI.Page protected void Page_Load(object sender, EventArgs e) if(!IsPostBack) if(SessionstuNo=null | SessionstuNo.ToString()=) Response.Redirect(Default.aspx); lblNam

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論