标签:style class blog code http ext
在重构机房收费系统之前就一直听说这次重构要用反射+配置文件。深远的作用不知道,但是在这次重构用到,目的还是挺明确的:就是为了更换数据时方便,遵循开放-封闭原则,解决了可维护和可扩展的问题。
下面就以机房收费系统登录为例来看看配置文件+反射的用法。机房收费系统登录用到的数据库表是User_info表(用户表)。我利用的是三层思想,先看一下我的整体架构!
下面看看配置文件+反射+抽象工厂在登录时访问数据库User表时的用法。
步骤:(1)在VS资源管理器的新建项目UI中,会有一个App.config文件。右击“打开”。
打开以后会出现如下结果。
(2)在配置文件中添加参数。
详解:在配置文件中写明是SQLServer还是Access,防止更改应用程序中的代码,利于扩展,避免修改。
(3)在要用到配置文件的项目中添加引用System.configuration(在这里我们Factroy项目中用到了配置文件):选中Factroy右击引用---打开引用界面。
(4)引用界面如下:
在左边“程序集”栏中找到“框架”从右边找到“System.configuration”这项勾选上。这样配置文件基本就完成!
接下来是代码阶段:
'************************************************* '文 件 名:SqlServerUserFactory '命名空间:Factory '内 容:读配置文件来给DB字符串赋值,在配置文件中写明是SQLServer还是Access,想要更换数据库直接改配置文件就行。读配置文件来给DB字符串赋值,在配置文件中写明是SqlServer还是Access,想要更换数据库直接改配置文件就行。前提是:Sqlserver前缀的DAL层类里写的是访问SQLServer数据库的代码。Access前缀的DAL层类里写的是访问Access数据库的代码。 '功 能:用反射+配置文件+抽象工厂,方便更换数据库。 '文件关系: '作 者:宋笑 '小 组:XX '生成日期:2014/6/1 16:14:45 '版 本 号:V1.0.0.0 '修改日志: '版权说明: '************************************************* Imports System.Reflection '添加反射的引用 Imports System.Configuration '添加配置文件的引用 Imports IDAL Public Class SqlServerUserFactory '利用反射+配置文件+抽象工厂 Private Shared ReadOnly AssemblyName As String = "DAL" '定义程序集名称变量,D层命名空间的名字 Private Shared db As String = ConfigurationManager.AppSettings("DB") '表示读取配置文件,如果配置文件中是SQLServer数据库,就访问SQLServer,如果是别的就访问别的,不用更改程序中的代码。 '创建用户表的工厂 Public Function CreateUserInfo() As IUser Dim className As String = AssemblyName + "." + db + "UserDAL" 'DAL层中的SqlServerUserDAl的类名。 Dim iuser As IUser '实例化接口IUser iuser = CType(Assembly.Load(AssemblyName).CreateInstance(className), IUser) '把DAL层的SqlServerUserDAl类转换成IUser接口类型,通过调用接口类中的函数来调用D层中实现该接口函数。 Return iuser End Function End Class
最后总结:相信配置文件不止这一个作用,我们还需要研究。。学习就是慢慢探索的过程。
Effective C++:条款13:以对象管理资源,布布扣,bubuko.com
标签:style class blog code http ext
原文地址:http://blog.csdn.net/u010470972/article/details/29833689