Spring.Net+NHibenate+Asp.Net mvc +ExtJs 系列

系统 2226 0

就以一个简单的DirectCenter项目开始介绍这个框架吧,DirectCenter主要分为用户管理,部门管理,公司管理三个模块。首先先搭建起解决方案DirectCenter:
DirectCenter:
DirectCenter.Model (类库项目)实体类库,其中包括hibernate映射文件(可以把映射文件放到DAL层,这样使Model也比较单纯,而DAL则只是Nhibernate的完整实现)
DirectCenter.IDAL (类库项目)数据访问层接口
DirectCenter.DAL (类库项目)数据库访问层实现(采用NHibernate)
DirectCenter.IBLL (类库项目)业务层接口
DirectCenter.BLL (类库项目)业务层实现( 使用IDAL,通过spring.net的IOC注入实际的数据访问层 )
DirectCenter.App (类库项目)系统的配置,其中包括Nhibernate,Spring.net的一些配置信息,业务层的DAL注入.
DirectCenter.UnitTest (类库项目) 使用nunit对业务层进行单元测试

DirectCenter.DTO (类库项目) data transform object 用于和前台UI层交互的实体。之所以分出来,也是为了考虑不只是为了Web项目,同时包括WebService等其它UI. (可能会有不少人会问已经有Model了,为什么还需要DTO?)

DirectCenter.Controllers (类库项目) Web控制器。用户请求和后台业务层的中转,接收并分析用户请求,调用业务层完成请求,再分发给用户。( 注意这里调用的是IBLL,是业务逻辑接口,也是通过Spring.Net的IOC注入具体的业务实现)。
DirectCenter.Web (Web Application) 单纯的View层,主要由ExtJs完成界面和Ajax请求。

当然,这里也可以加一个Controllers的单元测试项目,不过我觉得这里很多时候用处不是很大。因为这里Controllers的工作比较统一和单纯了。
首先先设计和建立数据库,字段和说明如下:


数据库中没有外键关系,因为一对多,多对多这些关系使用NHibernate的持久层建立和维护,每个表中都有一个Version字段,这是为了使用Nhibernate内置的对象的版本控制来解决并发问题。
接下来的工作就简单了许多,因为今天我们只要完成实体就行,而实体类和映射文件的工作有一些辅助工具可以帮我们生成,比如codesmith, Nconstruct,Database2Sharp等,不过我还没有发现哪个工具能够很好的生成关系映射.这里只把User的类和映射文件放在这里,其 它的两个可以在源代码附件中找到。

User.cs
<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>--> using System;
using System.Collections.Generic;
using System.Text;
using System.Collections;

namespace DirectCenter.Model
{


[Serializable]
public class User
{
/**/ /// <summary>
/// 创建日期
/// </summary>

public virtual DateTimeCreateTime
{
get ;
set ;
}


/**/ /// <summary>
/// 创建人
/// </summary>

public virtual System.StringCreator
{
get ;
set ;
}




/**/ /// <summary>
/// Email地址
/// </summary>

public virtual System.StringEmail
{
get ;
set ;
}


/**/ /// <summary>
/// 用户编号
/// </summary>
///

public virtual System.StringUserID
{
get ;
set ;
}


/**/ /// <summary>
/// 导入日期
/// </summary>

public virtual DateTime ? ImportTime
{
get ;
set ;
}



/**/ /// <summary>
/// 手机号码
/// </summary>

public virtual System.StringMobile
{
get ;
set ;
}


/**/ /// <summary>
/// 用户密码
/// </summary>

public virtual System.StringPassword
{
get ;
set ;
}


/**/ /// <summary>
/// 电话号码
/// </summary>

public virtual System.StringTelephone
{
get ;
set ;
}


/**/ /// <summary>
/// 用户名称
/// </summary>

public virtual System.StringUserName
{
get ;
set ;
}


/**/ /// <summary>
/// 生效日期
/// </summary>

public virtual DateTime ? ValidFrom
{
get ;
set ;
}



/**/ /// <summary>
/// 失效日期
/// </summary>

public virtual DateTime ? ValidTo
{
get ;
set ;
}



/**/ /// <summary>
/// 所属公司
/// </summary>

public virtual CompanyCompany
{
get ;
set ;
}



/**/ /// <summary>
/// 所属部门
/// </summary>

public virtual DepartmentDepartment
{
get ;
set ;
}



/**/ /// <summary>
/// 直接主管
/// </summary>

public virtual UserManager
{
get ;
set ;
}


}

}


<!--<br><br>Code highlighting produced by Actipro CodeHighlighter (freeware)<br>http://www.CodeHighlighter.com/<br><br>--> <? xmlversion="1.0"encoding="utf-8" ?>
< hibernate-mapping xmlns ="urn:nhibernate-mapping-2.2" >

< class name ="DirectCenter.Model.User,DirectCenter.Model" table ="UserAccount" lazy ="true" >

< id name ="UserID" column ="UserID" type ="System.String" >
< generator class ="assigned" />
</ id >

< property name ="CreateTime" column ="CreateTime" type ="System.DateTime" />
< property name ="Creator" column ="Creator" type ="System.String" length ="32" />
< property name ="Email" column ="Email" type ="System.String" length ="255" />

< property name ="Mobile" column ="Mobile" type ="System.String" length ="15" />
< property name ="Password" column ="Password" type ="System.String" length ="64" />
< property name ="Telephone" column ="Telephone" type ="System.String" length ="20" />
< property name ="UserName" column ="UserName" not-null ="true" type ="System.String" length ="32" />
< property name ="ValidFrom" column ="ValidFrom" type ="System.DateTime" />
< property name ="ValidTo" column ="ValidTo" type ="System.DateTime" />


<!-- 用户所属交易公司 -->
< many-to-one name ="Company"
class
="DirectCenter.Model.Company,DirectCenter.Model"
cascade
="none"
column
="CompanyID"
/>

<!-- 用户所属部门 -->
< many-to-one name ="Department"
class
="DirectCenter.Model.Department,DirectCenter.Model"
cascade
="none"
column
="DepartmentID"
/>

<!-- 主管 -->
< many-to-one name ="Manager"
class
="DirectCenter.Model.User,DirectCenter.Model"
cascade
="none"
column
="ManagerID"
/>
</ class >
</ hibernate-mapping >

注:User的表名和实体名不一致的原因是因为User是数据库中的关键字。另外需要注意的是,映射文件中的命名空间要正确,映射文件(*.hbm.xml)不要忘了设置成Embedded Resource (嵌入式资源)。

数据库设计,实体,映射文件是使用这个框架开发最关键的,毕竟是转换需求的最重要的一步。如果设计的好的话,接下来的开发相对容易多了。下次介绍数据访问层和业务层的实现。

代码

Spring.Net+NHibenate+Asp.Net mvc +ExtJs 系列 2


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论