アプリ開発ときどきアウトドア

主にJavaを使ったアプリ開発やトラブルシューティング等のノウハウ、キャンプや登山の紹介や体験談など。

1. システムエンジニアリング ASP.NET Core 実装技術

ASP.NET Core: 日本語の文字化け

投稿日:

ダイジェスト

Visual Studio 2019で作成したASP.NET Coreプロジェクトで、プログラム(Razor)から日本語を出力するとHTMLエンコードされてしまいます。例えば「さしすせそ」を出力した場合は「さしすせそ」となってしまいます。
ブラウザや開発者ツール(F12)では正常に表示されるので分からないのですが、実際のソースコードはこのようにHTMLエンコードで出力されています。なお、cshtml上の日本語は問題なく、Razorからの出力のみがこの問題の対象です。

これは次のようにエンコーダの設定を変更することで対応できます。

public void ConfigureServices(IServiceCollection services)
{
    ...
    // HTMLのエンコーディングをUTF-8にする(日本語のHTMLエンコード防止)
    services.Configure<WebEncoderOptions>(options => {
        options.TextEncoderSettings = new TextEncoderSettings(UnicodeRanges.All);
    });
    ...

エンコーダのエンコード対象(エスケープしない文字群)に日本語が含まれていないためエスケープ(HTMLエンコード)されてしまいます。そのため、エンコード対象として、(日本語も含む)ユニコードの全ての文字、を指定しています。
WebEncoderOptionsのTextEncoderSettingsは、エンコーダーでエスケープせずに表現できるコード ポイントを指定します。
UnicodeRangesを使って、ユニコードの範囲を指定しています。

詳細

例えば次のようなビューを作成して実行してみます。

@{
    ViewData["Title"] = "たいとる";
}

<div class="text-center">
    <h1 class="display-4">あいうえお</h1>
    <p>かきくけこ</p>
    <p>@("さしすせそ")</p>

    <button onclick="alert('@("アラート!")');">ボタン</button>
</div>

Chromeで確認してみます。
見た目上、次のように特に問題ありません。
開発者モード(Elementsタブ)で確認しても特に問題があるように見えません。


しかしながら、開発者モード(Sourcesタブ)や「ページのソースを表示」で確認するとHTMLエンコードされています。




(adsbygoogle = window.adsbygoogle || []).push({});


(adsbygoogle = window.adsbygoogle || []).push({});

-1. システムエンジニアリング, ASP.NET Core, 実装技術

執筆者:

関連記事

.NET Core: Azure AD B2Cユーザアカウント操作のサンプル

概要 管理者がAzure AD B2Cのユーザアカウントの管理が行えるASP.NET Coreのアプリの開発を想定している。Azure AD B2Cユーザアカウントの作成や更新等の操作はMicroso …

開発・検証用のFTPサーバ(IIS)を構築

FTPで外部連携するためのプログラムを開発する際に、接続先のFTPサーバの準備に困る場合があります。 ここでは、Widnwos10上に開発・検証用のFTPサーバを構築するための手順を説明します。 「I …

Azure AD B2Cの拡張属性とカスタム属性の違い

Azure AD B2Cのユーザアカウントを操作する際、拡張属性(ExtensionProperty)とカスタム属性(Custom Attribute)というキーワードがあり紛らわしい…と …

ASP.NET Core: Remote属性の過剰なHTTP要求を抑制

Remote属性は入力欄に対する文字入力やフォーカスが外れたタイミングで、サーバ側検証ロジックを実行できます。例えば、登録対象となるユーザIDが既に実在しないかの検証等、サーバ側でしか検証が難しい場合 …

slf4jで独自ログ項目を追加(MDC)

業務要件、障害発生時の処理追跡や証跡等、ログ出力に特定項目を含めたい場合があります。 共通のログ出力ユーティリティやライブラリを作って、その中でログ出力内容を変更しても良いのですが、MDC(Mappe …