SOA(面向服务的架构)
前言:SOA(面向服务的架构)是目前企业应用开发过程中普遍采用的技术,基于MVC WebAPI三层分布式框架开发,以此适用于企业信息系统的业务处理,是本文论述的重点。此外,插件技术的应用,富客户端JQuery实现技术,本文也对其具体实现做以说明。相关示例解决方案可以参考GitHub资源,在文章结尾给出。
http://blog.csdn.net/besley/article/details/8479943
1. 系统分层体系架构设计
分布式三层系统简单分为数据访问层,业务逻辑层和前端展现层。分层架构设计是构建大型分布式系统的必要手段,因为可以使得系统健壮,可扩展。
SOA即面向服务的架构,可以帮助企业构建灵活,扩展性强的复杂业务系统,按照服务的理念进行功能交付,调用方也不用去知道实现一方的具体细节;双方是按照统一消息格式,接口方式进行交互的。
SOA的实现是基于以Web服务的方式发布Api接口,目前WebAPI是一种Restfule形式的Web服务,相比WCF的复杂性,WebAPI的开发效率更高,而且在配置时也不需要客户端和服务端的xml配置。
企业核心业务数据可以让桌面、Web、平板、手机或物联设备访问,所以需要统一API接口,WebApi作为业务逻辑处理服务能够满足接口访问和接口之间交互的需求。
1,Dapper是一个轻型的ORM类。代码就一个SqlMapper.cs文件,编译后就40K的一个很小的Dll.
7,Dapper语法十分简单。并且无须迁就数据库的设计。
读取500条记录,并做简单对象的序列化操作时间对比如下图:
2.2 DataRepository类
2.4 服务实现类
API Controller:
--[HttpGet]
--[HttpPost]
--[HttpPut]
--[HttpDelete]
3.1 Asp.NETMVC 富客户端开发
GET/POST/PUT/DELETE
- /***
- * HttpGet获取服务端数据
- * @url 业务数据
- * @data
- */
- $.doHttpClientGet = function(url, fn) {
- $.getJSON(url, fn);
- }
- /***
- * HttpPut更新数据到服务端
- * @url 业务数据
- * @data
- */
- $.doHttpClientUpdate = function(url, data, fn) {
- $.ajax({
- url: url,
- type: 'PUT',
- data: data,
- dataType: 'json',
- contentType: 'application/json',
- success: fn
- });
- }
- /***
- * HttpDelete删除数据
- * @url 业务数据
- * @data
- */
- $.doHttpClientDelete = function(url, data, fn) {
- $.ajax({
- url: url,
- type: 'DELETE',
- data: data,
- dataType: 'json',
- contentType: 'application/json',
- success: fn
- });
- }
- /***
- * HttpPost保存数据
- * @url 业务数据
- * @data
- */
- $.doHttpClientSave = function(url, data, fn) {
- $.ajax({
- url: url,
- type: 'POST',
- data: data,
- dataType: 'json',
- contentType: 'application/json',
- success: fn
- });
- }
- /***
- * ajax获取服务端数据
- * @url 业务数据
- * @data
- */
- $.doAjaxGet = function(url, fn) {
- //$.getJSON(url, fn);
- $.ajax({
- url: url,
- type: "GET",
- dataType: 'json',
- //data: data,
- contentType: 'application/json',
- success: fn
- });
- }
- $.doAjaxPost = function(url, data, fn) {
- $.ajax({
- url: url,
- type: 'POST',
- data: data,
- dataType: 'json',
- contentType: 'application/json',
- success: fn
- });
- }
- //构造html的通用方法
- $.buildHTML = function(tag, html, attrs) {
- // you can skip html param
- if (typeof (html) != 'string') {
- attrs = html;
- html = null;
- }
- var h = '<' + tag;
- for (attr in attrs) {
- if (attrs[attr] === false) continue;
- h += ' ' + attr + '="' + attrs[attr] + '"';
- }
- return h += html ? ">" + html + "</" + tag + ">" : "/>";
- }
- //构造JsTree的通用方法
- $.fn.buildJsTree = function (url, fn) {
- var object = require(['jstree'], function(){
- $.jstree._themes = "/PlatJS/Scripts/jstree/themes/";
- var myTree = $(this).jstree({
- "json_data": {
- "ajax": {
- "url": url,
- "type": "GET",
- "dataType": "json",
- "contentType": "application/json charset=utf-8",
- "success": fn
- }
- },
- "plugins": ["themes", "json_data", "ui"]
- });
- })
- }
3.4 如何调试?
FireBug for Firefox
Firefox的RestClient插件—Rest Client测试插件
http://localhost:8081/ProductSys.WebAPI/api/order/insertwith?type="insertwith“
[HttpPost]
public HttpResponseMessageInsertWith(Order entity, string type)
http://localhost:8081/ProductSys.WebAPI/api/order/4
[HttpDelete]
public HttpResponseMessage Delete(string id)
3.5 Web异常错误代码
4.2 Javascript-自执行匿名函数
- //Self-Executing Anonymous Func: Part 2 (Public & Private)
- (function( skillet, $, undefined ) {
- //Private Property
- var isHot = true;
- //Public Property
- skillet.ingredient = "Bacon Strips";
- //Public Method
- skillet.fry = function() {
- var oliveOil;
- addItem( "\t\n Butter \n\t" );
- addItem( oliveOil );
- console.log( "Frying " + skillet.ingredient );
- };
- //Private Method
- function addItem( item ) {
- if ( item !== undefined ) {
- console.log( "Adding " + $.trim(item) );
- }
- }
- }( window.skillet = window.skillet || {}, jQuery ));
- <pre name="code" class="javascript">//Public Properties
- console.log( skillet.ingredient ); //Bacon Strips
- //Public Methods
- skillet.fry(); //Adding Butter & Fraying Bacon Strips
- //Adding a Public Property
- skillet.quantity = "12";
- console.log( skillet.quantity ); //12
- //Adding New Functionality to the Skillet
- (function( skillet, $, undefined ) {
- //Private Property
- var amountOfGrease = "1 Cup";
- //Public Method
- skillet.toString = function() {
- console.log( skillet.quantity + " " +
- skillet.ingredient + " & " +
- amountOfGrease + " of Grease" );
- console.log( isHot ? "Hot" : "Cold" );
- };
- }( window.skillet = window.skillet || {}, jQuery ));
- try {
- //12 Bacon Strips & 1 Cup of Grease
- skillet.toString(); //Throws Exception
- } catch( e ) {
- console.log( e.message ); //isHot is not defined
- }</pre><pre name="code" class="javascript"></pre>
- //建议申明对象或数组的写法
- var person = {},
- keys = [];
- //申明复杂对象或数组的写法
- var person = {
- firstName: "Elijah",
- lastName: "Manor",
- sayFullName: function() {
- console.log( this.firstName + " " +
- this.lastName );
- }
- },
- keys = ["123", "676", "242", "4e3"];
4.4 判断对象是否为NULL(c#)
- // <span style="color:#ff0000;">C# 例子. 不要在Javascript中这样写</span>
- if ( someString != null &&
- someString.length > 0 ) {
- //Do something here...
- }
- // C# 例子 检查字符串是否为空
- if ( !string.IsNullOrEmpty(someString) ) {
- //Do something here...
- }
4.5 判断对象是否为NULL(javascript)
- Javascript中的正确写法
- // Simplified JavaScript syntax to check for
- // undefined, null, & empty string values
- if ( someString ) {
- //Do something here...
- }
4.6 设置缺省值(c#)
- <span style="color: rgb(255, 0, 0);">// C# 例子,不要在Javascript这样写</span>
- if ( someString == null ) {
- someString = "default Value";
- }
- // Slightly better, but don't do this either
- someString = someString ? someString : "default value"; <pre name="code" class="javascript">请在Javascript按如下格式写
- // JavaScript syntax to set a default value
- someString = someString || "default value";
- </pre><br>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
- <pre></pre>
4.8 不同类型的比较操作符(===, !==)
4.9 不可取的数组遍历操作符for…in
- var myArray = [], name;
- myArray[5] = "test";
- console.log( myArray.length ); //6
- for ( name in myArray ) {
- console.log( name, myArray[name] );
- //Outputs...
- // 5, test
- }
4.10 正确的数组遍历操作符for…;…;
- var myArray = [], name;
- myArray[5] = "test";
- console.log( myArray.length ); //6
- for ( var i = 0, length = myArray.length; i < length; i++ ) {
- console.log( i, myArray[i] );
- //Outputs...
- // 0, undefined
- // 1, undefined
- // 2, undefined
- // 3, undefined
- // 4, undefined
- // 5, test
- }
- for ( var name in object ) {
- //Your code here
- }
- /* Check if object has property before
- iterating, because functions inherited
- from prototype are also included */
- for ( var name in object ) {
- if ( object.hasOwnProperty(name) ) {
- //Your code here
- }
- }
RequireJS 是一个非常小巧的 JavaScript 模块载入框架,是 AMD 规范最好的实现者之一。最新版本的 RequireJS 压缩后只有 14K,堪称非常轻量。它还同时可以和其他的框架协同工作,使用 RequireJS 必将使的前端代码质量得以提升。
- define(['Controllers/Main/ListView'], function (ListView) {
- function start() {
- var users = JSON.parse(localStorage.users);
- ListView.render({ users: users });
- }
- return {
- start: start
- };
- });
提供的示例RequireMVC199中,可以看一下ProductSys.WebApi的服务层代码,前端代码看RequireMvc199的WebApplication项目即可。
完整示例,可以看一下ProductList页面的代码,这个示例是完整的,包括文件:
WebApplication 包括:
\Controllers
--ProductController.cs
\ViewJS
\Controllers
\Product
--product-list.js
--product-detail.js
\Views
\Product
--productlist.cshtml
WebApi 包括:
ProductSys.WebApi
\Controllers
--ProductController.cs
ProductSys.ServiceImp
\Service
--ProductService.cs
SOA(面向服务的架构)的更多相关文章
- 使用WCF实现SOA面向服务编程—— 架构设计
原文地址:http://www.cnblogs.com/leslies2/archive/2011/03/29/1997889.html SOA本身就是一种面向企业级服务的系统架构,简单来说,SOA就 ...
- SOA面向服务体系架构
SOA概念 1.什么是SOA 面向服务的体系结构(Service-Oriented Architecture,SOA)是一个组件模型. 它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的 ...
- SOA面向服务的架构理解
Ø 单一应用架构 ·当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本. Ø 垂直应用架构 当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几 ...
- SOA面向服务的架构
1.关于SOA的定义,目前主要有以下三个: 1)W3C的定义:SOA是一种应用程序架构,在这种架构中,所有功能都定义为独立的服务,这些服务带有定义明确的可调用接口,能够以定义好的顺序调用这些服务来形成 ...
- SOA面向服务架构
SOA面向服务架构 风尘浪子 只要肯努力,梦想总有一天会实现 随笔分类 - SOA面向服务架构 结合领域驱动设计的SOA分布式软件架构 摘要: 领域驱动设计DDD的总体结构,Repository层使用 ...
- SOA (面向服务的架构)-Service Oriented Architecture
SOA (面向服务的架构) 编辑 面向服务的架构(SOA)是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来.接口是采用中立的方式进行定义的,它应该独立 ...
- 聊聊SOA面向服务架构
什么是SOA SOA(Service-Oriented Architecture),即面向服务的架构.SOA是一种粗粒度.松耦合服务架构,服务之间通过简单.精确定义接口进行通讯,不涉及底层编程接口和通 ...
- 亚马逊如何变成 SOA(面向服务的架构)?
阮一峰 日期: 2016年9月10日 上一篇文章,我摘录了<程序员的呐喊>.这本书有趣的内容太多,今天再摘录一段. 1. 亚马逊公司不仅是世界最大的网络书店,还是世界最大的云服务商.它是怎 ...
- 面向服务体系架构(SOA)和数据仓库(DW)的思考基于 IBM 产品体系搭建基于 SOA 和 DW 的企业基础架构平台
面向服务体系架构(SOA)和数据仓库(DW)的思考 基于 IBM 产品体系搭建基于 SOA 和 DW 的企业基础架构平台 当前业界对面向服务体系架构(SOA)和数据仓库(Data Warehouse, ...
- 面向服务的架构(SOA)
SOA架构基础概念 面向服务的架构(SOA) 在深入探讨什么是面向服务的架构(SOA)之前,先建立一些基本的概念和术语的基本描述而非严格定义,所以也许有些定义在业内还存留争议,此处暂且忽略. 架构基础 ...
随机推荐
- Android自带样式
Android系统自带样式: android:theme="@android:style/Theme.Dialog" 将一个Activity显示为对话框模式 android:the ...
- 多功能截图工具(WinSnap)4.5.6 绿色汉化版(附注册码)
http://www.uzzf.com/Soft/9840.html 注册名:www.uzzf.com 注册码:FGE5ML-XD2C0G33-GCMDLRB5
- android使用XmlPullParser来解析XML文件
解析下面的一个XML: <?xml version="1.0" encoding="utf-8" ?> <rss><sid> ...
- 【LeetCode】【Python解读】Container with most water
这个问题是芭芭拉在采访中遇到的,不幸的是,的复杂性O(n2)该,太失望了,难怪没有通过面试. Given n non-negative integers a1, a2, ..., an, where ...
- hdu 4856 Tunnels(bfs+状态压缩)
题目链接:hdu 4856 Tunnels 题目大意:给定一张图,图上有M个管道,管道给定入口和出口,单向,如今有人想要体验下这M个管道,问最短须要移动的距离,起点未定. 解题思路:首先用bfs处理出 ...
- Eamcs ditaa基于字符图形产生的图像上
ditta和artist mode这是一个好兄弟.artist mode帮我创建一个字符模式速度,ditta是java计划,字符图形可被读取,并生成图像. ditta网站:http://ditaa.s ...
- 一天JavaScript示例-点击图片显示大图片添加鼠标
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- SplashScreenDemo
对Java应用最常见的抱怨就是启动时间太长.这是因为Java虚拟机花费一段时间去加载所有必需的类,特别是对Swing应用,它们需要从Swing和AWT类库代码中去抽取大量的内容. 用户并不喜欢应用程序 ...
- Android开发之Handler的用法(源码分享)
Handler主要接受子线程发送的数据, 并用此数据配合主线程更新UI.. 当应用程序启动时.Android首先会开启一个主线程 (也就是UI线程) , 主线程为管理界面中的UI控件,进行事件分发. ...
- Swift开发学习(两):Playground
Swift开发学习:Playground 大约 对于软件用户.游戏玩家,我一直提倡用户体验.也是用户,是各种开发工具的使用者.也会喜欢用户体验做得好的工具软件.这次苹果想开发人员所想,提供了一个能够玩 ...