体系结构实验报告_第1页
体系结构实验报告_第2页
体系结构实验报告_第3页
体系结构实验报告_第4页
体系结构实验报告_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、课程实验报告软件系统结构专业软件工程学生姓名刘辉班级软件151学号1510701117指导老师孙莉请预览后下载!实验一 C/S结构应用设计(1)一、 实验目的设计并实现一个基于多层C/S结构的数据库应用,熟悉多层C/S体系结构及其基本处理流程,了解多层结构表现层、业务逻辑层(功能层)、数据访问层所完成的功能,掌握多层C/S结构的数据库应用设计方法,对这三层进行明确分割,并在逻辑上使其独立。学生通过本实验的训练能够熟练掌握对小型数据库应用系统三层结构层次划分方法及系统实现技术。本次实验目的:(1)熟悉并掌握二层C/S软件体系结构的相关知识;(2)掌握二层C/S结构应用系统的分析和设计;(3)掌握

2、一种开发二层C/S结构应用系统的技术线路;(4)实际开发出一个简单的基于二层C/S结构的应用实例个人通讯录管理系统。要求:(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)做完实验后写出本实

3、验的实验报告。二、实验环境奔腾以上计算机,装有SQL Server 2000数据库系统和Visual Studio 2000软件。三、实验内容1、分别采用二层C/S结构和多层C/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:请预览后下载!个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人 分析系统需求,完成软件体系结构设计及模块划分、数据库设计,采用Visual C#实现系统功能四、实验操作过程 在电脑上安装好Microsoft Visual Studio 2010 用于

4、系统的开发需要实际设计开发出一个简单的基于两层C/S结构的应用系统个人通讯录管理系统,主要步骤和内容如下:1、在 SQL Server 2000中建立数据库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,Nisu

5、sertable)=1) Drop table dbo.friend GO /建立表friend Create table dbo.friend (fid int 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的结构请预览后下载!列名数据类型长度

6、允许空是否标识说明FidInt4否是联系人编号,自动递增型FnameVarchar8否否联系人姓名FphoneVarchar12否否联系人电话FaddressVarchar100是否联系人地址新建完friend表之后向表中插入1条记录。以便程序调试时使用。2、在Visual Studio 2000中用C#语言建立用户界面层(UI)程序:Contact项目,主要呈现用户操作界面。 用户的主要操作界面如下:各个控件的属性如下表:空间类型Name属性Text属性Enable属性LabellblName姓名:TrueLabellblPhone电话:TrueLabellblAdress地址:TrueTe

7、xtBoxtxtNameFalseTextBoxtxtPhoneFalseTextBoxtxtAdressFalseButtonbtnOK确定FalseButtonbtnRE取消FalseButtonbtnAdd添加联系人信息TrueButtonbtnEdit修改选中联系人信息TrueButtonbtnDel删除选中联系人信息TrueButtonbtnAbout关于本软件True其中txtAddress控件的Multilane属性为True.最后我们要设置listView属性,将其FullRowSelect属性设置为true,Gridlines属性设置为True,View属性设置为Detail

8、s,并点开Columns属性,添加一列,设置其请预览后下载!Name为fContactID,Text属性为编号,以此方式再为其添加姓名、电话、联系方式。到此,用户图形界面就设计完成了。3、编写应用程序层代码,用于实现数据访问、添加、删除和修改等控制,关键代码如下:(1)数据连接数据库连接的代码如下:string connstr = Data Source=(local);Initial Catalog=contact;user id=sa;password=; 本代码的意思是以用户名为sa登录到本地数据库,密码为空。(2)数据添加、删除和修改等控制的主要代码 显示联系人信息 显示联系人信息由主

9、界面的listview显示,其思路是读取数据库中所有的联系人信息,然后通过Lisview显示。private void getInfo() string sql = select Fid,Fname,Fphone,Faddress from friend; SqlConnection conn = new SqlConnection(connstr); conn.Open (); SqlCommand cmd = new SqlCommand(sql, conn); SqlDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseCo

10、nnection); try this.listView.Items.Clear(); while (reader.Read() string subItems = new string reader.GetInt32(0).ToString(), reader.GetString(1), reader.GetString(2), reader.GetString(3); this.listView.Items.Add(new ListViewItem(subItems); reader.Close(); catch (Exception ex) MessageBox.Show(ex.ToSt

11、ring();请预览后下载! 添加联系人信息 对联系人信息进行添加的操作并录入数据库 public void addInfo(string name, string phone, string address) string sql=insert into friend(Fname,Fphone,Faddress)values(+name+,+phone+,+address+); SqlConnection conn=new SqlConnection(connstr); SqlCommand cmd=new SqlCommand(sql,conn); conn.Open(); cmd.Exe

12、cuteNonQuery(); conn.Close();修改联系人信息 对联系人信息进行修改的操作并录入数据库 private void btnEdit_Click(object sender, EventArgs e) if (this.listView.SelectedItems.Count = 0) MessageBox.Show(请单击选择需要修改的联系人!); return; this.enableInfo(); ListViewItem lvi = this.listView.SelectedItems this.listView.SelectedItems.Count - 1;

13、 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.isAdd = false; this.btnDel.Enabled = false; this.btnAdd.Enabled = false; 删除联系人对联系人信息进行删除的操作并录入数据库private void button5_Click(obj

14、ect sender, EventArgs e) int infoID = this.getselectid(); if (infoID = 0) MessageBox.Show(请选中信息先!);请预览后下载! return; try string sql = delete friend where fid= + infoID; SqlConnection conn = new SqlConnection(connstr); conn.Open(); SqlCommand cmd = new SqlCommand(sql, conn); cmd.ExecuteNonQuery(); conn

15、.Close(); this.getInfo(); catch (Exception ex) MessageBox.Show(ex.Message); 五、实验结果及结论。当我们运行程序时可以看到之前在数据库中插入的数据已经显示在了联系人列表中,我们点击添加联系人信息之后再次插入信息,点击确定后,我们可以看到,新插入的数据已经在联系人列表中了,如下图所示。添加联系人单击确定按钮之后显示通讯上去了:请预览后下载!六、心得体会这次实验让我学会了两层C/S体系结构的设计实现方法,在实验中我也犯了很多低级错误,比如在进行程序编码时要注意C#区分大小写,编写程序时一定要注意;程序要注意保存,并记住保存的

16、位置。本实验为综合性实验,需要多次才能完成,前面的阶段性实验成果后续需要使用。这次实验让我学会了个道理:做事要脚踏实地,一步一步地来,不能着急,遇到问题首先不能着急,静下心来慢慢地检查和解决问题,这才是最好的方法,不然永远不能解决问题,在以后的实验中也要慢慢地学会如何学习,掌握学习的方法最重要。请预览后下载!实验二 C/S结构应用设计(2)一、实验目的设计并实现一个基于多层C/S结构的数据库应用,熟悉多层C/S体系结构及其基本处理流程,了解多层结构表现层、业务逻辑层(功能层)、数据访问层所完成的功能,掌握多层C/S结构的数据库应用设计方法,对这三层进行明确分割,并在逻辑上使其独立。学生通过本实

17、验的训练能够熟练掌握对小型数据库应用系统三层结构层次划分方法及系统实现技术。本次实验目的:(1)熟悉并掌握多层C/S软件体系结构的相关知识;(2)掌握多层C/S结构应用系统的分析和设计;(3)掌握一种开发多层C/S结构应用系统的技术线路;(4)实际开发出一个简单的基于多层C/S结构的应用实例个人通讯录管理系统。实验要求(1)需要预先掌握SQL server 2000数据库基本操作、VS.net(用C#语言)编程技术和多层C/S软件体系结构的概念;(2)进行多层C/S结构应用系统的分析和设计,在实验报告中写出个人通讯录管理系统的设计方案;(3)在SQL server 2000数据库系统中建立数据

18、库并输入数据; (4)在VS.net中用C#语言编写表现层(UI)程序;(5)在VS.net中用C#语言编写业务逻辑层(BLL)程序;(6)完成系统调试,得出正确的实验结果;请预览后下载!(7)做完实验后写出本实验的实验报告。二、实验环境奔腾以上计算机,装有SQL Server 2000数据库系统和Visual Studio 2000软件。三、实验内容1、分别采用二层C/S结构和多层C/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息

19、删除联系人 分析系统需求,完成软件体系结构设计及模块划分、数据库设计,采用Visual C#实现系统功能四、 实验操作过程需要实际设计开发出一个简单的基于多层C/S结构的应用系统个人通讯录管理系统,主要步骤和内容如下:1、在 SQL Server 2000中建立数据库Contact,建立表friend。在创建二层C/S时,我们已经创建了contact数据库,并建立了friend表,这次我们可以直接引用。2、在Visual Studio 2000中用C#语言建立用户界面层(UI)程序:Contact项目,主要呈现用户操作界面。 在创建二层C/S架构中,我们已经创建过此用户图形界面,三层架构的用户

20、图形层(UI)与两层架构一致,所以在此就不再重复。3、在Contact中增加新类ContactDb.cs作为业务逻辑层(BLL)程序。请预览后下载!在业务逻辑层中需要为其添加头文件using System;using System.Collections.Generic;using System.Text;using System.Data;并创建contactDB类using System.Data.SqlClient;namespace Contactclass ContactDB4、编写类文件ContactDb.cs代码,用于实现数据访问控制,关键代码如下:(1)数据连接数据库的访问是由

21、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();其中连接字符窜connStr是contactDB类的

22、域: string connStr = Data source=(local);Initial Catalog=contact;user id=sa;password=;然后建立数据命令对象:SqlCommand cmd = new SqlCommand(sql, conn);数据命令对象cmd使用的数据库连接是conn,而参数sql表示数据命令的数据文本为sql,即数据命令的CommandText属性为sql。(2)数据获取SqlDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection); return rea

23、der;在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),

24、 reader.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

25、), reader.GetString(2), reader.GetString(3)接下来将subItems中的数据封装为listView的一个节点(listViewItem)并添加到listView中:this.listView.Items.Add(new ListViewItem(subItems);reader.Close();至此显示联系人的功能就完成了,其他模块的代码编写与此类似,就不再重复。五、 实验结果及结论。(1)数据库中原有两个数据,分别为彭振东与张三的信息,我们选择修改联系人,修改张三的名字为王麻子,电话为8890,,联系地址为中国,可以看到listView中张三的信息修

26、改了,如下图所示:注册页面:请预览后下载!修改信息:(2)思考题:与二层C/S体系结构比较,三层(多层)体系结构有什么特点?采用三层体系结构在设计时应该注意哪些问题?答:三层体系结构的优点:允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性允许更灵活有效地选用相应的平台和硬件系统三层C/S结构中,应用的各层可以并行开发,各层也可以选择各自最合适的开发语言。允许充分利用功能层有效地隔离层表示层与数据层。三层C/S结构各层间的通信效率若不高,即使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。请预览后下载!六、心得体会这次实验主要是对于三层C/S体系结构的设计和实现,在实验进行

27、中我还是会犯一些错误,但是相对于第一次已经好很多了,在实验过程中我深刻地体会到了三层体系结构的优点,它允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性;允许更灵活有效地选用相应的平台和硬件系统;三层C/S结构中,应用各层可以并行开发,各层也可以选择各自独立最适合的开发语言;允许充分利用功能层有效地隔离表示层与数据层。并且了解了三层与两层之间的区别。三层的结构很分明。这次实验让我学到很多,独立的思考问题并解决问题是锻炼我们独立思考的能力,而且比较学习才能发现其中的奥妙,知识的积累靠的是我们反复地推敲以及思考如何达到目标,很庆幸,我们做到了。请预览后下载!实验三 B/S结构应用设计(1)一

28、、实验目的 设计并实现一个基于B/S结构的数据库应用,熟悉B/S体系结构及其基本处理流程,了解B/S结构系统各部分所完成的功能,掌握B/S结构的数据库应用设计方法。学生通过本实验的训练能够熟练掌握对小型数据库应用系统B/S结构设计及系统实现技术。二、实验环境MyEclips 10、Tomcat、SQL Server 2010三、实验内容1、采用B/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人分析系统需求,完成软件体系结构

29、设计及模块划分、数据库设计,采用ASP.Net(使用C#语言)实现系统功能四、实验操作过程请预览后下载!在MyEclips中新建项目:Structure_Contact。生成项目之后在src下新建包org.action,在org.action包中建立action类,包括:addAction、deleteAction、editAction、mainAction、modifyAction、registerAction类主要步骤如下:(1) 建立addAction类继承ActionSupport类,主要是同于添加用户,主要代码如下:public String execute() throws Exc

30、eptionHttpServletRequest request = ServletActionContext.getRequest(); /markHttpSession session = request.getSession();userfriend = new UserFriend();userfriendid = new UserFriendId();userfrienddaoimp = new UserFriendDaoImp();name = request.getParameter(name);address = request.getParameter(address);ph

31、one = request.getParameter(phone);user = (User)session.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.i

32、nsert(userfriend)ArrayList al = userfrienddaoimp.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;privat

33、e UserFriendId userfriendid;private UserFriendDaoImp userfrienddaoimp;请预览后下载!public String execute() throws Exceptionuserfriend = new UserFriend();userfriendid = new UserFriendId();userfrienddaoimp = new UserFriendDaoImp();HttpServletRequest request = ServletActionContext.getRequest(); /markHttpSess

34、ion session = request.getSession();/markuser = request.getParameter(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

35、 = userfrienddaoimp.getAll(user);session.setAttribute(al, al);return 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 UserFri

36、end userfriend;private UserFriendId userfriendid;private UserFriendDaoImp userfrienddaoimp;public String execute() throws ExceptionHttpServletRequest request = ServletActionContext.getRequest();HttpSession session = request.getSession();userfriendid = new UserFriendId();userfriend = new UserFriend()

37、;userfrienddaoimp = new UserFriendDaoImp();System.out.println(request.getParameter(username); /nullSystem.out.println(request.getParameter(id);/nulluser = request.getParameter(username);请预览后下载!id = Integer.parseInt(request.getParameter(id);name = request.getParameter(name);address = request.getParam

38、eter(address);phone = request.getParameter(phone);userfriendid.setId(id);userfriendid.setUser(user);userfriend.setId(userfriendid);userfriend.setName(name);userfriend.setAddress(address);userfriend.setPhone(phone);if(userfrienddaoimp.update(userfriend)ArrayList al = userfrienddaoimp.getAll(user);ses

39、sion.setAttribute(al, al);return success;elsereturn error;(4)建立org.model包,在包中创建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

40、= username;public User(String username, String password) this.username = username;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(Strin

41、g 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 na

42、me, String address, String phone) this.id = id; = name;this.address = address;this.phone = phone;public UserFriendId getId() return this.id;public void setId(UserFriendId id) this.id = id;public String getName() return ;public void setName(String name) = name;public Strin

43、g getAddress() return this.address;public void setAddress(String address) this.address = address;public String getPhone() return this.phone;public void setPhone(String phone) this.phone = phone;请预览后下载!public class UserFriendId implements java.io.Serializable private Integer id;private String user;pu

44、blic UserFriendId() public UserFriendId(Integer id, String user) this.id = id;this.user = user;public Integer getId() return this.id;public void setId(Integer id) this.id = id;public String getUser() return this.user;public void setUser(String user) this.user = user;public boolean equals(Object other) if (this = other)return true;if (other = null)return false;if (!(other instanceof UserFriendId)retu

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论