《体系结构实验报告材料.doc》由会员分享,可在线阅读,更多相关《体系结构实验报告材料.doc(28页珍藏版)》请在三一办公上搜索。
1、word课程实验报告软件系统结构实验一 C/S结构应用设计1一、 实验目的设计并实现一个基于多层C/S结构的数据库应用,熟悉多层C/S体系结构与其根本处理流程,了解多层结构表现层、业务逻辑层(功能层)、数据访问层所完成的功能,掌握多层C/S结构的数据库应用设计方法,对这三层进展明确分割,并在逻辑上使其独立。学生通过本实验的训练能够熟练掌握对小型数据库应用系统三层结构层次划分方法与系统实现技术。本次实验目的:1熟悉并掌握二层C/S软件体系结构的相关知识;2掌握二层C/S结构应用系统的分析和设计;3掌握一种开发二层C/S结构应用系统的技术线路;4实际开发出一个简单的基于二层C/S结构的应用实例个人
2、通讯录管理系统。要求:1需要预先掌握SQL server 2000数据库根本操作、VS.net用C#语言编程技术和多层C/S软件体系结构的概念;2进展二层C/S结构应用系统的分析和设计,在实验报告中写出个人通讯录管理系统的设计方案;3在SQL server 2000数据库系统中建立数据库并输入数据; 4在VS.net中用C#语言编写表现层UI程序;5在VS.net中用C#语言编写业务逻辑层BLL程序;6完成系统调试,得出正确的实验结果;7做完实验后写出本实验的实验报告。二、实验环境奔腾以上计算机,装有SQL Server 2000数据库系统和Visual Studio 2000软件。三、实验内
3、容1、分别采用二层C/S结构和多层C/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括某某、住址、 。整个系统的功能图如如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人 分析系统需求,完成软件体系结构设计与模块划分、数据库设计,采用Visual C#实现系统功能四、实验操作过程 在电脑上安装好Microsoft Visual Studio 2010 用于系统的开发需要实际设计开发出一个简单的基于两层C/S结构的应用系统个人通讯录管理系统,主要步骤和内容如下:1、在 SQL Server 2000中建立数据
4、库Contact,建立表friend。(1)建立数据库Contact:Create database contact(2)建立数据库表friend /使用contact数据库USE contact GO /是否存在数据库表friend,如果存在如此删除If exists(select*from dbo.sysobjects where id=object id(Ndbo.friend)and OBJECTPROPERTY (id,Nisusertable)=1)Drop table dbo.friend GO /建立表friendCreate table dbo.friend (fid int
5、 identity(1,1) not null,fname varchar (8) collate Chinese prc ci as not null,fphone varchar (12) collate Chinese prc ci as null,faddress varchar (100) collate Chinese prc ci as null)on primary表1 friend的结构列名数据类型长度允许空是否标识说明FidInt4否是联系人编号,自动递增型FnameVarchar8否否联系人某某FphoneVarchar12否否联系人 FaddressVarchar100
6、是否联系人地址新建完friend表之后向表中插入1条记录。以便程序调试时使用。2、在Visual Studio 2000中用C#语言建立用户界面层UI程序:Contact项目,主要呈现用户操作界面。 用户的主要操作界面如下:各个控件的属性如下表:空间类型Name属性Text属性Enable属性LabellblName某某:TrueLabellblPhone :TrueLabellblAdress地址:TrueTextBoxtxtNameFalseTextBoxtxtPhoneFalseTextBoxtxtAdressFalseButtonbtnOK确定FalseButtonbtnRE取消Fal
7、seButtonbtnAdd添加联系人信息TrueButtonbtnEdit修改选中联系人信息TrueButtonbtnDel删除选中联系人信息TrueButtonbtnAbout关于本软件True其中txtAddress控件的Multilane属性为True.最后我们要设置listView属性,将其FullRowSelect属性设置为true,Gridlines属性设置为True,View属性设置为Details,并点开Columns属性,添加一列,设置其Name为fContactID,Text属性为编号,以此方式再为其添加某某、 、联系方式。到此,用户图形界面就设计完成了。3、编写应用程序
8、层代码,用于实现数据访问、添加、删除和修改等控制,关键代码如下:1数据连接数据库连接的代码如下:string connstr = Data Source=(local);Initial Catalog=contact;user id=sa;password=; 本代码的意思是以用户名为sa登录到本地数据库,密码为空。2数据添加、删除和修改等控制的主要代码显示联系人信息 显示联系人信息由主界面的listview显示,其思路是读取数据库中所有的联系人信息,然后通过Lisview显示。private void getInfo() string sql = select Fid,Fname,Fphon
9、e,Faddress from friend; SqlConnection conn = new SqlConnection(connstr); conn.Open (); Sqlmand cmd = new Sqlmand(sql, conn); SqlDataReader reader = cmd.ExecuteReader(mandBehavior.CloseConnection); try this.listView.Items.Clear(); while (reader.Read() string subItems = new string reader.GetInt32(0).T
10、oString(), reader.GetString(1), reader.GetString(2), reader.GetString(3); this.listView.Items.Add(new ListViewItem(subItems); reader.Close(); catch (Exception ex) MessageBox.Show(ex.ToString(); 添加联系人信息 对联系人信息进展添加的操作并录入数据库public void addInfo(string name, string phone, string address) string sql=inser
11、t into friend(Fname,Fphone,Faddress)values(+name+,+phone+,+address+); SqlConnection conn=new SqlConnection(connstr); Sqlmand cmd=new Sqlmand(sql,conn); conn.Open(); cmd.ExecuteNonQuery(); conn.Close();修改联系人信息 对联系人信息进展修改的操作并录入数据库private void btnEdit_Click(object sender, EventArgs e) if (this.listView
12、.SelectedItems.Count = 0) MessageBox.Show(请单击选择需要修改的联系人!); return; this.enableInfo(); this.listView.SelectedItems.Count - 1; this.txtName.Text = lvi.SubItems1.Text; this.txtPhone.Text = lvi.SubItems2.Text; this.txtAddress.Text = lvi.SubItems3.Text; Fid = Convert.ToInt32(lvi.SubItems0.Text); this.isA
13、dd = false; this.btnDel.Enabled = false; this.btnAdd.Enabled = false; 删除联系人对联系人信息进展删除的操作并录入数据库private void button5_Click(object sender, EventArgs e) int infoID = this.getselectid(); if (infoID = 0) MessageBox.Show(请选某某息先!); return; try string sql = delete friend where fid= + infoID; SqlConnection co
14、nn = new SqlConnection(connstr); conn.Open(); Sqlmand cmd = new Sqlmand(sql, conn); cmd.ExecuteNonQuery(); conn.Close(); this.getInfo(); catch (Exception ex) MessageBox.Show(ex.Message); 五、实验结果与结论。当我们运行程序时可以看到之前在数据库中插入的数据已经显示在了联系人列表中,我们点击添加联系人信息之后再次插入信息,点击确定后,我们可以看到,新插入的数据已经在联系人列表中了,如如下图所示。添加联系人单击确定
15、按钮之后显示通讯上去了:六、心得体会这次实验让我学会了两层C/S体系结构的设计实现方法,在实验中我也犯了很多低级错误,比如在进展程序编码时要注意C#区分大小写,编写程序时一定要注意;程序要注意保存,并记住保存的位置。本实验为综合性实验,需要屡次才能完成,前面的阶段性实验成果后续需要使用。这次实验让我学会了个道理:做事要脚踏实地,一步一步地来,不能着急,遇到问题首先不能着急,静下心来慢慢地检查和解决问题,这才是最好的方法,不然永远不能解决问题,在以后的实验中也要慢慢地学会如何学习,掌握学习的方法最重要。实验二 C/S结构应用设计2一、实验目的设计并实现一个基于多层C/S结构的数据库应用,熟悉多层
16、C/S体系结构与其根本处理流程,了解多层结构表现层、业务逻辑层(功能层)、数据访问层所完成的功能,掌握多层C/S结构的数据库应用设计方法,对这三层进展明确分割,并在逻辑上使其独立。学生通过本实验的训练能够熟练掌握对小型数据库应用系统三层结构层次划分方法与系统实现技术。本次实验目的:1熟悉并掌握多层C/S软件体系结构的相关知识;2掌握多层C/S结构应用系统的分析和设计;3掌握一种开发多层C/S结构应用系统的技术线路;4实际开发出一个简单的基于多层C/S结构的应用实例个人通讯录管理系统。实验要求1需要预先掌握SQL server 2000数据库根本操作、VS.net用C#语言编程技术和多层C/S软
17、件体系结构的概念;2进展多层C/S结构应用系统的分析和设计,在实验报告中写出个人通讯录管理系统的设计方案;3在SQL server 2000数据库系统中建立数据库并输入数据; 4在VS.net中用C#语言编写表现层UI程序;5在VS.net中用C#语言编写业务逻辑层BLL程序;6完成系统调试,得出正确的实验结果;7做完实验后写出本实验的实验报告。二、实验环境奔腾以上计算机,装有SQL Server 2000数据库系统和Visual Studio 2000软件。三、实验内容1、分别采用二层C/S结构和多层C/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修
18、改和删除操作。联系人信息包括某某、住址、 。整个系统的功能图如如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人 分析系统需求,完成软件体系结构设计与模块划分、数据库设计,采用Visual C#实现系统功能四、 实验操作过程需要实际设计开发出一个简单的基于多层C/S结构的应用系统个人通讯录管理系统,主要步骤和内容如下:1、在 SQL Server 2000中建立数据库Contact,建立表friend。在创建二层C/S时,我们已经创建了contact数据库,并建立了friend表,这次我们可以直接引用。2、在Visual Studio 2000中用C#语言建立用户界面层UI
19、程序:Contact项目,主要呈现用户操作界面。 在创建二层C/S架构中,我们已经创建过此用户图形界面,三层架构的用户图形层UI与两层架构一致,所以在此就不再重复。业务逻辑层BLL程序。在业务逻辑层中需要为其添加头文件using System;using System.Collections.Generic;using System.Text;using System.Data;并创建contactDB类using System.Data.SqlClient;namespace Contactclass ContactDB4、编写类文件ContactDb.cs代码,用于实现数据访问控制,关键代
20、码如下:1数据连接数据库的访问是由contactDB类中的getReader方法实现的,在MainForm中,只需要如下代码:SqlDataReader reader = cdb.getReader();getReader方法定义了一个String类型的变量sql,用于保存访问数据库的SQL命令:string sql = select Fid,Fname,Fphone,Faddress FROM friend;接着新建数据库连接对象conn并打开数据连接:SqlConnection conn = new SqlConnection(connStr); conn.Open();其中连接字符窜co
21、nnStr是contactDB类的域: string connStr = Data source=(local);Initial Catalog=contact;user id=sa;password=;然后建立数据命令对象:Sqlmand cmd = new Sqlmand(sql, conn);数据命令对象cmd使用的数据库连接是conn,而参数sql表示数据命令的数据文本为sql,即数据命令的mandText属性为sql。2数据获取SqlDataReader reader = cmd.ExecuteReader(mandBehavior.CloseConnection); return
22、reader;在MainForm的getInfo方法中,获取了由ContactDB类的getReader方法返回的数据阅读器后,接下来要执行的是循环读取阅读器中的信息,然后依次添加到listView中;try SqlDataReader reader = cdb.getReader(); this.listView.Items.Clear(); /去除listView中所有的item while (reader.Read() string subItems = new string reader.GetInt32(0).ToString(), reader.GetString(1), read
23、er.GetString(2), reader.GetString(3); this.listView.Items.Add(new ListViewItem(subItems); reader.Close(); catch (Exception ex) MessageBox.Show(ex.ToString(); while (reader.Read() 每次读取一条记录都将记录中的每个字段的信息封装到string类型的数组中:string subItems = new string reader.GetInt32(0).ToString(), reader.GetString(1), rea
24、der.GetString(2), reader.GetString(3)接下来将subItems中的数据封装为listView的一个节点listViewItem并添加到listView中:this.listView.Items.Add(new ListViewItem(subItems);reader.Close();至此显示联系人的功能就完成了,其他模块的代码编写与此类似,就不再重复。五、 实验结果与结论。(1)数据库中原有两个数据,分别为彭振东与X三的信息,我们选择修改联系人,修改X三的名字为王麻子, 为8890,, 为中国,可以看到listView中X三的信息修改了,如如下图所示:注册
25、页面:修改信息:(2)思考题:与二层C/S体系结构比拟,三层(多层)体系结构有什么特点?采用三层体系结构在设计时应该注意哪些问题?答:三层体系结构的优点:允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性允许更灵活有效地选用相应的平台和硬件系统三层C/S结构中,应用的各层可以并行开发,各层也可以选择各自最适宜的开发语言。允许充分利用功能层有效地隔离层表示层与数据层。三层C/S结构各层间的通信效率假如不高,即使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。六、心得体会这次实验主要是对于三层C/S体系结构的设计和实现,在实验进展中我还是会犯一些错误,但是相对于第一次已经好很多
26、了,在实验过程中我深刻地体会到了三层体系结构的优点,它允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性;允许更灵活有效地选用相应的平台和硬件系统;三层C/S结构中,应用各层可以并行开发,各层也可以选择各自独立最适合的开发语言;允许充分利用功能层有效地隔离表示层与数据层。并且了解了三层与两层之间的区别。三层的结构很清楚。这次实验让我学到很多,独立的思考问题并解决问题是锻炼我们独立思考的能力,而且比拟学习才能发现其中的奥妙,知识的积累靠的是我们反复地推敲以与思考如何达到目标,很庆幸,我们做到了。实验三 B/S结构应用设计1一、实验目的 设计并实现一个基于B/S结构的数据库应用,熟悉B/S体
27、系结构与其根本处理流程,了解B/S结构系统各局部所完成的功能,掌握B/S结构的数据库应用设计方法。学生通过本实验的训练能够熟练掌握对小型数据库应用系统B/S结构设计与系统实现技术。二、实验环境MyEclips 10、Tomcat、SQL Server 2010三、实验内容1、采用B/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括某某、住址、 。整个系统的功能图如如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人分析系统需求,完成软件体系结构设计与模块划分、数据库设计,采用ASP.Net(使用C#语言)实现
28、系统功能四、实验操作过程在MyEclips中新建项目:Structure_Contact。生成项目之后在src下新建包org.action,在org.action包中建立action类,包括:addAction、deleteAction、editAction、mainAction、modifyAction、registerAction类主要步骤如下:(1) 建立addAction类继承ActionSupport类,主要是同于添加用户,主要代码如下:public String execute() throws ExceptionServletRequest request = ServletAc
29、tionContext.getRequest(); /markSession session = request.getSession();userfriend = new UserFriend();userfriendid = new UserFriendId();userfrienddaoimp = new UserFriendDaoImp();name = request.getParameter(name);address = request.getParameter(address);phone = request.getParameter(phone);user = (User)s
30、ession.getAttribute(user);/account and passworduserfriendid.setUser(user.getUsername();/account_nameuserfriend.setId(userfriendid);/id auto-increaseuserfriend.setName(name);userfriend.setAddress(address);userfriend.setPhone(phone);if(userfrienddaoimp.insert(userfriend)ArrayList al = userfrienddaoimp
31、.getAll(user.getUsername();session.setAttribute(al, al);return success;elsereturn error;(2)建立deleteAction类继承ActionSupport类用于删除用户,代码如下:public class deleteAction extends ActionSupportprivate UserFriend userfriend;private String user;private int id;private UserFriendId userfriendid;private UserFriendDa
32、oImp userfrienddaoimp;public String execute() throws Exceptionuserfriend = new UserFriend();userfriendid = new UserFriendId();userfrienddaoimp = new UserFriendDaoImp();ServletRequest request = ServletActionContext.getRequest(); /markSession session = request.getSession();/markuser = request.getParam
33、eter(username);System.out.println(request.getParameter(id);id = Integer.parseInt(request.getParameter(id);userfriendid.setUser(user);userfriendid.setId(id);userfriend.setId(userfriendid);if(userfrienddaoimp.delete(userfriend)ArrayList al = userfrienddaoimp.getAll(user);session.setAttribute(al, al);r
34、eturn success;elsereturn error; (3)建立editAction类继承ActionSupport类,用于编辑用户,代码如下:public class editAction extends ActionSupportprivate String user ;private int id;private String name;private String address;private String phone;private UserFriend userfriend;private UserFriendId userfriendid;private UserFr
35、iendDaoImp userfrienddaoimp;public String execute() throws ExceptionServletRequest request = ServletActionContext.getRequest();Session session = request.getSession();userfriendid = new UserFriendId();userfriend = new UserFriend();userfrienddaoimp = new UserFriendDaoImp();System.out.println(request.g
36、etParameter(username); /nullSystem.out.println(request.getParameter(id);/nulluser = request.getParameter(username);id = Integer.parseInt(request.getParameter(id);name = request.getParameter(name);address = request.getParameter(address);phone = request.getParameter(phone);userfriendid.setId(id);userf
37、riendid.setUser(user);userfriend.setId(userfriendid);userfriend.setName(name);userfriend.setAddress(address);userfriend.setPhone(phone);if(userfrienddaoimp.update(userfriend)ArrayList al = userfrienddaoimp.getAll(user);session.setAttribute(al, al);return success;elsereturn error;(4)建立org.model包,在包中创
38、建User、UserFriend和UserFriendId类,创建User.hbm.xml和UserFriend.hbm.xml文档。public class User implements java.io.Serializable private String username;private String password;public User() public User(String username) this.username = username;public User(String username, String password) this.username = usern
39、ame;this.password = password;public String getUsername() return this.username;public void setUsername(String username) this.username = username;public String getPassword() return this.password;public void setPassword(String password) this.password = password;public class UserFriend implements java.io.Serializable private UserFriendId id;private String name;private String address;private String phone;public UserFriend() public UserFriend(UserFriendId id) this.id = id;public UserFriend(UserFriendId id, String name, String address