WCF回顾一、基本概念和应用场景
一、WCF描述
wcf是一款基于面向服务的架构的通讯框架平台,在分布式框架中得到了广泛使用。 wcf入门非常简单,只要花几分钟就能编写一个完整的wcf程序,而实际上WCF是概念非常多的一门技术,需要花很大精力去深入研究。
二、WCF优点
1、将各种通讯技术进行整合
WCF是对于 Web Service,Net Remoting,Enterprise Service,WSE,MSMQ等技术的整合
表示层可以基于 soap XML传输 和 rest http调用
传输层可以基于 http https tcp pipe msmq (在都可以满足需求的情况下,我个人比较喜欢tcp从性能和灵活性方面的综合考虑)
2、采用面向服务去实现,让编程变的更简单
软件开发方法:面向过程编程—>面向对象—>面向组件开发—>面向服务架构
面向服务优势:
一个项目中,如果存在多种风格的技术、第三方DLL或者两种技术不能同一个系统下运行 这种情况下将变的难以维护和编码不雅,但是把这些功能全部分离到的一个服务项目,通过一个个的服务接口去调用,多个环境去发布,既做到了解耦又提高了内聚, 代码在烂眼不见心不烦。
三、WCF基本概念
WCF程序分为服务端和客户端,WCF程序通过宿主托管到进程中,读取配置并启动服务,客户端通过代理类实现调用。
1契约 :
(1)服务契约: 暴露给客户端的一组接口,需要加上[ServiceContract]特性,客户端才可以调用该服务。
(2)操作契约: 函数名加上[OperationContract],服务中才可以调用该函数。
[ServiceContract]
public interface IService1
{
[OperationContract]
string GetData(int value); [OperationContract]
CompositeType GetDataByData(DataClass dc); }
(3)数据契约: 客户端和服务端传递的class需要加上属性[DataContract]标注为数据契约,在class的成员属性加上DataMember特性标注共享成员
注意:即使不添加特性DataContract,仍然默认为DataContract,只有数据契约可以偷懒不写
[DataContract]
public class DataClass{
[DataMember]
public double TotalPrice { get; set; } }
(4)消息契约:这个比较有意思,网上说法很多,关于应用场景的相当少
我的理解:首先消息契约和数据契约一样都支持流,返回流还能带附带其它信息,这些数据契约一样做的到只是多几个属性摆了。
消息契约重点在消息这两个字,数据的特性是一致性,你是 “1” 我也是 “1” ,但是消息不同我可以说成是 “1” 也可以说成是 ”一“,区别在于多样化。
消息契约是将传输数据 指定到 soap head或者soap body,可以通过order对多个head或者body中的数据进行排序,还可以自定义一些消息格式让传输格式多样化,支持更多设备的接收, 还可以对head进行加密等操作。
数据契约所有数据都在一起,我们无法控制生成的soap是什么样子。
注意每种契约都有各自的特性参数,这里就不介绍了
2地址
每个服务可以有多种传输协议,每种传输协议只能有一个调用地址
比如 :
http://192.168.1:800/Service1
net.tcp://localhost:8080/Service1
3代理
项目右键添加服务引,输入服务地址 便可以很方便的生成代理服务,也可以使用工具生成代理或者手写。
4、WCF配置文件
分为三块 bindings 、services和 behaviors
(1)services:
可以有多个service ,一个service代表一个服务,
一个service可以多个endpoint, endpoint作用主要是 地址、契约、绑定
endpoint举个例子比如 绑定http 地址就是 http://192.168.1.1:80/service1 服务契约就是 IService
(2) behaviors:
一个service可以有一个behavior ,约定服务的行为,比如服务出错是否输出详细错误,是否显示元数据等(元数据就是WCF浏览页)
(3) bindinds:
一个service可以有一个bingding用于配置服务的传输协议和传输参数的设置等。
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.web>
<compilation debug="true" targetFramework="4.0" />
</system.web>
<system.serviceModel>
<bindings>
<netTcpBinding>
<binding name="tcpBind" portSharingEnabled="true" transferMode="Buffered" >
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<security mode="None">
</security>
</binding>
</netTcpBinding>
</bindings>
<services>
<service behaviorConfiguration="MyServiceTypeBehaviors" name="WcfService.SayService">
<endpoint binding="netTcpBinding" bindingConfiguration="tcpBind" contract="WcfService.ISayService" />
<endpoint address="mex" binding="mexTcpBinding" contract="IMetadataExchange" />
</service>
</services>
<behaviors>
<serviceBehaviors>
<behavior name="MyServiceTypeBehaviors" >
<!--发布元数据,发布前删除-->
<serviceMetadata httpGetEnabled="true" />
<!--输出错误,发布前删除-->
<serviceDebug includeExceptionDetailInFaults="true" />
</behavior>
</serviceBehaviors>
</behaviors>
</system.serviceModel>
</configuration>
===============================================================纯属个人理解=========================================================
WCF回顾一、基本概念和应用场景的更多相关文章
- MQ(1)---消息队列概念和使用场景
消息队列概念和使用场景 声明:本文转自:MQ入门总结(一)消息队列概念和使用场景 写的很好,都不用自己在整理了,非常感谢该作者的用心. 一.什么是消息队列 消息即是信息的载体.为了让消息发送者和消息接 ...
- kubernetes1.9管中窥豹-CRD概念、使用场景及实例
欢迎访问网易云社区,了解更多网易技术产品运营经验. 前言 默认读者有kubernetes基础概念的背景知识,因此基础概念例如有状态.pod.Replica Sets.Deployments.state ...
- WCF分布式开发步步为赢(1):WCF分布式框架基础概念
众所周知,系统间的低耦合一直是大型企业应用系统集成追寻的目标,SOA面向服务架构的出现为我们的如何利用现有企业系统资源进行企业ERP系统设计和实现提供了重要的参考原则.SOA如此炙手可热,各大厂商都推 ...
- ThreadLocal概念以及使用场景
ThreadLocal概念以及使用场景 根据自身的知识深度,这里只限于自己使用和学习的知识点整理,原理的解释还需要再沉淀. 该文章从项目开发中举例,希望能帮助到各位,不了解ThreadLocal的朋友 ...
- WCF分布式开发步步为赢(14):WCF安全编程--基本概念
WCF安全机制是个非常复杂的问题,因为涉及的知识点较多,所以今天这个文章,会分析进行WCF安全开发应该了解的哪些知识点.如何查看资料.为了更好地理解WCF安全相关知识,我把WCF安全机制主要知识点整理 ...
- [原创]cocos2d-x研习录-第二阶 概念类之场景类(CCScene)
场景类CCScene是Cocos2D-x在屏幕显示的内容,相当于游戏关卡或界面.CCDirector任何时候只能显示一个场景CCScene,游戏中可能存在若干场景,CCDirector通过场景切换达到 ...
- [转]RabbitMQ入门教程(概念,应用场景,安装,使用)
原文地址:https://www.jianshu.com/p/dae5bbed39b1 RabbitMQ 简介 RabbitMQ是一个在AMQP(Advanced Message Queuing Pr ...
- redis(redis概念,运用场景,如何操作基本数据类型)
什么是redis:Nosql一种缓存数据库 redis可以干什么:redis可以减轻对数据库的请求压力如果不使用缓存:客服端->控制层->业务层->dao层使用缓存:客服端-> ...
- zookerper入门、核心概念和使用场景
zookeeper是一个分布式程序的高性能协调服务,提供集中式信息存储服务,数据存储于内存中,类似文件系统的树形结构,高吞吐量和低延时,集群高可靠,基于zookeeper可以实现分布式统一配置中心.分 ...
随机推荐
- arcgis打开图层后右下角坐标小数点位数调整
打开arcmap,加载图层后,在其右下方会显示鼠标移动的点坐标,但是默认显示的小数点只有三位,如果是经纬度坐标,只有三位的话不够精确,因此想着能否改变其显示的精度,搜了半天,算是搜到了,但是过了一段时 ...
- jQuery之Deferred对象详解
deferred对象是jQuery对Promises接口的实现.它是非同步操作的通用接口,可以被看作是一个等待完成的任务,开发者通过一些通过的接口对其进行设置.事实上,它扮演代理人(proxy)的角色 ...
- TextEdit 回车事件
<dxe:TextEdit Name="txtSearchPatientName" KeyDown="txtSearchPatientName_KeyDown_1& ...
- A Brief History of Scaling LinkedIn
原文地址 LinkedIn started in 2003 with the goal of connecting to your network for better job opportuniti ...
- Maven Learning - Direct Dependencies & Transitive Dependencies
Dependencies declared in your project's pom.xml file often have their own dependencies. The main dep ...
- 编程语言 IDE 对比
IDE是集成开发环境的英文缩写,所谓集成开发环境,就是将你在开发过程中所需要的工具或功能集成到了一起,比如代码编写.分析.编译.调试等功能,从而最大化地提高开发者的工作效率. 每种编程语言都有一些特定 ...
- Windows 2008 利用Filezilla server搭建FTP
Windows 2008 利用Filezilla server搭建FTP, 安装后总是提示Error Connection To Server Lost , 后来,无意中先安装了IIS,再安装file ...
- Python: 无参数的函数装饰器
写带参数的函数装饰器最纠结的是需要包好多层,最外层是接收参数的函数,它返回一个接收函数的的函数.但这样有个问题是,最终包装出来的装饰器必须加()调用一下,即使没有参数也需要这样做,因为调用这个最外层函 ...
- ASP.NET 回调技术(CallBack)
在asp.net中客户端与服务器端的交互默认都是整页面提交, 此时客户端将当前页面表单中的数据(包括一些自动生成的隐藏域)都提交到服务器端,服务器重新实例化一个当前页面类的实例响应这个请求,然后将整个 ...
- [GraphQL] Use GraphQL's List Type for Collections
In order to handle collections of items in a GraphQL Schema, GraphQL has a List Type. In this video, ...