近期維護一個Silverlight專案。由於服務端WebService的Authentication驗證改成了使用SoapHeader,使用者名和密碼封裝進了AuthHeader類,通過SoapHeader傳遞。
.Net Framework 4.0下VS2010生成的用戶端Client類沒有包含SoapHeader相關的屬性,沒有辦法直接賦值。後在國外網站上發現如下方法:
我們可以使用System.ServiceModel.Channels.MessageHeader類,在Silverlight程式下建立一個AuthHeader類並繼承MessageHeader
1:  public class AuthHeader : MessageHeader
   2:  {
   3:      public string UserName { get; set; }
   4:      public string Password { get; set; }
   5:   
   6:      protected override void OnWriteHeaderContents(System.Xml.XmlDictionaryWriter writer, MessageVersion messageVersion)
   7:      {
   8:          writer.WriteElementString("UserName", "http://www.dovery.net/", UserName);
   9:          writer.WriteElementString("Password", "http://www.dovery.net/", Password);
  10:      }
  11:   
  12:      public override string Name
  13:      {
  14:          get { return "AuthHeader"; }
  15:      }
  16:   
  17:      public override string Namespace
  18:      {
  19:          get { return "http://www.dovery.net/"; }
  20:      }
  21:  }
上面代碼中UserName和Password屬性是WebService裡AuthHeader類的兩個屬性。需要注意的是OnWriteHeaderContents方法的重寫,這裡需要通過System.Xml.XmlDictionaryWriter物件往SoapHeader裡寫入使用者名和密碼的結點,注意結點的命名空間要與Namespace返回的命名空間一致,否則WebService會找不到使用者名和密碼。關於MessageHeader類的文檔,參照MSDN。
到這裡,SoapHeader準備好了,下面開始向WebService發送Soap
  1:  FingerprintWebServiceSoapClient client = new FingerprintWebServiceSoapClient();
   2:  client.GetSuspectInfoCompleted += new EventHandler<GetSuspectInfoCompletedEventArgs>((obj, ev) =>
   3:  {
   4:      MessageBox.Show(ev.Result.Data.ToString());
   5:  });
   6:  OperationContext.Current = new OperationContext(client.InnerChannel);
   7:  MessageHeader header = new SilverlightApplication1.AuthHeader();
   8:  OperationContext.Current.OutgoingMessageHeaders.Add(header);
   9:  client.GetSuspectInfoAsync("Fingerprint", "Justin");
上面代碼中注意倒數2,3,4行。相關類的說明這裡省略,詳細見MSDN。
通過這種方法,WebService就能接收到SoapHeader了。
創作者介紹
創作者 shadow 的頭像
shadow

資訊園

shadow 發表在 痞客邦 留言(0) 人氣()