日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

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

系統 2733 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條評論
主站蜘蛛池模板: 鸡泽县| 三台县| 法库县| 布拖县| 浑源县| 老河口市| 陕西省| 大宁县| 双江| 剑阁县| 福建省| 乌拉特前旗| 泸定县| 固原市| 余江县| 江达县| 济南市| 平潭县| 留坝县| 宁武县| 于都县| 高唐县| 吉安县| 洛阳市| 沾化县| 呼玛县| 竹溪县| 宾川县| 罗甸县| 南溪县| 平度市| 云和县| 涞水县| 阜阳市| 江山市| 兴城市| 镇康县| 胶南市| 仁布县| 鄂州市| 秦安县|