本文将介绍的是基于.NET平台的Web框架搭建,笔者最近基于ExtJs和ASP.NET MVC做了一个系统.来总结下.一起讨论下.
一.技术分析
1.web数据传输
ExtJS作为前端UI展现层,传输数据格式为Json或者xml,一般大部分为Json.
2.ASP.NET MVC
(不要考虑太多mvc其他特性,controller+method就够了)的和路由url很好的符合了这一要求,实现起来很轻松.
3.选一款依赖注入容器
只要你好好学过一款Ioc组件,概念都还是一样的,做法不同而已,我选的是微软的Unity,
这里我并没有把Service配置在xml中,根据我的理解,大部分软件并不需要这么灵活,我就纯注册就够了(其实往往是这样,我们可以问问自己,我们用到了多少功能).因为大部分都是注册一次,永不修改的…真的有必要的时候可以提出
Ioc组件很多,个人认为比较强大的还是spring.net,功能非常丰富,还有AOP功能,最主要的是其可以和其他组件结合的很好.
容器作为底层服务,主要就是为我们提供灵活性.想办法与现有组件结合,注册相关服务.
4.数据库操作(NHibernate)
3年前我会选ADO.NET
2年前我选Microsoft.Practices.Data.Application
1年前我选linq to sql
现在我选nhibernate
关于NHibernate映射
(1)若你是初学者,乖乖的自己手动配吧
(2)若你喜欢linq的,有一款FluentNHibernate可供选择(用新技术请考虑风险,玩的没关系)
(3)若你映射配置文件玩的很熟悉了,就用NHibernate.Mapping.Attributes挂标签自动生成吧(不推荐用什么代码生成器,都是要重新改的)
5.比较java web经典平台
比较庆幸,之前有接触过java,java的web编程架构很稳定,3年前如此,现在还是一样,不同的只是版本升级而已,这点.net程序员比较惨的.这也见证了spring,hibernate,struts(webwork)在目前而言是***的拍档.
换成.net平台也就是spring.net(Ioc容器)+nhibernate(orm)+asp.net mvc
spring.net和nhibernate都属于java移植产品,所以应该来说资料是非常的多,想学习的人,应该把眼光放到java社区中,收获会很多的,稍微比较下c#和java语言就好了(千万别学了就跑去学java了:)).
asp.net mvc对比struts而言,方便了很多,但不同的是java附产品比较多,像asp.net mvc这样的框架,java也有些框架已经开始改进了(看到过,基本上理念是一样的).
当然这里均采用的开源路线,大家也可以采用微软自家平台的技术.
二.技术串联
1.注册容器
2.初始化Nhibernate
我们都知道Ioc是可以与asp.net mvc结合的
3.Nhibernate与容器配合法
(1)Nhibernate与spring.net的结合,这里已经有经典例子在了,何谓经典例子,就是大家都这么干,而且也没出什么问题,我也就这么干,确实有点道理的…虽然有时候真不懂为什么这么干。。。呵呵
(2)用单例的方式在应用启动时注册,如上法
(3)Nhibernate若映射换FluentNHibernate的话,或者加入linq to nh,则整个设计就要重新考虑了
我想上面的设计有点意思,特别是加入了linq to nh我的设想是这样的
(1)简单查询用linq to nh
(2)hql主打,标准查询辅助…
(3)若由于对nh框架不熟,导致查不出来,或者遇到速度慢,先上t-sql(原因一般都是自身学的不好造成的,先怀疑自己,怀疑不下去了再去怀疑框架本身…)
三.项目细分
这里忽略分布式应用,我没具体搞过…
- Entity项目一个
- Service接口项目一个
- Service接口默认实现项目一个
- Domain项目一个
- 主体辅助类项目一个(放杂七杂八用的)
- 测试项目一个(可选)
- web相关项目一个(放与web相关的和controller)
- web主打项目一个(运行项目,主放js用…)
基本上最基本的就是这样,你可以细分,也可以把上面很多项目合并为同一项目.
若想灵活就多用反射与配置文件
四.细化
若要完成一般的数据增删改系统的话,我们还可以稍微细化封装,这样的封装是很方便的.
1.没有绝对的灵活,需要一定的耦合,ext框架对于后端请求的json数据有一定要求,所以数据转换在所难免,所以准备一些通用的数据类型转换的功能
2.对于千篇一律的数据增删改,若无特殊的业务逻辑,可考虑借助asp.net mvc和反射功能完成,这样一个controller的设计可以代替很多个.
3.在传json时勿使用延迟加载等特性.
4.一个hql配置系统,不要因为某一查询条件改了而重新编写代码,可以考虑做个机制,把hql语句提取出来
5.巧用nhibernate拦截机制,日志必不可少
6.一套稳定的权限机制
7.对于ext,要有一套js加载机制
总结起来细化的都是对于不同需求而变化设计的.
如果不是很难的项目,花一段时间实践,这种搭配很容易学会.
接下来重点还是回到.net framework来学习.
原文标题:基于.net平台的web框架搭建
链接:http://www.cnblogs.com/Clingingboy/archive/2009/11/10/1600554.html