web-dev-qa-db-ja.com

WebAPIルーティングとhttp投稿

WEB API2を使用してAPIを構築しています。

私は次のAPIコントローラーを持っています:

[RoutePrefix("api/account")]
public class AccountController : ApiController
{
    [Route("login")]
    [HttpPost]
    public IHttpActionResult AuthenticateUser(string username, string password)
    {
        if (string.IsNullOrEmpty(username) || string.IsNullOrEmpty(password))
        {
            return BadRequest("You must submit username and password");
        }

        if (!Membership.ValidateUser(username, password))
        {
            return BadRequest("Incorrect username or password");
        }

        FormsAuthentication.SetAuthCookie(username, true);

        return Ok();
    }
}

そしてjquery関数:

<script>
    $(document).ready(function () {
        $("#login-form").submit(function (e) {
            e.preventDefault();

            var username = $('#username').val();
            var password = $('#password').val();

            $.ajax({
                type: 'POST',
                url: '/api/account/Login/',
                data: { username: username, password: password },
                success: function() {
                    location.reload();
                }
            });
        });
    });
</script>

ログインフォームを送信すると、GoogleChromeのコンソールに次のエラーが表示されます。

POST http://localhost:60898/api/account/Login/ 404 (Not Found)

HTTP POSTを受け入れるルートを作成するにはどうすればよいですか?

ありがとう!

8
šljaker

申し訳ありませんが、この投稿は表示されませんでした: WebAPI-属性ルーティングPOST WebAPI Corsで機能していませんか?

APIコントローラーを次のように更新しました。

[RoutePrefix("api/account")]
public class AccountController : ApiController
{
    public class LoginInfo
    {
        public string username { get; set; }
        public string password { get; set; }
    }

    [Route("login")]
    [HttpPost]
    public IHttpActionResult AuthenticateUser(LoginInfo loginInfo)
    {
        if (string.IsNullOrEmpty(loginInfo.username) || string.IsNullOrEmpty(loginInfo.password))
        {
            return BadRequest("You must submit username and password");
        }

        if (!Membership.ValidateUser(loginInfo.username, loginInfo.password))
        {
            return BadRequest("Incorrect username or password");
        }

        FormsAuthentication.SetAuthCookie(loginInfo.username, true);

        return Ok();
    }
}

そして今、すべてがうまく機能しています。

15
šljaker