网络上设置Silverlight动态访问WCF服务,大多是抛开ServiceReferences.ClientConfig文件,完全以代码方式实现对WCF的动态访问。但这种做法存在实现复杂和局限性。在实际使用的过程中,出于安全等原因,很多时候需要通过自定义绑定,设置很多内容。通过VS中的向导生成Silverlight对WCF的访问,能够自动识别这些内容,并自动生成ServiceReferences.ClientConfig文件,简单地实现对服务的访问,但手动通过代码实现这些绑定,显然难度比VS向导方式大了很多,而且一旦服务的绑定等发生变化,Silverlight端代码的修改也非常麻烦。
我们知道,WCF服务是通过ABC三种要素进行设置的,VS向导能自动生成ABC三种要素。程序部署到服务器上,唯一变化的就是A——地址。因此,通过一定的方式,依托自动生成的配置文件,只是动态地修改A,显然是最简单的方式。
程序在开发环境和部署到服务器上时,主要会面临两种情况:
1、Silverlight始终以一个固定的服务器地址访问WCF服务,例如,其中一个服务的地址是http://myServices.com/MyService.svc。
2、服务器提供公网和局域网两种访问方式,WCF服务和承载Silverlight的Web程序在同一个站点上,两者可能在同一个Web程序中,也可能是两个不同的程序。例如,在局域网中,分别是http://192.168.1.4/myServices/myService.svc和http://192.168.1.4/webUI/aaa.aspx。在公网中,又分别是http://Mytest.com/myServices/myService.svc和http://Mytest.com/webUI/aaa.aspx。
显然,两种情况需要不同的处理方式。为了同时满足两种情况,可以使用下面的方式进行处理。
1、Web程序端
对于第一种情况,由于Silverlight的配置文件都打包在xap文件中,因此可以通过承载Silverlight的Web程序为其传递服务地址,这个地址最好的存放处就是Web程序的web.config文件。例如在web.config的appSettings节中增加一个键值对<add key="WcfServiceAddress" value="http://myServices.com"/>。然后在承载Silverlighgt的aspx页面文件中调用Silverlight处,增加下面的内容:
<param name="InitParams" value='WcfServiceAddress=<%= System.Configuration.ConfigurationManager.AppSettings["WcfServiceAddress"] %>' />
对于第二种情况,则不需要在web.config中增加内容。
2、Silverlight端
1)在App.Xaml.cs的Application_Startup方法中,增加下面的代码:
//读取Web程序传递的WCF服务地址
var slServicePath = e.InitParams["WcfServiceAddress"];
//如果没有值,说明为第二种情况,则读取承载的Web程序的地址信息,以适应公网和局域网两种情况
if (string.IsNullOrEmpty(slServicePath))
{
var tmp = HtmlPage.Document.DocumentUri;
WcfServiceAddress = string.Format("{0}://{1}:{2}", tmp.Scheme,tmp.Host,tmp.Port);
}
//将读取到的WCF地址保存到资源中。
Application.Current.Resources.Add("WcfServiceAddress",slServicePath);
2)建立一个公用的Utility类,并在其中增加一个方法,代码如下:
public static EndpointAddress ProcessServiceAddress(EndpointAddress originalEndpointAddress)
{
var newUri = Application.Current.Resources["SlServicePath"] + originalEndpointAddress.Uri.AbsolutePath;
return new EndpointAddress(newUri);
}
3)使用WCF服务:
MyServiceClient myService = new MyServiceClient();
myService .Endpoint.Address = Utility.ProcessServiceAddress(myService.Endpoint.Address);
//调用服务方法的代码……
这样,就能轻松地实现Silverlight对WCF的动态访问。即使WCF服务的绑定等内容发生变化,也只需要简单地通过VS的向导更新服务引用即可,代码不需要任何修改。
VS2005和VS2008开发网站时,可以采用文件方式和IIS两种。IIS方式任何操作系统都正常,这里不做说明。采用文件方式是采用ASP.NET development sever作为web服务器来显示网站。在xp或win2003系统一切正常,而Windows server 2008/Vista系统时会显示页面无法找到错误。
经过google搜索,终于找到了问题原因和解决方案,特此记录,供遇到同样问题的朋友参考。
问题原因:windows2008/Vista提供了对IPV6的支持(Windows2003/XP没有),而ASP.NET development sever对IPV6支持有问题,所以出现无法显示页面问题。
解决方案:打开系统盘符\Windows\System32\drivers\etc目录下hosts文件,找到写有“::1 localhost”的行,删除它或用#注释它。
年前公司团年,照例和几个老对手(共事3年的同事)切磋了几个小时的麻将,虽然近一年没摸过麻将,依然保持了不败战绩,但个中滋味却让我回味很久。
一直喜欢麻将而不喜欢扑克,因为扑克的多数玩法每盘必须分出胜负,没有和局或无输赢的可能,拿到一手烂牌基本上只有认输,而麻将则可以划船或其他方式化险为夷甚至反败为胜,可谓变化无穷,不愧为国粹。
成都麻将与WEB2.0
成都麻将早期和其他地方没有多大区别,但经过多年简化,去掉了中发白,东南西北,花牌,虽然失去了很多花样,但达到了上手容易、计算简单的好处,加上成都的休闲,人口众多,人人参与,病毒式传播,所以成都麻将的用户量很可能是全国第一的,同时又带动了相关产业的发展(如麻将牌、电子麻将桌、茶铺等),各大棋牌软件都有四川麻将(和成都麻将玩法一样),WEB2.0的发展方式和成都麻将真有异曲同工之处。
根牌和胡牌
因为无论是否胡牌,根牌都能先期获得收入,胡牌时又能增加收入,所以每盘首先关注的是根牌。
每当遇到根牌但又造成手里的牌一片混乱时,总是一种考验,虽然根牌有收入,但造成胡牌难度激增或几乎变成不可完成的任务。这种情况下,每次选择根牌的时候,手上的牌总是看上去很好,总是安慰自己,手气好,还能摸上好牌,但结果大都是其他对手以更多的根牌和胡牌回敬,最后得不偿失,白白损失了一手好牌。但每当舍根为碰,舍去根牌利益,却能让手上的的牌越来越顺,能很快胡出,反而利益最大化。
根牌经常是人生道路上的一道道风景或诱惑,总让人流连忘返或就此拐上另一条道路,前程总是模糊的,眼前的却伸手可及,短期确实很爽,但过了这一段,前面的路变得异常艰难,如何做到欣赏风景又不停下前进的脚步,将诱惑化为能量,真的该认真考虑和权衡。
烂牌和好牌
组织每当摸到手上一副好牌,但这门牌对手们也都要,是做清一色硬碰还是审时度势改为其他方式发展多种经营,是一种选择。大多数时候,硬碰的结果是谁也胡不了,白白损失好牌。还有一种情况是仗着一手好牌,肆意妄为,结果可想而知。
每当摸到一手烂牌,多数人会骂烂牌,最后促成别人赢到比预期还多的收获,摸到烂牌的机会也越来越多,最好以惨败结束。也有人不骂,慢慢摸,慢慢调整,也能做成大牌,最差也能平安过渡,而摸到的牌越来越好,最后经常满载而归。
人生就像不同阶段摸到的牌,少数的人生下来就含着金钥匙,天生好牌,大多数的人都是一手烂牌或极为平常的牌。最后是赢家还是输家,取决于自己的态度。
记得很久前很喜欢打麻将,虽然手气和技术都不差,但总是输多赢少,一次一个做销售的好友看我打麻将(他不会打麻将),看完后分析了我输的原因:胜骄败馁。改正这个问题后,就变成赢多输少,副作用是那个好友从此迷上麻将,至今乐此不疲。麻将中充满了舍得,正确平稳且持久的心态。
谨以此文自勉,在牛年同时也是本命年稳步前行,迈向下一个人生目标。