既存の動作中の ASP.NET MVC 4 Web アプリケーションがあります。私は独自RoleProvider
に作成し、標準の[Authorize] 属性を使用しています。私のコントローラーは次のようになります。
[Authorize(Roles="ContactAdmins")] //System.Web.Mvc
public ActionResult Index()
アプリケーションに WebAPI コントローラーを追加し、既存の配管を活用したいと考えています。
[Authorize(Roles="ContactAdmins")] //System.Web.Http
public IEnumerable<Contact> Get()
これは、私のサイト内からの Javascript ajax 呼び出しで機能します (ブラウザー ユーザーは既にフォーム認証 Cookie で認証されているため)。私の質問は、C# コンソール アプリケーション (または Web アプリの一部ではない他のアプリケーション) からのもので、この API に対して認証するにはどうすればよいですか?
公開されている API の部分について、この質問Consuming WebApi in MVC3にあるものと非常によく似たコードを使用していると仮定します。
var url = "http://localhost:9000/api/contacts";
using (var client = new WebClient())
using (var reader = XmlReader.Create(client.OpenRead(url)))
{
var serializer = new XmlSerializer(typeof(Contact[]));
var contacts = (Contact[])serializer.Deserialize(reader);
// TODO: Do something with the contacts
}
ここで何を変更する必要がありますか? それとも、これを破棄して、まったく別のアプローチを使用する必要がありますか? リモートクライアントのAPI認証にフォームを使用することに縛られていませんが、アプリの一部であるJavaScriptクライアントに対して現在のエレガントなアプローチを維持したいと思います(フォームCookieが設定されているため、APIをリクエストするだけです)。