wcf实现IP访问限制

wcf开发应用程序的时候常常会遇到一个问题,就是如何只让指定的客户端访问服务,其他客户端禁止访问服务。因为很多时候我们这样做可以防止一系列的黑客攻击、及非法调用等。

今天开心银光将介绍一种在wcf中取得访问端电脑的IP地址而进行过滤的方法,达到一定效果。这种方法对结合asp.net等web应用有很好的效果。

因为asp.net的机制是一个特定的服务器访问wcf,而像silverlight等ria或普通的win程式就比较难达到效果,因为这样的客户端我们无法确定他的ip,目前大多数中国用户使用的都是adsl动态ip。

所以此方案建议构建于asp.net结合的解决方案中。

1.只需在wcf简单的几句代码即可取得访问端的IP地址:

 1:  [OperationContract]
 2:  public string GetCustomerIP()
 3:  {
 4:      string CustomerIP = "";
 5:  
 6:      if( HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"] != null)
 7:          CustomerIP = HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"].ToString();
 8:      else if (HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"] != null)                
 9:          CustomerIP = HttpContext.Current.Request.ServerVariables["REMOTE_ADDR"].ToString();
10:      return CustomerIP;
11:  }
12:  

以上代码即可取得调用端的ip地址。只要再作修改就可以成为限制IP访问wcf服务。须然IIS7也提供了IP访问限制功能,不过在部署方面让操作更简单。这也是一种很多的方案。希望本文对大家有所帮助。

posted @ 2012-12-10 09:14  黎东海  阅读(1445)  评论(1编辑  收藏  举报