How can I ret开发者_如何转开发urn a HTTP 401 from a WCF service?
If you are programming a REST-service it can be done this way:
private IWebOperationContext context = new WebOperationContextWrapper(WebOperationContext.Current); // Get the context
context.OutgoingResponse.StatusCode = HttpStatusCode.Unauthorized; // Set the 401
throw new WebFaultException(System.Net.HttpStatusCode.Unauthorized);
Notes:
MSDN: When using a WCF REST endpoint (WebHttpBinding and WebHttpBehavior or WebScriptEnablingBehavior) the HTTP status code on the response is set accordingly. However, WebFaultException can be used with non-REST endpoints and behaves like a regular FaultException.
If you're using the WebServiceHost2 factory from the WCF REST Starter Kit, you can also throw specific WebProtocolException
and specify a HTTP return code:
(source: robbagby.com)
(source: robbagby.com)
(source: robbagby.com)
There's also a HttpStatusCode.Unauthorized
which corresponds to the 401 status code.
See Rob Bagby's excellent blog post Effective Error Handling with WCF REST for more detail on the various ways of specifying HTTP return codes. (screenshots are from Rob's blog post - he deserves all the credit for this.)
Depending on when you need to do the authorization check, you could do it in an HttpModule
using something like the following:
HttpContext context = HttpContext.Current;
context.Response.StatusCode = 401;
context.Response.End();
精彩评论