API Design: HTTP Basic Authentication vs API Token

前端 未结 4 1528
走了就别回头了
走了就别回头了 2021-01-29 22:37

I\'m currently creating an authentication system on front of a public web API for a web application. Given that each user account has an API key and each request must be authent

4条回答
  •  一生所求
    2021-01-29 23:09

    Best bet might be using an API key in the header (e.g. 'Authorization: Token MY_API_KEY') instead of as a url param:

    Advantages over HTTP Basic Auth:

    • More convenient, as you can easily expire or regenerate tokens without affecting the user's account password.
    • If compromised, vulnerability limited to API, not the user's master account
    • You can have multiple keys per account (e.g. users can have "test" and "production" keys side by side.)

    Advantages over API key in URL:

    • Provides extra measure of security by preventing users from inadvertently sharing URLs with their credentials embedded in them. (Also, URL can wind up in things like server logs)

提交回复
热议问题