WCF:跨电脑调用方未由服务器进行身份验证

1、修改配置文件
<configuration>
    <system.serviceModel>

      <bindings>
        <wsHttpBinding>
          <binding name= " NoneSecurity "
            maxBufferPoolSize= " 12000000 " maxReceivedMessageSize= " 12000000 " useDefaultWebProxy= " false " >
            <readerQuotas maxStringContentLength= " 12000000 " maxArrayLength= " 12000000 " />
            <security mode= " None " />
          </binding>
        </wsHttpBinding>
      </bindings>

<services>
    <service name= " WcfService2.Service1 " behaviorConfiguration= " WcfService2.Service1Behavior ">
     <!-- Service Endpoints -->
     <endpoint address= "" binding= " wsHttpBinding " bindingConfiguration= " NoneSecurity " contract= " WcfService2.IService1 ">

红色部分就是添加的代码,服务端 客户端都要 这样添加。

如果客户端未添加配置,会出现:

无法打开安全通道,因为与远程终结点的安全协商已失败。这可能是由于用于创建通道的 EndpointAddress 中不存在 EndpointIdentity 或错误指定了 EndpointIdentity。请确认由 EndpointAddress 指定或暗示的 EndpointIdentity 正确标识了远程终结点。
 
2、修改服务端
就是调整服务器端 Binding 的安全方式,比如设为 "None"。
NetTcpBinding binding = new NetTcpBinding();
binding.Security.Mode = SecurityMode.None;

ServiceHost host = new ServiceHost(typeof(MyService));
host.AddServiceEndpoint(typeof(IService), binding, "net.tcp://192.168.0.112:8081");

ServiceMetadataBehavior metadata = new ServiceMetadataBehavior();
metadata.HttpGetUrl = new Uri("http://192.168.0.112:8080");
metadata.HttpGetEnabled = true;
host.Description.Behaviors.Add(metadata);

host.Open();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值