软件体系结构.doc_第1页
软件体系结构.doc_第2页
软件体系结构.doc_第3页
软件体系结构.doc_第4页
软件体系结构.doc_第5页
已阅读5页,还剩20页未读 继续免费阅读

下载本文档

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

文档简介

课程实验报告软件系统结构专业软件工程学生姓名张韬班级B软件121学号1210701132指导老师孙莉实验一 C/S结构应用设计(1)一、 实验目的 设计并实现一个基于多层C/S结构的数据库应用,熟悉多层C/S体系结构及其基本处理流程,了解多层结构表现层、业务逻辑层(功能层)、数据访问层所完成的功能,掌握多层C/S结构的数据库应用设计方法,对这三层进行明确分割,并在逻辑上使其独立。学生通过本实验的训练能够熟练掌握对小型数据库应用系统三层结构层次划分方法及系统实现技术。二实验环境奔腾以上计算机,装有SQL Server 2000数据库系统和Visual Studio 2000软件。三、实验内容1、分别采用二层C/S结构和多层C/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人 分析系统需求,完成软件体系结构设计及模块划分、数据库设计,采用Visual C#实现系统功能四、实验操作过程 在电脑上安装好Microsoft Visual Studio 2010 用于系统的开发需要实际设计开发出一个简单的基于两层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,Nisusertable)=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的结构列名数据类型长度允许空是否标识说明FidInt4否是联系人编号,自动递增型FnameVarchar8否否联系人姓名FphoneVarchar12否否联系人电话FaddressVarchar100是否联系人地址新建完friend表之后向表中插入1条记录。以便程序调试时使用。2、在Visual Studio 2000中用C#语言建立用户界面层(UI)程序:Contact项目,主要呈现用户操作界面。 用户的主要操作界面如下:各个控件的属性如下表:空间类型Name属性Text属性Enable属性LabellblName姓名:TrueLabellblPhone电话:TrueLabellblAdress地址:TrueTextBoxtxtNameFalseTextBoxtxtPhoneFalseTextBoxtxtAdressFalseButtonbtnOK确定FalseButtonbtnRE取消FalseButtonbtnAdd添加联系人信息TrueButtonbtnEdit修改选中联系人信息TrueButtonbtnDel删除选中联系人信息TrueButtonbtnAbout关于本软件True其中txtAddress控件的Multilane属性为True.最后我们要设置listView属性,将其FullRowSelect属性设置为true,Gridlines属性设置为True,View属性设置为Details,并点开Columns属性,添加一列,设置其Name为fContactID,Text属性为编号,以此方式再为其添加姓名、电话、联系方式。到此,用户图形界面就设计完成了。3、编写应用程序层代码,用于实现数据访问、添加、删除和修改等控制,关键代码如下:(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,Fphone,Faddress from friend; SqlConnection conn = new SqlConnection(connstr); conn.Open (); SqlCommand cmd = new SqlCommand(sql, conn); SqlDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection); 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.ToString(); 添加联系人信息 对联系人信息进行添加的操作并录入数据库 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.ExecuteNonQuery(); 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; 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(object 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.Close(); this.getInfo(); catch (Exception ex) MessageBox.Show(ex.Message); 五、实验结果及结论。当我们运行程序时可以看到之前在数据库中插入的数据已经显示在了联系人列表中,我们点击添加联系人信息之后再次插入信息,点击确定后,我们可以看到,新插入的数据已经在联系人列表中了,如下图所示。单击确定按钮之后显示通讯上去了:六、心得体会本次实验完成了实验要求里的内容,遇到一些问题,都得到很好的解决。实验二 C/S结构应用设计(2)一、实验目的 设计并实现一个基于多层C/S结构的数据库应用,熟悉多层C/S体系结构及其基本处理流程,了解多层结构表现层、业务逻辑层(功能层)、数据访问层所完成的功能,掌握多层C/S结构的数据库应用设计方法,对这三层进行明确分割,并在逻辑上使其独立。学生通过本实验的训练能够熟练掌握对小型数据库应用系统三层结构层次划分方法及系统实现技术。二、实验环境奔腾以上计算机,装有SQL Server 2000数据库系统和Visual Studio 2000软件。三、实验内容1、分别采用二层C/S结构和多层C/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人 分析系统需求,完成软件体系结构设计及模块划分、数据库设计,采用Visual C#实现系统功能四、 实验操作过程需要实际设计开发出一个简单的基于多层C/S结构的应用系统个人通讯录管理系统,主要步骤和内容如下:1、在 SQL Server 2000中建立数据库Contact,建立表friend。在创建二层C/S时,我们已经创建了contact数据库,并建立了friend表,这次我们可以直接引用。2、在Visual Studio 2000中用C#语言建立用户界面层(UI)程序:Contact项目,主要呈现用户操作界面。 在创建二层C/S架构中,我们已经创建过此用户图形界面,三层架构的用户图形层(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)数据连接数据库的访问是由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类的域: 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 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), 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), reader.GetString(2), reader.GetString(3)接下来将subItems中的数据封装为listView的一个节点(listViewItem)并添加到listView中:this.listView.Items.Add(new ListViewItem(subItems);reader.Close();至此显示联系人的功能就完成了,其他模块的代码编写与此类似,就不再重复。五、 实验结果及结论。(1)数据库中原有两个数据,分别为彭振东与张三的信息,我们选择修改联系人,修改张三的名字为王麻子,电话为8890,,联系地址为中国,可以看到listView中张三的信息修改了,如下图所示:(2)思考题:与二层C/S体系结构比较,三层(多层)体系结构有什么特点?采用三层体系结构在设计时应该注意哪些问题?答:三层体系结构的优点:允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性允许更灵活有效地选用相应的平台和硬件系统三层C/S结构中,应用的各层可以并行开发,各层也可以选择各自最合适的开发语言。允许充分利用功能层有效地隔离层表示层与数据层。三层C/S结构各层间的通信效率若不高,即使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。6、 心得体会本次实验很顺利,完成了要求。实验三 B/S结构应用设计(1)一、实验目的 设计并实现一个基于B/S结构的数据库应用,熟悉B/S体系结构及其基本处理流程,了解B/S结构系统各部分所完成的功能,掌握B/S结构的数据库应用设计方法。学生通过本实验的训练能够熟练掌握对小型数据库应用系统B/S结构设计及系统实现技术。二、实验环境MyEclips 10、Tomcat、SQL Server 2010三、实验内容1、采用B/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人分析系统需求,完成软件体系结构设计及模块划分、数据库设计,采用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 ExceptionHttpServletRequest request = ServletActionContext.getRequest(); /markHttpSession 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)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.insert(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;private UserFriendId userfriendid;private UserFriendDaoImp userfrienddaoimp;public String execute() throws Exceptionuserfriend = new UserFriend();userfriendid = new UserFriendId();userfrienddaoimp = new UserFriendDaoImp();HttpServletRequest request = ServletActionContext.getRequest(); /markHttpSession 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 = 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 UserFriend 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();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.getParameter(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);session.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 = 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(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, 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 String 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;public 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)return false;UserFriendId castOther = (UserFriendId) other;return (this.getId() = castOther.getId() | (this.getId() != null& castOther.getId() != null & this.getId().equals(castOther.getId()& (this.getUser() = castOther.getUser() | (this.getUser() != null& castOther.getUser() != null & this.getUser().equals(castOther.getUser();public int hashCode() int result = 17;result = 37 * result + (getId() = null ? 0 : this.getId().hashCode();result = 37 * result+ (getUser() = null ? 0 : this.getUser().hashCode();return result;(5)User.hbm.xml,用于数据库中的表User和定义的属性相对应,代码如下: (6)UserFriend.hbm.xml用于数据库中的表UserFriend和定义的属性相对应,代码如下: 五、实验结果及结论(1)用户登录界面显示:(2)用户主界面:(3)编辑界面:(4)思考题:与C/S体系结构比较,B/S体系结构有什么优点?采用B/S与C/S混合体系结构在设计时应该注意哪些问题?答:基于B/S体系结构的软件,系统安装、修改和维护全在服务器端解决。用户在使用系统时,仅需要一个浏览器就可以运行全部的模块,真正达到了“零客户端”的功能,很容易在运行时自动升级。B/S体系结构还提供了异种机、异种网、异种应用服务的联机、联网、统一服务的最现实的开发性基础。6、 心得体会本次实验学到了很多东西,对于要求的内容,也都得到很好的解决。实验四 B/S结构应用设计(1)一、实验目的 设计并实现一个基于B/S结构的数据库应用,熟悉B/S体系结构及其基本处理流程,了解B/S结构系统各部分所完成的功能,掌握B/S结构的数据库应用设计方法。学生通过本实验的训练能够熟练掌握对小型数据库应用系统B/S结构设计及系统实现技术。二、实验环境MyEclips 10、Tomcat、SQL Server 2010三、实验内容1、采用B/S结构实现个人通讯录系统。该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。联系人信息包括姓名、住址、电话。整个系统的功能图如下图所示:个人通讯录查看联系人信息添加联系人修改联系人信息删除联系人分析系统需求,完成软件体系结构设计及模块划分、数据库设计,采用ASP.Net

温馨提示

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

评论

0/150

提交评论