WCF REST架构简单网站
C# 3.5 WCF REST架构简单网站 前言 以前在微软的平台,架构一个网站,需要传统的数据库处理代码,业务逻辑层代码,前端的页面处理,还有交互程序处理这几部分的紧密结合,可以说解耦比较困难。网站开发的难度高,更新成本的难度也就高了。就我经验来说,一个简单的网站必须是一个可扩展,易跨平台数据复用,易维护的架构。我在这里抛砖引玉的说说我使用的架构:数据库 +REST Server+WEB(MVC?) 在下面的文字我尽量少做细节描述,把我目前的做法和大家分享一下就是了。 下载范例 概要 在MS平台上的,数据库是MS SQL2008 .NET3.5+VS2008,首先建立数据模型,然后生成DataContext(数据库处理层),然后使用WCF生成REST风格的Web Service,然后再在网站使用Web Service做页面的处理,对应的网站动态数据交互,以后可以考虑使用MSMQ做消息,然后异步的关心Web Service的Cache等,这是后话,以后有机会再和大家交流。 一:数据库的操作 前我经常用工厂模式去做,后来发现在大中网站基本用不了那么复杂的逻辑,因为数据库的架构基本上是万古不变的,所以我直接使用C#3.5的Dlinq ,在效率,维护成本上都要高出c#2.0的传统做法的实现。 OK,用VS2008 创建一个项目 DbDomain,然后新建一个Linq To Sql类,然后在服务器资源管理器链接数据库,找到表,拖过来。就OK了。具体的代码在附件有。数据库的结构是: 如上,是两张简单的表,会员表和文章表。
二:生成RSET 风格的Web Service 为什么需要Web Service,主要是考虑复用,缓存,数据之间的EVENT通知,还有调试维护等,至于为什么要生成REST风格的,不明白的请自觉GG之,当然,不是每个方法的实现都用REST风格的,对于安全级别比较高的,我还是会使用传统的生成的wsdl web service去安排设计。这里这些暂时不会考虑。 新建一个wcf 应用程序WcfService,创建一个wcf服务Member.svc,范例中只实现了对会员的简单查询和录入:先看看IMember的实现: namespace WcfService 注意第一行标注[ServiceContract]这是一个可转换的Service,3.5大部分是这种模式,接下来是[OperationContract]操作方法,相当于asmx的类似于webmethod的这种标注,然后[WebGet(UriTemplate = "User/{id}", ResponseFormat = WebMessageFormat.Json)]这就是表示访问路径与相应的格式。我们期望在应用程序访问http://localhost/member.svc/User/1,能相应Json格式的User数据。这里的User我并没有数据的Member,因为敏感数据控制,缓存等考虑,中间做了一层,专用跨平台交互: [DataContract] 在dlinq查询是非常的方便的,例如看看具体的实现: [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)] etCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]标注,是指明在IIS里访问该service。这里我没有做cache等,是直接操作数据库的,dlinq操作数据之前,都会建立一个 DbDomain.TestDbHandlerDataContext dc = new DbDomain.TestDbHandlerDataContext();查询类。查询和更新都需要,语法也是很规范的linq,完全不会出现native sql或者dataset这些东西,全部是模型对象的处理,话外DataContext注意每次使用new的,不要使用static的。
注意,如果要让你的svc是REST风格的,除了上面的UriTemplate以外,还要修改svc的标注,加上这句: Factory="System.ServiceModel.Activation.WebServiceHostFactory" 修改web.Config,注意<system.serviceModel>节点上加这句: <serviceHostingEnvironment aspNetCompatibilityEnabled="true" /> 在 <behaviors> 注意加红变粗的地方。差不多就注意这几个地方,具体看我范例的配置吧。
然后再http://localhost:3274/Member.svc/User/1 这样的去访问,就会返回json格式的数据: 添加数据库的方法就是用POST的方式: var usern = client.UploadString("http://localhost:3274/Member.svc/User/admin/admin", "POST",String.Empty); 可以成功的POST数据,然后返回新用户的ID。 三:使用web service开发网站 网站的与数据的交互开发就是使用上面的web service,注意,这里的rest风格的web service就是没有wsdl,需要post数据,然后自己序列化,一般都是公开数据字典,直接序列化,3.5已经自带序列化System.ServiceModel.Web(在 System.ServiceModel.Web.dll 中),所以不再用json.net等第三方的类折腾了: 我在范例网站抽取了我常用的一段代码,在方法 private T CoreRequest<T>(string url, object objdata, string mt) var u = CoreRequest<User>("http://localhost:3274/Member.svc/User/1", null, "GET"); 就OK 了。 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |