我们在IIS7中运行了一个WCF(.NET 3.5 SP1)服务,该服务被标记为允许ASP.NET兼容模式,因此我们可以访问HttpContext.Current
:
[AspNetCompatibilityRequirements(
RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
但是,在尝试访问任何服务器变量时,它会抛出ArgumentException
:
System.ArgumentException: Value does not fall within the expected range.
at System.Runtime.InteropServices.Marshal.ThrowExceptionForHRInternal(Int32 errorCode, IntPtr errorInfo)
at System.Web.Hosting.IIS7WorkerRequest.GetServerVariableInternal(String name)
at System.Web.Hosting.IIS7WorkerRequest.GetServerVariable(String name)
at System.Web.Hosting.IIS7WorkerRequest.GetRemoteAddress()
at System.Web.HttpRequest.get_UserHostAddress()
e.g。以下任何行都会抛出此异常:
ha = HttpContext.Current.Request.UserHostAddress;
ip = HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_FOR"];
us = HttpContext.Current.Request.UserAgent;
这似乎是内部框架调用的结果,这意味着调用代码没有错误。
据推测,我们的配置中有一些东西导致了这个问题,但我不知道是什么。有任何想法吗?或者任何想法我还能如何检索这三位数据(不幸的是,它们本身并不是由WCF本身公开)。
答案 0 :(得分:14)
原来问题是操作标有...
[OperationContract(IsOneWay = true)]
...并且单向操作中的服务器变量不可用。
羞耻的例外并没有说出那种效果......