电子文档交易市场
安卓APP | ios版本
电子文档交易市场
安卓APP | ios版本
换一换
首页 金锄头文库 > 资源分类 > DOC文档下载
分享到微信 分享到微博 分享到QQ空间

课程4上课日志1+三层架构+

  • 资源ID:131872952       资源大小:275KB        全文页数:9页
  • 资源格式: DOC        下载积分:2金贝
快捷下载 游客一键下载
账号登录下载
微信登录下载
三方登录下载: 微信开放平台登录   支付宝登录   QQ登录  
二维码
微信扫一扫登录
下载资源需要2金贝
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
支付方式: 支付宝    微信支付   
验证码:   换一换

 
账号:
密码:
验证码:   换一换
  忘记密码?
    
1、金锄头文库是“C2C”交易模式,即卖家上传的文档直接由买家下载,本站只是中间服务平台,本站所有文档下载所得的收益全部归上传人(卖家)所有,作为网络服务商,若您的权利被侵害请及时联系右侧客服;
2、如你看到网页展示的文档有jinchutou.com水印,是因预览和防盗链等技术需要对部份页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有jinchutou.com水印标识,下载后原文更清晰;
3、所有的PPT和DOC文档都被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;下载前须认真查看,确认无误后再购买;
4、文档大部份都是可以预览的,金锄头文库作为内容存储提供商,无法对各卖家所售文档的真实性、完整性、准确性以及专业性等问题提供审核和保证,请慎重购买;
5、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据;
6、如果您还有什么不清楚的或需要我们协助,可以点击右侧栏的客服。
下载须知 | 常见问题汇总

课程4上课日志1+三层架构+

上课日志20171110一、三层架构的基本概念和作用1、前三章开发实例的优缺点前三章我们讲解了实例2-1学生信息的增删改查、实例2-2文章阅读器的实现、实例3-3通过一般处理程序及SqlHelper工具类实现对数据库的增删改查,它们的共同特点都是用户界面层直接或者通过SqlHelper工具类直接对数据库进行操作并把结果直接返回到用户界面。效率高,但系统大、界面多、代码多的情况下是不便于代码管理及后期维护的。为什么?形象比喻:2、三层架构的形象理解三层架构/多层架构就是使整个程序的逻辑结构更加清晰、便于代码的管理有利于系统的维护和扩展。笑话:有个村长得意地向他老婆吹牛:“全中国只有四个人比我官大,乡长、县长、省长和国务院总理”。这个笑话也体现了真实社会中分层的现象。社会人群会分层,公司人员结构也会分层,楼房是分层的,甚至做包子的笼屉都是分层的。虽然分层的目的各有不同,但都是为解决某一问题而产生的。所以,分层架构其实是为了解决某一问题而产生的一种解决方案。 从社会的发展来看,社会分工是人类进步的表现 。社会分工的优势就是让适合的人做自己擅长的事情,使平均社会劳动时间大大缩短。3、通常三层架构分为哪三层三层架构就是在项目开发过程中根据代码的不同功能,分别对代码进行存储与调用。通常分为表现层、业务逻辑层、数据访问层,这三层如何理解?如右图所示。表现层(UI层User Interface layer):主要用于存放与用户交互的展示页面(主要实现和用户的交互,接收用户请求或返回用户请求的数据结果的展现,而具体的数据处理则交给业务逻辑层和数据访问层去处理)业务逻辑层(BLL层Business Logic Layer):主要用于存放针对具体问题对数据进行逻辑处理的代码,业务逻辑层承上启下数据访问层(DAL层Data access layer):主要用于存放对原始数据进行操作的代码,它封装了所有与数据库交互的操作,并为业务逻辑层提供数据服务 二、三层架构的趣味理解(三层架构与养猪)及三层架构的优缺点1、趣味理解(三层架构与养猪)2、三层架构的优点和缺点优 点 缺 点代码结构清晰增加了开发成本耦合度降低,可维护性和可扩展性提高降低了系统的性能适应需求的变化,降低维护的成本和时间在表现层中增加一个功能,为保证其设计符合分层式结构,就需要在相应的业务逻辑层和数据访问层中都增加相应的代码三、三层架构的登录功能(实例4-1)搭建三层项目基本结构1、实例功能展示通过完整源代码展示2、数据库创建及说明ItcastUserLogin(id为自动增长)3、搭建三层项目基本结构(1)新建解决方案Module4,同时添加数据访问层(类库)Lesson1DAL(2)右击解决方案Module4,添加业务逻辑层(类库)Lesson1BLL(3)右击解决方案Module4,添加表现层(ASP.NET空web应用程序)Lesson1UI四、为实例4-1实现数据访问层功能1、右击解决方案Module4,添加实体模型层(类库)Model在实际开发中往往会有大量的数据需要处理,所以通常都会在项目中创建一个数据库实体模型层。(实例2-2文章阅读器创建过)2、在Model层中添加表实体类即添加“UserLogin.cs”类文件对应数据库表UserLogin,所以也叫表实体类。可以这样理解 实体类作为数据容器,在层间传递注意:类加public修饰符、自动属性的理解、自动生成的Class1.cs类可以删除3、在数据访问层Lesson1DAL中添加对数据实体模型层Modle的引用右击Lesson1DAL层的引用添加引用,右侧选择解决方案,再选择到Model。4、在Lesson1DAL中创建UserLoginDal.cs类文件,为该类添加SelectUserLogin()方法,用于查询与用户名相对应的数据注意/提问:(1)前面仅仅添加了引用Modle还不够,还要在Lesson1DAL层的类文件中添加相应类所在的命名空间(Modle)(2)把工具类SqlHelper复制到Lesson1DAL层中,并添加引用System.Configuration和添加命名空间using System.Configuration、SqlHelper所在命名空间(3)在表现层的Web.Config文件中增加连接数据库字符串5、核心代码public class UserLoginDal/注意:需要添加public修饰符,否则其他层访问不到 public UserLogin SelectUserLogin(string UserName) string sql = "select * from UserLogin where userName=userName" SqlParameter para = new SqlParameter("userName", UserName); UserLogin user = null; using (SqlDataReader reader = SqlHelper.ExecuteReader(sql, para) if (reader.Read() user = new UserLogin(); user.ID = reader.GetInt32(0); user.UserName = reader.GetString(1); user.Pwd = reader.GetString(2); return user; 以上代码根据用户名进行查找用户,并把查找到的用户信息封装到UserLogin对象。提问:如果user为null说明什么?五、为实例4-1实现业务逻辑层功能1、为业务层添加引用在Lesson1DAL层中获取到数据库中的数据后,接下来就可以在LessonBLL业务逻辑层来调用数据访问层返回的数据,并返回给UI层。也即业务逻辑层要对数据访问层进行访问。因此要在业务层添加对数据访问层的引用,同时还要添加对Model层的引用。2、核心代码public class UserLoginBll private UserLoginDal dal = new UserLoginDal(); public UserLogin GetUserLogin(string UserName) return dal.SelectUserLogin(UserName); 分析层之间是如何的调用。提示:当一个层调用另一个层中的方法时,需要添加方法所在层的引用。六、为实例4-1实现表现层布局1、在表现层Lesson1UI层中添加web窗体Login.aspx2、前台基本布局<div id="divLogin"> <table id="tab"> <tr> <td class="td1">管理员登录</td> <td class="td1"> </td> </tr> <tr> <td class="td2">用户名:</td> <td><asp:TextBox ID="txtUserName" runat="server" Width="160px"></asp:TextBox></td> </tr> <tr> <td class="td2">密码:</td> <td> <asp:TextBox ID="txtPwd" runat="server" TextMode="Password" Width="160px"></asp:TextBox></td> </tr> <tr> <td colspan="2" class="td3"> <asp:ImageButton ID=" ImgBtnLogin" runat="server" ImageUrl="/Image/LoginImage.png" /></td> </tr> </table></div>3、CSS样式<style type="text/css"> #divLogin width:358px; height:276px; background-image:url("Image/DIVBackGroundImage.png"); position:absolute; left:50%; top:50%; margin-top:-138px; margin-left:-179px; #tab width:100%; height:100%; .td1 height: 110px; color:white; font-size:22px; font-family:微软雅黑; .td2 height: 45px; width:120px; color:white; font-size:18px; font-family:微软雅黑; text-align:right; .td3 text-align:center; </style>4、浏览查看效果把表现层Lesson1UI设置为启动项,并设置相关页为起始页,即可启动观看效果,当然最好还是右击相应aspx页面,选择在浏览器中查看。七、为实例4-1实现表现层功能1、添加引用表现层调用业务逻辑层。所以先添加对业务层和实体模型层的引用及引入相应的命名空间。2、主要代码public UserLoginBll bll = new UserLoginBll();

注意事项

本文(课程4上课日志1+三层架构+)为本站会员( y****g)主动上传,金锄头文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即阅读金锄头文库的“版权提示”【网址:https://www.jinchutou.com/h-59.html】,按提示上传提交保证函及证明材料,经审查核实后我们立即给予删除!

温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




关于金锄头网 - 版权申诉 - 免责声明 - 诚邀英才 - 联系我们
手机版 | 川公网安备 51140202000112号 | 经营许可证(蜀ICP备13022795号)
©2008-2016 by Sichuan Goldhoe Inc. All Rights Reserved.