httpc:request()関数によるhttpリクエストでクライアント認証用のユーザー/パスワードを指定するにはどうすればよいですか?
4 に答える
httpc
モジュールがそのための機能を提供するとは思わない。それでも、実装するのは難しくありません(基本認証について話している場合)。結局のところ、これはBase64でエンコードされた「user:password」ペアを持つ単なる追加のリクエストヘッダーです。たとえば、Tsungのts_http_commonモジュールがそれを行います。
たとえば、基本認証を使用してHTTPPUTリクエストを実行する方法は次のとおりです。
auth_header(User, Pass) ->
Encoded = base64:encode_to_string(lists:append([User,":",Pass])),
{"Authorization","Basic " ++ Encoded}.
put_request(Url, User, Pass, Body) ->
ContentType = "text/json",
Headers = [auth_header(User, Pass), {"Content-Type",ContentType}],
Options = [{body_format,binary}],
httpc:request(put, {Url, Headers, ContentType, Body}, [], Options).
ドキュメントで、HTTPOptionsがパスとユーザーを保持していることがわかります。
HTTPOptions = http_options()
http_options() = [http_option()]
http_option() = {timeout, timeout()} | {connect_timeout, timeout()} | {ssl, ssloptions()} | {ossl, ssloptions()} | {essl, ssloptions()} | {autoredirect, boolean()} | {proxy_auth, {userstring(), passwordstring()}} | {version, http_version()} | {relaxed, boolean()} | {url_encode, boolean()}
ダイジェストの場合、基本と同じことを行う必要がありますが、それ以上のことを行う必要があります。通常、認証なしでページにアクセスし、「WWW-Authenticate」ヘッダー情報を取得してから、レルムとナンスを使用して「Authorization」ヘッダーを生成します。 http://en.wikipedia.org/wiki/Digest_access_authenticationの下部に適切な例があります。
一般に、ほとんどのユースケースでは、HTTPS+Basicで十分です。
サポートしているibrowseを使用してみてください。私はそれを使用しています。https://github.com/cmullaparthi/ibrowse