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可以实现分布式统一配置中心.分 ...
随机推荐
- 【干货】个人工作文档节选:XAML MVVM 框架易用性细节优化Tips
1 易用性细节优化 1.1 代码片段 在ViewModel内,会有大量重复性的在Property set中激发 INotifyPropertyChanged.PropertyChanged 事件 ...
- Logstash——multiline 插件,匹配多行日志
本文内容 测试数据 字段属性 按多行解析运行时日志 把多行日志解析到字段 参考资料 在处理日志时,除了访问日志外,还要处理运行时日志,该日志大都用程序写的,比如 log4j.运行时日志跟访问日志最大的 ...
- THEOS makefile
转自https://www.h4ck.org.cn/2013/07/theos-makefile/ theos的makefile写法与其他linux/unix环境下的makefile写法大同小异,但是 ...
- 阿里大鱼.net core 发送短信
阿里大鱼还未提供 .net core 版SDK,但提供了相关API,下面是.net core版实现,只是简单发送短信功能: using System; using System.Collections ...
- A Simple MVVM Example[Forward]
In my opinion, if you are using WPF or Silverlight you should be using the MVVM design pattern. It i ...
- ecshop登陆后价格可见,会员注册登陆才能显示价格
打开模版文件夹里面的goods.dwt 查找{$lang.shop_price}<font class="price" id="ECS_SHOPPRICE" ...
- FancyTree 状态保持
FancyTree非常优秀的树控件 examples:http://wwwendt.de/tech/fancytree/ 如何将树节点的选中状态保存下来,无论刷新页面还是,ajax重复请求,都保持在上 ...
- 使用Eclipse进行远程调试【转】
今天决定做件有意义的事,写篇图文并茂的blog,为什么要图文并茂?因为很多事可能用语言也说不明白,从以前我发表的一篇文章可以看得出来,http://blog.csdn.net/sunyujia/arc ...
- DRUPAL 慢的原因
不止一次听人抱怨DRUPAL 慢,在本地开发环境尤为常见,较为常见的原因有:- 本地环境造成慢的原因,最常见的是由update manager 造成的,如果你发现你开的DRUPAL 页面 一直在等待 ...
- linux(以ubuntu为例)下Android利用ant自动编译、修改配置文件、批量多渠道,打包生成apk文件
原创,转载请注明:http://www.cnblogs.com/ycxyyzw/p/4555328.html 之前写过一篇<windows下Android利用ant自动编译.修改配置文件.批量 ...