您的位置:首页 > 编程语言

如何利用NB代码生成工具和NBear框架,快速开发WEB项目

2008-11-02 22:07 1121 查看
     如何利用NB代码生成工具和NBear框架,快速开发WEB项目
  
  NBear是一个.Net 2.0下的快速开发框架。它提供了包括可视化实体设计、代码生成、持久化、SOA、MVP等一系列组件。
  
   NBear的设计目标是尽最大可能减少程序员的重复劳动、提高开发效率、提升代码的可维护性和整体质量。
   官方网站:http://nbear.org/
   中文教程目录索引:http://www.cnblogs.com/teddyma/archive/2006/11/07/553562.HTML
   示例程序:从官方网站下载NBearVXXX_tutorials.zip,解压后见tutorials目录。
  
  本文提到的NBear代码生成工具,主要是配合NBear框架更快速开发项目的一种代码生成工具。主要工具是根据数据库生成NBear框架中ServiceInterfaces层ServiceImpls层的代码。提高开发效率。接合本身NBear所带的实体生成工具,和配置文件生成工具。加上本文中的这个工具,可以大大提高项目的开发时间,开发人员只用编写跟业务有关的代码,框架相关的代码,基本上这几个工具,都可以自动生成了。
  
  下面详细说明一下如何使用这几个工具来快速开发项目:
  
   一、创建应用程序解决方案
  
   1.1 打开VS2005开发环境,新建一个空的解决方案Solution。
  
   1.2 向Solution中添加两个新建的C#类库工程,两个类库工程的名称分别为EntityDesigns和Entities,删除IDE自动创建的Class1.cs文件。
  
   1.3 向Solution中再添加两个新建的C#类库工程,两个类库工程的名称分别为ServiceInterfaces和ServiceImpls,删除IDE自动创建的Class1.cs文件。
  
  
  
  
  
  1.4 向Solution 中新建一个名叫WebApplication的ASP.NET Web应用程序,为WebApplication添加一个Web.config文件。
  
  
  
  
  
  1.5 项目依赖设置:
  
  WebApplication -> Entities, ServiceInterfaces
  ServiceInterfaces -> Entities
  ServiceImpls -> Entities, ServiceInterfaces
  
  
  
  
  
  注:设置完依赖后,记得添加项目引用,并在各项目中添加NB的相关dll
  
   1.6相关引用
  
   WebApplication需:NBear.Common.dll,NBear.Data.dll和NBear.IoC.dll的引用
  
  ServiceInterfacesf需:NBear.Common.dll和NBear.IoC.dll的引用
  
  ServiceImpls 需: NBear.Common.dll,NBear.Data.dll和NBear.IoC.dll的引用
  
  Entities需:NBear.Common. dll
  
  EntityDesigns需:NBear.Common.Design.dll的引用,因为每一个设计实体接口必须继承自NBear.Common.Design.Entity这个接口
  
  
  
  
  
  记得using
  
   一、从数据库到实体
  
   1. 运行NBear.Tools.DbToEntityDesign.exe,在Connection String文本框中输入下面的连接子串:Server=(local);Database=Northwind;Uid=sa;Pwd=sa
  
  2. 在EntitiyDesigns工程中新建一个代码文件EntityDesigns.cs,添加using System和using NBear.Common.Design设置namespace为EntityDesigns。并将刚才从DbToEntityDesign复制的代码粘贴至该文件中。
  
  
  
  3 下面,对这些生成的代码做一下改造(具体查询NB中文说明书Step 3 设计实体、关系及元数据)
  
  
  
  
  
  二、从实体设计代码生成实体代码、实体配置文件
  
  
  
  3.1编译EntityDesigns工程。
  3.2 运行dist目录中的NBear.Tools.EntityDesignToEntity.exe工具,载入EntityDesigns工程编译生成的EntityDesigns.dll。点击Generate Entities按钮,将生成的代码保存到Entities工程中的一个名叫Entities.cs的新代码文件
  3.3 点击Generate Configuration按钮,将生成的代码保存到website工程下的名为EntityConfig.XML的新文件中。
  
   三、使用Nbear代码工具生成代码
  
   打开工具后,在系统菜单中找到参数配置。配置好数据库类型及相应的链接字符串,将项目的顶级名字空间设置好(PX.ServiceInterfaces)那这里要设置成PX,导出路径设置成你项目的根目录(一般是跟解决方案.sln同一路径,这样生成时,代码自动会生成到解决方案的相应目录中,然后在IDE中,点击解决方案上方的显示所有文件按钮,将生成好的.cs包括到项目中就可以了)
  
   工具说明:本工具用在数据库表很多时,才会发挥大的作用,主要是生成ServiceInterfaces,ServiceImpls这两层的代码,ServiceImpls中使用了partial关键字,用户自己写的代码要放在ServiceUS.cs中,以免当数据库修改后,二次生成后,把用户自己写在Service里的代码覆盖。
  
   四、使用实体及NBear.Data.Gateway访问数据库
  
   1.设置website的Web.config文件,添加一个entityConfig section以包含EntityConfig.XML这个实体配置文件,并设置数据库连接字串。下面是设置完的Web.config,注意,粗体的部分都是我们添加的代码(注意修改数据库登录密码。):
  
  
  
  <?xml version="1.0"?>
  <configuration>
   <configSections>
   <section name="entityConfig" type="NBear.Common.EntityConfigurationSection, NBear.Common" />
   </configSections>
   <entityConfig>
   <includes>
   <add key="Sample Entity Config" value="~/EntityConfig.xml" />
   </includes>
   </entityConfig>
   <appSettings/>
  <connectionStrings>
  <add name="DbName" connectionString="Server=(local);Database=tempdb;Uid=sa;Pwd=sa" providerName="NBear.Data.SqlServer.SqlDbProvider"/>
   </connectionStrings>
  <castle>
  <components>
  <component id="Article" service="ServiceInterfaces.IArticleService, ServiceInterfaces" type="ServiceImpls.ArticleService, ServiceImpls"/> <system.web>
   <compilation debug="false" />
   <authentication mode="Windows" /
   </system.web>
  </configuration>
  
  
  
  
  
  5.3 好了,到目前为止,实体设置和配置完毕了。下面我们将开始讨论IoC模块的使用。
  
  
  
  
  
  
  具体使用参看DEMO;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息