DotNetOpenAuth实践之Webform资源服务器配置
系列目录:
DotNetOpenAuth实践系列(源码在这里)
上篇我们讲到WebApi资源服务器配置,这篇我们说一下Webform下的ashx,aspx做的接口如何使用OAuth2认证
一、环境搭建
1、新建Webform项目
2、使用Nuget添加DotNetOpenAuth 5.0.0 alpha3
3、把上次制作的证书文件拷贝的项目中
二、编写关键代码
1、公共代码
ResourceServerConfiguration
1 using System.Security.Cryptography.X509Certificates; 2 3 namespace WebformResourcesServer.Code 4 { 5 public class ResourceServerConfiguration 6 { 7 public X509Certificate2 EncryptionCertificate { get; set; } 8 public X509Certificate2 SigningCertificate { get; set; } 9 } 10 }
Common.cs
1 namespace WebformResourcesServer.Code 2 { 3 public class Common 4 { 5 public static ResourceServerConfiguration Configuration = new ResourceServerConfiguration(); 6 } 7 }
Global
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Security.Cryptography.X509Certificates; 5 using System.Web; 6 using System.Web.Optimization; 7 using System.Web.Routing; 8 using System.Web.Security; 9 using System.Web.SessionState; 10 using WebformResourcesServer.Code; 11 12 namespace WebformResourcesServer 13 { 14 public class Global : HttpApplication 15 { 16 void Application_Start(object sender, EventArgs e) 17 { 18 Common.Configuration = new ResourceServerConfiguration 19 { 20 EncryptionCertificate = new X509Certificate2(Server.MapPath("~/Certs/idefav.pfx"), "a"), 21 SigningCertificate = new X509Certificate2(Server.MapPath("~/Certs/idefav.cer")) 22 }; 23 // 在应用程序启动时运行的代码 24 RouteConfig.RegisterRoutes(RouteTable.Routes); 25 BundleConfig.RegisterBundles(BundleTable.Bundles); 26 } 27 } 28 }
2、关键代码
ashxhandler
1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Net.Http; 5 using System.Security.Cryptography; 6 using System.Security.Principal; 7 using System.Threading; 8 using System.Threading.Tasks; 9 using System.Web; 10 using System.Web.UI; 11 using DotNetOpenAuth.Messaging; 12 using DotNetOpenAuth.OAuth2; 13 14 namespace WebformResourcesServer.Code 15 { 16 public class AshxHandler 17 { 18 public AshxHandler(HttpContext context) 19 { 20 Context = context; 21 } 22 23 public HttpContext Context { get; set; } 24 25 private async Task<IPrincipal> VerifyOAuth2(HttpRequestBase httpDetails, params string[] requiredScopes) 26 { 27 var resourceServer = new ResourceServer(new StandardAccessTokenAnalyzer((RSACryptoServiceProvider)Common.Configuration.SigningCertificate.PublicKey.Key, (RSACryptoServiceProvider)Common.Configuration.EncryptionCertificate.PrivateKey)); 28 return await resourceServer.GetPrincipalAsync(httpDetails, requiredScopes: requiredScopes); 29 30 } 31 32 public async Task Proc(Action<HttpContext> action) 33 { 34 try 35 { 36 var principal = await VerifyOAuth2(new HttpRequestWrapper(Context.Request)); 37 if (principal != null) 38 { 39 Context.User = principal; 40 Thread.CurrentPrincipal = principal; 41 action.Invoke(Context); 42 } 43 } 44 catch (ProtocolFaultResponseException exception) 45 { 46 var outgoingResponse = await exception.CreateErrorResponseAsync(CancellationToken.None); 47 Context.Response.StatusCode = (int)outgoingResponse.StatusCode; 48 //Context.Response.SuppressContent = true; 49 foreach (var header in outgoingResponse.Headers) 50 { 51 52 //Context.Response.Headers[header.Key] = header.Value.First(); 53 Context.Response.AddHeader(header.Key, header.Value.First()); 54 } 55 Context.Response.Write(exception.Message); 56 } 57 } 58 } 59 }
3、添加一个ashx文件
目录:
代码:
1 using System; 2 using System.Threading; 3 using System.Threading.Tasks; 4 using System.Web; 5 using WebformResourcesServer.Code; 6 7 namespace WebformResourcesServer.Api 8 { 9 /// <summary> 10 /// Values 的摘要说明 11 /// </summary> 12 public class Values : IHttpAsyncHandler 13 { 14 15 public void ProcessRequest(HttpContext context) 16 { 17 context.Response.ContentType = "text/plain"; 18 } 19 20 public bool IsReusable 21 { 22 get 23 { 24 return false; 25 } 26 } 27 28 public IAsyncResult BeginProcessRequest(HttpContext context, AsyncCallback cb, object extraData) 29 { 30 return new AsyncResult(cb, extraData, new AshxHandler(context).Proc(c => 31 { 32 c.Response.Write("The Data you get!"); 33 })); 34 35 36 } 37 38 public void EndProcessRequest(IAsyncResult result) 39 { 40 var r = (AsyncResult)result; 41 r.Task.Wait(); 42 43 } 44 } 45 46 internal class AsyncResult : IAsyncResult 47 { 48 private object _state; 49 private Task _task; 50 private bool _completedSynchronously; 51 52 public AsyncResult(AsyncCallback callback, object state, Task task) 53 { 54 _state = state; 55 _task = task; 56 _completedSynchronously = _task.IsCompleted; 57 _task.ContinueWith(t => callback(this), TaskContinuationOptions.ExecuteSynchronously); 58 } 59 60 public Task Task 61 { 62 get { return _task; } 63 } 64 65 66 public object AsyncState 67 { 68 get { return _state; } 69 } 70 71 public WaitHandle AsyncWaitHandle 72 { 73 get { return ((IAsyncResult)_task).AsyncWaitHandle; } 74 } 75 76 public bool CompletedSynchronously 77 { 78 get { return _completedSynchronously; } 79 } 80 81 public bool IsCompleted 82 { 83 get { return _task.IsCompleted; } 84 } 85 } 86 }
4、测试
获取access_token
访问api
如果token不正确
到这篇为止,本系列基本结束,如果有不明白的地方可以评论留言,感谢大家的关注
posted on 2015-10-24 09:18 idefav2010 阅读(1680) 评论(2) 编辑 收藏 举报