<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
    <channel>
        <title>Aliases on KnightLiブログ</title>
        <link>https://www.knightli.com/ja/tags/aliases/</link>
        <description>Recent content in Aliases on KnightLiブログ</description>
        <generator>Hugo -- gohugo.io</generator>
        <language>ja</language>
        <lastBuildDate>Sun, 17 May 2026 20:00:17 +0800</lastBuildDate><atom:link href="https://www.knightli.com/ja/tags/aliases/index.xml" rel="self" type="application/rss+xml" /><item>
        <title>Hugo aliases の使い方：古い URL の自動リダイレクトと 404 修正ガイド</title>
        <link>https://www.knightli.com/ja/2026/05/17/hugo-aliases-url-redirect/</link>
        <pubDate>Sun, 17 May 2026 20:00:17 +0800</pubDate>
        
        <guid>https://www.knightli.com/ja/2026/05/17/hugo-aliases-url-redirect/</guid>
        <description>&lt;p&gt;Hugo の &lt;code&gt;aliases&lt;/code&gt; は、ページの古い URL に対してリダイレクトを作るための機能だ。&lt;/p&gt;
&lt;p&gt;記事の URL を変更したとき、ページを統合したとき、ブログを移行したとき、またはよくある誤った URL を救済したいとき、記事の Front Matter に &lt;code&gt;aliases&lt;/code&gt; を追加できる。Hugo はそれらの古いアドレス用にリダイレクトページを生成し、訪問者を現在の記事の新しいアドレスへ送る。これにより、古いリンクがそのまま 404 になるのを避けられる。&lt;/p&gt;
&lt;h2 id=&#34;aliases-が役立つ場面&#34;&gt;aliases が役立つ場面
&lt;/h2&gt;&lt;p&gt;よくある場面は三つある。&lt;/p&gt;
&lt;p&gt;一つ目は記事 URL の整理だ。&lt;/p&gt;
&lt;p&gt;たとえば、元の記事 URL が次のようなものだったとする。&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-text&#34; data-lang=&#34;text&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;/posts/tech/2023-01-01-hello/
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;後から、より短い URL に変えたい場合がある。&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-text&#34; data-lang=&#34;text&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;/hello/
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;このとき、新しい記事に古いアドレスを alias として追加する。すると検索エンジン、外部リンク、SNS 上の古いリンクからも内容へ到達できる。&lt;/p&gt;
&lt;p&gt;二つ目はページの統合や移行だ。&lt;/p&gt;
&lt;p&gt;複数の古い記事を一つの新しい記事にまとめる場合や、Hexo、Typecho、WordPress などから Hugo に移行する場合、古いプラットフォームの URL 構造は新しいサイトと一致しないことが多い。&lt;code&gt;aliases&lt;/code&gt; を使えば、それらの古いアドレスを新しいページへ一つずつ向けられ、移行後の 404 を減らせる。&lt;/p&gt;
&lt;p&gt;三つ目はスペルミスの処理だ。&lt;/p&gt;
&lt;p&gt;URL を過去に誤って書いたり、外部サイトが間違ったパスにリンクしていたりすることがある。その誤ったリンクにアクセスがあるなら、専用の alias を設定して、ユーザーを正しいページへ誘導できる。&lt;/p&gt;
&lt;h2 id=&#34;基本的な書き方&#34;&gt;基本的な書き方
&lt;/h2&gt;&lt;p&gt;記事の Front Matter に &lt;code&gt;aliases&lt;/code&gt; フィールドを追加するだけでよい。&lt;/p&gt;
&lt;p&gt;YAML の例は次の通り。&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;2
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;3
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;4
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;5
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;6
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;7
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;8
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-yaml&#34; data-lang=&#34;yaml&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nn&#34;&gt;---&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;title&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;s2&#34;&gt;&amp;#34;新しい記事タイトル&amp;#34;&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;date&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;ld&#34;&gt;2026-05-17T12:00:00&lt;/span&gt;&lt;span class=&#34;m&#34;&gt;+09&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;m&#34;&gt;00&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;url&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;l&#34;&gt;/new-path/my-new-article/&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;aliases&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;  &lt;/span&gt;- &lt;span class=&#34;l&#34;&gt;/old-path/old-article/&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;  &lt;/span&gt;- &lt;span class=&#34;l&#34;&gt;../old-version/&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nn&#34;&gt;---&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;ここで &lt;code&gt;/old-path/old-article/&lt;/code&gt; はサイト相対パスだ。&lt;code&gt;../old-version/&lt;/code&gt; は現在のページからの相対パスになる。&lt;/p&gt;
&lt;p&gt;実際には、&lt;code&gt;/&lt;/code&gt; で始まるサイト相対パスを優先する方が分かりやすい。直感的で、記事ディレクトリ構造が変わったときにも誤解が起きにくい。&lt;/p&gt;
&lt;h2 id=&#34;url-フィールドとの関係&#34;&gt;url フィールドとの関係
&lt;/h2&gt;&lt;p&gt;&lt;code&gt;url&lt;/code&gt; は現在ページの新しいアドレスを決める。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;aliases&lt;/code&gt; は、どの古いアドレスをその新しいアドレスへリダイレクトするかを決める。&lt;/p&gt;
&lt;p&gt;例：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;2
&lt;/span&gt;&lt;span class=&#34;lnt&#34;&gt;3
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-yaml&#34; data-lang=&#34;yaml&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;url&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;w&#34;&gt; &lt;/span&gt;&lt;span class=&#34;l&#34;&gt;/new-path/my-new-article/&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;nt&#34;&gt;aliases&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;:&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;w&#34;&gt;  &lt;/span&gt;- &lt;span class=&#34;l&#34;&gt;/old-path/old-article/&lt;/span&gt;&lt;span class=&#34;w&#34;&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;ビルド後、ユーザーが &lt;code&gt;/old-path/old-article/&lt;/code&gt; にアクセスすると、&lt;code&gt;/new-path/my-new-article/&lt;/code&gt; へリダイレクトされる。&lt;/p&gt;
&lt;p&gt;記事で &lt;code&gt;url&lt;/code&gt; を明示していない場合、Hugo はサイトの &lt;code&gt;permalinks&lt;/code&gt; 設定、記事の日付、slug などのルールから現在ページのアドレスを生成する。&lt;code&gt;aliases&lt;/code&gt; はその最終的に生成されたページを指す。&lt;/p&gt;
&lt;h2 id=&#34;hugo-のデフォルト実装&#34;&gt;Hugo のデフォルト実装
&lt;/h2&gt;&lt;p&gt;デフォルトでは、Hugo は alias ごとに独立した HTML ファイルを生成する。&lt;/p&gt;
&lt;p&gt;その HTML ファイルは通常、次のタグを使う。&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;div class=&#34;chroma&#34;&gt;
&lt;table class=&#34;lntable&#34;&gt;&lt;tr&gt;&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code&gt;&lt;span class=&#34;lnt&#34;&gt;1
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;
&lt;td class=&#34;lntd&#34;&gt;
&lt;pre tabindex=&#34;0&#34; class=&#34;chroma&#34;&gt;&lt;code class=&#34;language-html&#34; data-lang=&#34;html&#34;&gt;&lt;span class=&#34;line&#34;&gt;&lt;span class=&#34;cl&#34;&gt;&lt;span class=&#34;p&#34;&gt;&amp;lt;&lt;/span&gt;&lt;span class=&#34;nt&#34;&gt;meta&lt;/span&gt; &lt;span class=&#34;na&#34;&gt;http-equiv&lt;/span&gt;&lt;span class=&#34;o&#34;&gt;=&lt;/span&gt;&lt;span class=&#34;s&#34;&gt;&amp;#34;refresh&amp;#34;&lt;/span&gt;&lt;span class=&#34;p&#34;&gt;&amp;gt;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;
&lt;/div&gt;
&lt;/div&gt;&lt;p&gt;これにより、ブラウザが古いアドレスを開いたあと自動的に新しいアドレスへ移動する。&lt;/p&gt;
&lt;p&gt;この方式はシンプルで、プラットフォームを問わず使いやすく、一般的な静的ホスティングに向いている。ただし本質的にはブラウザ側のリダイレクトであり、サーバーが返す 301 / 302 リダイレクトではない。&lt;/p&gt;
&lt;p&gt;小規模サイトなら、通常はこれで十分だ。古いアドレスが開けて、最終的に新しい記事へ到達できるなら、目立つ 404 問題は避けられる。&lt;/p&gt;
&lt;h2 id=&#34;サーバーサイドリダイレクトを検討する場面&#34;&gt;サーバーサイドリダイレクトを検討する場面
&lt;/h2&gt;&lt;p&gt;サイトを Netlify、Cloudflare Pages、Vercel など、リダイレクトルールをサポートする環境で運用しているなら、サーバーサイドリダイレクトを検討できる。&lt;/p&gt;
&lt;p&gt;サーバーサイドリダイレクトには次の利点がある。&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;中間の HTML リダイレクトページを返さず、より直接的に応答できる。&lt;/li&gt;
&lt;li&gt;301 または 302 ステータスコードを明示しやすい。&lt;/li&gt;
&lt;li&gt;大量の移行ルールを集中管理しやすく、監査と保守が楽になる。&lt;/li&gt;
&lt;li&gt;SEO 移行をより制御しやすい。&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;よくある方法は、Hugo のデフォルト alias ページ生成を無効化し、ホスティング環境が必要とするリダイレクトルールファイルを出力することだ。Netlify では &lt;code&gt;_redirects&lt;/code&gt; がよく使われ、Cloudflare Pages でも &lt;code&gt;_redirects&lt;/code&gt; やプラットフォーム側のルールを使える。&lt;/p&gt;
&lt;p&gt;この方針を取る場合は、Hugo の &lt;code&gt;disableAliases&lt;/code&gt; とカスタム output format を確認する必要がある。単に &lt;code&gt;aliases&lt;/code&gt; を削除してはいけない。そうすると古いリンクはそのまま 404 になる。&lt;/p&gt;
&lt;h2 id=&#34;aliases-を使うときの注意点&#34;&gt;aliases を使うときの注意点
&lt;/h2&gt;&lt;p&gt;第一に、&lt;code&gt;aliases&lt;/code&gt; を URL を気軽に変更する口実にしない。&lt;/p&gt;
&lt;p&gt;URL は一度公開されると、検索エンジン、RSS、SNS、ブックマーク、外部リンクに入っていく。頻繁な URL 変更は保守コストを生む。&lt;code&gt;aliases&lt;/code&gt; は、パスを頻繁に変えるためではなく、過去の問題を修正するために使うのがよい。&lt;/p&gt;
&lt;p&gt;第二に、alias の循環を避ける。&lt;/p&gt;
&lt;p&gt;古いアドレスは現在の記事の新しいアドレスへ向けるべきだ。A が B に飛び、B がまた A に戻るような構成や、複数ページが同じ alias を奪い合う構成は避ける。&lt;/p&gt;
&lt;p&gt;第三に、多言語サイトでは言語プレフィックスに注意する。&lt;/p&gt;
&lt;p&gt;Hugo の多言語サイトでは、言語パスが自動処理されることが多い。ある言語版の記事内で alias を書く場合、&lt;code&gt;/en/&lt;/code&gt; や &lt;code&gt;/zh-tw/&lt;/code&gt; のようなプレフィックスを手動で付けなくてよい場合がある。付けてしまうと &lt;code&gt;/en/en/...&lt;/code&gt; のような重複パスが生成されることがある。具体的な挙動はローカルビルド結果で確認する。&lt;/p&gt;
&lt;p&gt;第四に、変更後は生成ディレクトリを確認する。&lt;/p&gt;
&lt;p&gt;alias を追加したら一度サイトをビルドし、&lt;code&gt;public&lt;/code&gt; ディレクトリに古いパスに対応する &lt;code&gt;index.html&lt;/code&gt; が生成されたか確認する。さらに、その中のリダイレクト先が正しいかを見る。&lt;/p&gt;
&lt;h2 id=&#34;実用的な確認手順&#34;&gt;実用的な確認手順
&lt;/h2&gt;&lt;p&gt;記事の Front Matter を編集したら、次の流れで確認するとよい。&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;現在の記事の新しい URL を確認する。&lt;/li&gt;
&lt;li&gt;&lt;code&gt;aliases&lt;/code&gt; に古い URL を書く。&lt;/li&gt;
&lt;li&gt;Hugo ビルドを実行する。&lt;/li&gt;
&lt;li&gt;&lt;code&gt;public&lt;/code&gt; ディレクトリで古い URL に対応する &lt;code&gt;index.html&lt;/code&gt; が生成されたか確認する。&lt;/li&gt;
&lt;li&gt;生成された HTML を開き、リダイレクト先が新しい URL か確認する。&lt;/li&gt;
&lt;li&gt;多言語ページでは、言語プレフィックスが重複していないか特に確認する。&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;これで、デプロイ前に多くのパス問題を見つけられる。&lt;/p&gt;
&lt;h2 id=&#34;まとめ&#34;&gt;まとめ
&lt;/h2&gt;&lt;p&gt;&lt;code&gt;aliases&lt;/code&gt; は、Hugo で古いリンクを扱うための軽量な仕組みだ。&lt;/p&gt;
&lt;p&gt;記事 URL の変更、ブログ移行、ページ統合、誤ったパスの修正に向いている。一般的な静的サイトなら Hugo がデフォルトで生成する HTML リダイレクトページをそのまま使える。サイト規模が大きい場合や SEO 移行をより厳密に扱いたい場合は、サーバーサイドリダイレクトルールへ進むとよい。&lt;/p&gt;
&lt;p&gt;大事なのは、新しいリンクをきれいにすることだけではない。すでに存在する古いリンクも守ることだ。古い URL を新しいページへ滑らかに連れていけるサイトは、移行やリニューアルで過去の流入を失いにくい。&lt;/p&gt;
&lt;h2 id=&#34;参考資料&#34;&gt;参考資料
&lt;/h2&gt;&lt;ul&gt;
&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://gohugo.io/content-management/urls/#aliases&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;
    &gt;Hugo Documentation: Aliases&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a class=&#34;link&#34; href=&#34;https://gohugo.io/content-management/urls/&#34;  target=&#34;_blank&#34; rel=&#34;noopener&#34;
    &gt;Hugo Documentation: URL management&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
</description>
        </item>
        
    </channel>
</rss>
