Files
cpp-httplib/docs-src/pages/ja/cookbook/s10-post-routing.md
2026-04-10 18:47:42 -04:00

2.3 KiB
Raw Permalink Blame History

title, order, status
title order status
S10. Post-routing handlerでレスポンスヘッダーを追加する 29 draft

ハンドラが返したレスポンスに、あとから共通のヘッダーを追加したいことがあります。CORSヘッダー、セキュリティヘッダー、独自のリクエストIDなどです。こういうときはset_post_routing_handler()を使います。

基本の使い方

svr.set_post_routing_handler(
  [](const httplib::Request &req, httplib::Response &res) {
    res.set_header("X-Request-ID", generate_request_id());
  });

Post-routingハンドラは、ルートハンドラが実行された後、レスポンスが送信される前に呼ばれます。ここでres.set_header()res.headers.erase()を使えば、全レスポンスに対して一括でヘッダーの追加・削除ができます。

CORSヘッダーを付ける

よくある用途がCORSです。

svr.set_post_routing_handler(
  [](const httplib::Request &req, httplib::Response &res) {
    res.set_header("Access-Control-Allow-Origin", "*");
    res.set_header("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS");
    res.set_header("Access-Control-Allow-Headers", "Content-Type, Authorization");
  });

プリフライトリクエスト(OPTIONSには別途ハンドラを登録するか、pre-routingハンドラで処理します。

svr.Options("/.*", [](const auto &req, auto &res) {
  res.status = 204;
});

セキュリティヘッダーをまとめて付ける

ブラウザ向けのセキュリティヘッダーを一箇所で管理できます。

svr.set_post_routing_handler(
  [](const httplib::Request &req, httplib::Response &res) {
    res.set_header("X-Content-Type-Options", "nosniff");
    res.set_header("X-Frame-Options", "DENY");
    res.set_header("Referrer-Policy", "strict-origin-when-cross-origin");
  });

どのハンドラがレスポンスを作っても、同じヘッダーが付くようになります。

Note: Post-routingハンドラは、ルートにマッチしなかったリクエストや、エラーハンドラが返したレスポンスに対しても呼ばれます。ヘッダーをすべてのレスポンスに確実に付けたいときに便利です。