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

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

2008-11-03 23:26 961 查看
如何利用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.W
 

设置website的Web.config文件,添加一个entityConfig section以包含EntityConfig.xml这个实体配置文件,并设置数据库连接字串。下面是设置完的Web.config,注意,粗体的部分都是我们添加的代码(注意修改数据库登录密码。):
 

<?xml version="1.0" encoding="utf-8"?>
 

<configuration>
 

     <configSections>
 

    <section name="castle" type="Castle.Windsor.Configuration.AppDomain.CastleSectionHandler, Castle.Windsor"/>
 

         <section name="entityConfig" type="NBear.Common.EntityConfigurationSection, NBear.Common"/>
 

     </configSections>
 

     <entityConfig>
 

         <includes>
 

              <add key="Sample" value="~/EntityConfig.xml"/>
 

         </includes>
 

     </entityConfig>
 

     <castle>
 

         <components>
 

              <component id="CurriculumClass" service="PX.ServiceInterfaces.ICurriculumClass, PX.ServiceInterfaces" type="PX.ServiceImpls.CurriculumClassService, PX.ServiceImpls"/>
 

         </components>
 

     </castle>
 

     <connectionStrings>
 

     <add name="pxinfo" connectionString="Server=100.100.100.100;Database= info;Uid=sa;Pwd=sa" providerName="NBear.Data.SqlServer.SqlDbProvider"/>
 

     </connectionStrings>
 

         <appSettings/>
 

        <system.web>
 

5.3 好了,到目前为止,实体设置和配置完毕了。下面我们将开始讨论IoC模块的使用。
 

具体使用参看DEMO;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息