色んなドキュメントを見たりしていると、タイトルのように複数の大文字小文字のパターンがありどれならいいのか混乱したので少し調べた「メモ」です。
rfc7540#section-8.1.2の辺りを見ました。
HTTP1.1 では大文字小文字区別しない
HTTP2 では大文字は駄目で、小文字である必要がある?
とのことです。
なので多分content-type
を使っていけば問題ないのかなということで、小文字を使っていこうと思いました。
色んなドキュメントを見たりしていると、タイトルのように複数の大文字小文字のパターンがありどれならいいのか混乱したので少し調べた「メモ」です。
rfc7540#section-8.1.2の辺りを見ました。
HTTP1.1 では大文字小文字区別しない
HTTP2 では大文字は駄目で、小文字である必要がある?
とのことです。
なので多分content-type
を使っていけば問題ないのかなということで、小文字を使っていこうと思いました。
いつか書く。
通信許可できる参照元オリジン名。
この通信で許可できるメソッド GET, POST, OPTIONS, PUT, PATCH, DELETE
通信時にヘッダーに含めても大丈夫な項目。
クッキーをやり取りするかどうか。する場合はtrue
を指定します。
OPTIONS
のヘッダーのAccess-Control-Allow-Origin
の値と実際のメソッドのヘッダーで返しているAccess-Control-Allow-Origin
の値が異なる。
以下はやった時のメモになります。その時は以下のファイルがありました。
csr
(Certificate Signing Request) コモンネームや組織名が含まれているファイル
-----BEGIN CERTIFICATE REQUEST-----
が含まれる
cer
, ca
, crt
デジタル証明書ファイル
-----BEGIN CERTIFICATE-----
が含まれる
ルート証明書と中間CA証明書?(恐らくcer
やca
)
サーバー証明書?(恐らくcrt
)
全部certificate
の略?
rsa
秘密鍵ファイル
-----BEGIN PRIVATE KEY-----
が含まれる
手元に有るファイルが上記以外の拡張子だった場合、以下の方法で確認することができます。
// Certificate Signing Request か?
openssl req -text -noout -in
// cer(crt?) か?
openssl x509 -text -noout -in
// rsa か?
openssl rsa -text -noout -in
結果が長々と出てきたり(Bash)echo $?
や(Fish)echo $status
で0
だったものが正です。
今回はcer(crt?)ファイルがすでに複数存在していたので、 証明書発行の為の Certificate Signing Request は扱わなくて良いようです。
また複数存在しているcer(crt?)ファイルを 1 つのファイルに結合する必要がありますが、上記のopenssl x509
を実行した時にSubject:
の値がCN=自分のドメイン
となっているファイルをが先頭に来るようにします。(複数ある場合は、Issuer:
も見て次にその証明書が来るように結合しないと駄目?)
以下のような形で結合します。ただcat
で結合すると-----END CERTIFICATE----------BEGIN CERTIFICATE-----
のようになってしまうので、<(echo)
によって改行を挟んでいます。
また、権限は400
に設定します。
cat www.example.com.cer <(echo) ca.cer > result.crt
chmod 400 result.crt
# できたファイルに対しても確認をしておく
openssl x509 -text -noout -in result.crt
できたらサーバーに上げて更新します。
Basic Auth(Basic 認証)を使うと Web ページに簡単な認証を付けれます。認証はユーザー名とパスワードのペアから成るもので、このペアが一致した場合のみ本来のリクエストを取得できます。
セキュリティとしては貧弱ですが、ちょっとした Web サイトの開発中などに特定の誰かとのネットを介した共有などを行うにあたっては割と便利です。
図を作りました。
PlantUML では。
@startuml
participant browser
participant server
autonumber
browser -> server: アクセス
loop
alt 認証が失敗
server -> browser: 401\nwww-authenticate: Basic realm=... を返す
browser -> browser: 認証ダイアログを出す
opt ユーザー名とパスワード入力
browser -> server: authorization: Basic ... を送信
server -> server: 認証
end
else
server -> browser: 200
end
end
@enduml
www-authenticate: Basic realm="..."
ヘッダーを持たせて401
ステータスコードでレスポンスを返します。(...
は適当な文字列になります)
このヘッダーを持つ401
レスポンスを受け取ったブラウザは自動的に認証ダイアログを表示してくれます。
ダイアログにはキャンセルボタンもあるので、ユーザーがそれをクリックした場合、そこで一連のフローは終わります。
ユーザーがユーザーとパスワードを送信した場合、サーバーではauthorization: Basic ...
というヘッダーが含まれて送られてきます。(...
はユーザー名とパスワードを:
で繋げてbase64
化したものです
サーバーはそのヘッダーからbase64
化された部分を取り出し、自分たちの持つ認証情報とマッチするか確認します。
ここで認証が失敗すればまた401
をwww-authenticate
付きで送り上記のフローを繰り返し、認証が成功すれば200
で本来受け取るべきレスポンスを受け取ります。
ExpressJS で作った例です。以下で起動して、
yarn && yarn dev
localhost:9997/foo
やlocalhost:9997/bar
といった URL で確認できます。
ヘッダーにx-frame-options
を含めると、そのレスポンス結果をリファラーサイトの<iframe>
で表示しても良いかどうか決めれます。
このオプションは次の2つ(3つ)の値を持てます。
deny
sameorigin
allow-from <url>
ただし3つ目のallow-from <url>
は古いのかうまく設定が効きかなかったので、覚えなくて良いかもしれません。
リファラサイトへの<iframe>
での埋め込みを禁じます。禁じられた場合 Chrome では接続拒否画面が表示されます。
allow-from
が使えないので、もしサイトによって許可・不許可の制御が必要なのであればreferer
ヘッダーを都度見てx-frame-options: deny
を設定する必要がありそうです。
同ドメイン内だけに<iframe>
埋め込みを許可したい場合はこの値です。例えばlocalhost:3000/contents
を埋め込む場合、localhost:3000
では大丈夫ですが、localhost:30001
では接続が拒否されます。