『随笔』WCF开发那些需要注意的坑
执行如下 批处理:
"C:\Program Files\Microsoft SDKs\Windows\v6.0A\Bin\svcutil.exe" http://127.0.0.1:40001/TestService?wsdl /language:C# /out:"D:\TestProxy.cs" /config:"app.config"
"C:\Program Files (x86)\Microsoft SDKs\Windows\v7.0A\Bin\svcutil.exe" http://127.0.0.1:40001/TestService?wsdl /language:C# /out:"D:\TestProxy.cs" /config:"app.config"
就能在 D盘 得到 代理类 & 配置文件片段
——————————————————————————————————————————————————————
关于 WCF的 传统用法 几点忠告:
>WCF不支持 List 等一切 集合类型 (一切集合 都会被 WCF 转换为 数组)
>WCF不支持 Hashtable 等大部 哈希类型 (大部哈希 都会被 WCF 转换为 Dictionary<object,object>)
——部分特殊情况 WCF 连 Dictionary<object, object> 都不支持
>注意在 服务端 对 需要的对象 声明特性 : [KnownType(typeof(TestVModel_User))]
>建议: WCF穿透对象 尽量不要出现 List 和 Hash —— 可以的话 尽量用 T[] 和 Dictionary<K, V>
>警告: 使用 Hashtable 就是一个 不折不扣 的 埋坑行为。
——————————————————————————————————————————————————————
关于 WCF的 另类用法 几个方案:
PS: "穿透实体" = "视图实体"
"数据实体" 指 保存有效数据的 实体对象
>方案一 : WCF 传统用法 : 写服务端、生成客户端代理类
>优势 : 代码简单;
用 穿透实体 保护 数据实体;
>劣势 : 数据类型 狭隘; 存在 不稳定因素;
服务端改变, 所有 客户端代理类 需 重新生成 (最难维护 的 环节);
>方案二 : WCF 穿透对象 只使用 byte[]
>优势 : 通讯量小,速度快,类型广泛,数据稳定;不需要重新生成 代理类;
>劣势 : byte[] 反向解析 问题:
>如果 是 反序列化 :则 要求客户端 存在 实体类程序集 —— 无法保护 数据实体;
>方案三 : WCF 穿透对象 只使用 string
>优势 : 通讯量小,速度快,数据稳定,跨Java等平台,不需要重新生成 代理类;
>劣势 : >只能兼容 XML 和 JSON 类型 —— 类型依然狭隘;
>string 明文, 可能存在 安全问题;
>需要客户端 反解析 JSON 或 XML 字符串 —— 代码多了一点;
>方案四 : >系统内网电脑 WCF 使用 byte[] —— 共享 实体类程序集
>系统外网电脑 另外开辟 Web服务, 另外开辟 穿透实体;
>优势 : 在 有安全机制 的 内网, 使用 稳定快速的 方式;
>劣势 : 在 有风险 的 外网, 使用 另外的暴露 方式;
最后 : 实体类程序集
>只包含 视图实体类, 字段属性 —— 结构简单;
>并不包含 逻辑代码, 被外部引用 —— 真的会有 安全风险 么?
当然, 任何一种方案, 难度都差不多 —— 更多的都是 后期维护的 难度不同;
——————————————————————————————————————————————————————
关于 WCF的 维护测试:
>如果 没有标记 [DataMember] :
>如果 部分标记 [DataContract] 和 [DataMember] —— 则未标记 属性 会丢失(不会出现在 代理类中)
>如果 不标记任何 [DataContract] 和 [DataMember]
>且 不标记 [Serializable] —— 完全正常
>若 标记 [Serializable] —— 所有属性名 都会被加上 __BackingField 后缀
>如果 增加/减少 穿透对象的属性 :
>减少 穿透对象 属性, 但是 代理类却没有更新 —— 客户端一切正常, 减少属性 无值
>增加 穿透对象 属性, 但是 代理类却没有跟新 —— 客户端一切正常, (代理类 ExtensionData 有增加值)
>如果 增加/减少 服务函数 :
>如果 增加 服务函数 :
>如果 新函数 返回 新穿透对象, 但是 代理类却没有更新 —— 客户端 在不掉用新函数时(客户端根本就没有新函数) 一切正常
>如果 减少 服务函数, 但是 代理类却没有更新 —— 客户端 在不调用删除函数时 一切正常
>如果 函数参数列表 增加/减少 函数参数 :
>增加服务函数 末尾参数, 但是 代理类却没有更新 —— 客户端一切正常, 新参数 无值 (我已经被 彻底 雷死了)
>新增服务参数 乱序参数, 但是 代理类却没有更新 —— 客户端一切正常, 新参数 无值 (我已经被 完全 雷死了)
>减少服务参数 任意参数, 但是 代理类却没有更新 —— 客户端一切正常, 新参数 无值 (我已经被 无语了)
>打乱服务参数, 但是 代理类却没有更新 —— 客户端传入参数 异常 :
>如 :
>最开始 服务端、客户端 参数表: testArg, testArg2, testArg3
>服务端 修改为 testArg2, testArg, testArg3 —— 则 服务端 仅有 testArg testArg3 有值
>服务端 修改为 testArg, testArg3, testArg2 —— 则 服务端 仅有 testArg testArg2 有值
>结论 : WCF 的 稳定性&维护性 远远超过 我之前的 预期
——————————————————————————————————————————————————————
『随笔』WCF开发那些需要注意的坑的更多相关文章
- 『随笔』C# 程序 修改 ConfigurationManager 后,不重启 刷新配置
基本共识: ConfigurationManager 自带缓存,且不支持 写入. 如果 通过 文本写入方式 修改 配置文件,程序 无法刷新加载 最新配置. PS. Web.config 除外:Web. ...
- 『随笔』Socket 链接 必须 上下行 同时使用
结论: > Socket 理论上 支持 只上行,或者 只下行. > 心跳包 必须是 上下行的 —— 心跳包请求(上行) - 心跳包响应(下行). > 如果 长时间 只有单向链接(只发 ...
- 『随笔』.Net 底层 数组[] 的 基本设计探秘 512 子数组
static void Main(string[] args) { Console.ReadKey(); //初始化数组 不会立即开辟内存字节, 只有实际给数组赋值时 才会开辟内存 // //猜测数组 ...
- WCF开发那些需要注意的坑 Z
执行如下 批处理:"C:\Program Files\Microsoft SDKs\Windows\v6.0A\Bin\svcutil.exe" http://127.0.0.1: ...
- 『设计』Slithice 分布式架构设计-支持一体式开发,分布式发布
项目原因: 参与过各种 分布式项目,有 Socket,Remoting,WCF,当然还有最常用的可以跨平台的 WebService. 分布式编码的时间浪费: 但是,无一例外的,开发分布式程序的开发遵循 ...
- app外包开发注意事项大全『最新』
随着移动互联网的高速发展,很多互联网创业公司或传统向互联网转型的公司都急需发开一款app软件,多数公司会选择让外包公司来开发.问题来了,App外包市场鱼龙混杂,我们要如何在这里面选择一个靠谱的公司,这 ...
- 『开源』Slithice 2013 服务器集群 设计和源码
相关介绍文章: <『设计』Slithice 分布式架构设计-支持一体式开发,分布式发布> <『集群』001 Slithice 服务器集群 概述> <『集群』002 Sli ...
- 『摄影欣赏』16幅 Romantic 风格照片欣赏【组图】
今天,我们将继续分享人类情感的系列文章.爱是人类最重要的感觉,也可能是各种形式的艺术(电影,音乐,书,画等)最常表达的主题 .这里有40个最美丽的爱的照片,将激励和给你一个全新的视觉角度为这种情绪.我 ...
- 『实践』VirtualBox 5.1.18+Centos 6.8+hadoop 2.7.3搭建hadoop完全分布式集群及基于HDFS的网盘实现
『实践』VirtualBox 5.1.18+Centos 6.8+hadoop 2.7.3搭建hadoop完全分布式集群及基于HDFS的网盘实现 1.基本设定和软件版本 主机名 ip 对应角色 mas ...
随机推荐
- 【php】mysql全局ID生成方案
生产系统随着业务增长总会经历一个业务量由小变大的过程,可扩展性是考量数据库系统高可用性的一个重要指标;在单表/数据库数据量过大,更新量不断飙涨时,MySQL DBA往往会对业务系统提出sharding ...
- Netlog 的数据库及 LAMP 架构
Database Sharding@Netlog 详细的描述了 Netlog 数据库架构的演变过程,文章浅显易懂,非常值得学习.本文数据.图片均来自:Database Sharding at Netl ...
- c++基础回顾
#include <iostream> #include <vector> #include <string> int main(int argc, const c ...
- Linux下集群的搭建
1.集群的简介: 集群(cluster)技术是一种较新的技术,通过集群技术,可以在付出较低成本的情况下获得在性能.可靠性.灵活性方面的相对较高的收益,其任务调度则是集群系统中的核心技术. 如果一个事情 ...
- Azure CDN 启用HTTPS
默认情况下,订阅里的CDN不支持HTTPS 需要联系21v,提交工单告知订阅号,由后台为订阅启用CDN的HTTPS功能. 然后就可以在创建CDN时选到HTTPS的选项了.
- redis master配置了密码进行主从同步
1.如果master不设置密码,那么直接在slave服务器配置slaveof即可 配置如下 #slaveof ip 端口 slaveof 配置好我们看下redis的日志 看是否同步成功 :S Jan ...
- QQ一键登录功能的实现过程
QQ登录的思路: 当qq登陆成功后,QQ会给我们返回一个唯一的用户标识:openId,当用户授权QQ时,判断 if(已经有openId){ 跳转到登陆后的页面. }else if(没有openId){ ...
- 最小的k个数
// 最小的k个数.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #include & ...
- hadoop yarn configure
<property> <description>The minimum allocation for every container request at the RM, ...
- Solr字段配置错误
在站内搜索Solr Schema设计时,有个FTS_URL字段(之前设计url也会参与检索和打分),因此其配置信息如下: <field name="FTS_URL" type ...