ASP.NET サポート音声列

この列をニーズに合わせてカスタマイズするには、関心のあるトピックと、今後のサポート技術情報の記事やサポート音声列で対処する必要がある問題に関するアイデアを提出するようお勧めします。 アイデアとフィードバックを送信するには、Ask For It フォームを使用します。 この列の下部には、フォームへのリンクもあります。

はじめに

ようこそ! Microsoft ASP.NET 開発者サポート チームの Sukesh Khare です。 サポート音声列を作成するのは初めてです。 私は数ヶ月先にそのような列をさらに作成することを楽しみにしています。今月のコラムでは、Active Server Pages (ASP) と ASP.NET のグローバリゼーションの問題、ASP で直面する問題、ASP.NET 1x での状況の変化、グローバリゼーションの面での ASP.NET 2.0 の概要について説明します。注 理解できない用語がある場合は、この列の下部にある用語集のセクションを参照してください。

ASP でのグローバリゼーションの問題

ASP.NET 以前は、グローバル ユーザー向けのアプリケーションの開発に対する構造化されたサポートはありませんでした。 ASP の初期の開発では、私のような開発者は、オペレーティング システム、ブラウザー、ASP、バックエンド システムでのグローバリゼーションのサポートが散らばっていました。 ただし、これらのアプリケーション全体で自動接続を確認することはめったにありません。 幸いなことに、文字セット、コード ページ、ブラウザー言語、フォントなどの概念を理解しました。この概念は、グローバル ユーザー向けのアプリケーションの開発に活用できます。ASP.NET のグローバリゼーションの問題をすべてカテゴリに分けるのは難しすぎます。 代わりに、これらのさまざまな問題に関連する一連の概念を一覧表示します。

文字セットとコードページ

コンピューターの画面の文字は、一連のバイトだけであることがわかります。 バイト系列は、任意の数の方法で作成および解釈できます。 解釈でバイト配列が作成されたエンコーディングとは異なるエンコーディングを使用する場合、解釈はガベージとして表示されます。 文字セット (文字セット) は、通常ブラウザーで使用されるエンコード形式です。 サーバー側の変換に適した Codepage プロパティは、文字のエンコード方法を指定する変換テーブルにすぎません。ブラウザーは、現在の文字セットに従ってフォームの投稿データをエンコードします。 現在の文字セットが "windows-1256" の場合、サーバーへのバイト転送も "windows-1256" としてエンコードされます。 ASP が解釈されている場合、Form コレクションと Querystring コレクションは、コードで参照されるまでビルドされません。 それらがビルドされると、現在のコード ページに従って文字列データが Unicode に変換されます。 (既定では、ASP と ASP.NET の両方が Unicode 形式を使用してコンテンツを処理します)。 コレクションを参照する前に正しいコード ページを設定することが非常に重要です。そうしないと、メモリ内の Unicode 表現が正しくなくなります。コード ページを設定するには、Session.Codepage または Response.Codepage を使用します。 Response.Codepage は、Microsoft インターネット インフォメーション サービス (IIS) 5.1 以降のバージョンでのみ使用できます。 これらのプロパティを に設定する整数値 (文字セットに対応する) については、次の Microsoft Web サイトを参照してください。

文字セット認識http://msdn2.microsoft.com/en-us/library/Aa752010.aspxたとえば、アラビア語のコード ページを設定するには、次のコードを使用します。

Session.Codepage = 1256

Response.Codepage は現在の応答にのみ影響します。 ただし、Session.Codepage は、現在のユーザーによって行われたすべての応答に影響します。 これらのプロパティのいずれかを使用してコード ページを設定し、Form コレクションと Querystring コレクションをビルドすると、現在のコード ページのこの変更により、Response.Write メソッドはメモリ内の Unicode を現在のコード ページに変換します。 このトピックの詳細については、次の MSDN Web サイトを参照してください。

文字列変換 (ASP) のコード ページの設定 http://msdn2.microsoft.com/en-us/library/ms525789.aspx文字セットとコードページに関連する問題に関する要点は、クライアントの文字セットとサーバーのコードページが一致する必要があるということです。

言語を受け入れる

ASP 開発者がユーザーがブラウザーで設定した言語を知りたい場合、開発者は Request.ServerVariables ("HTTP_ACCEPT_LANGUAGE") 変数を使用して、ユーザーが応答を読み取る言語の一覧 (英語、ドイツ語、インドなど) と、ユーザーがこれらの言語を表示する優先順位を見つけることができます。 ASP.NET では、同様の情報が Request.UserLanguages プロパティに配列として存在します。ASP コードでこの情報を使用する方法の詳細については、次の記事番号をクリックして、Microsoft サポート技術情報の記事を表示してください。

229690 ブラウザーの言語設定に従って ASP ロケール ID を設定する方法  

インターネット エクスプローラーでのマルチバイト文字セットの表示

マルチバイト文字セットを表示できるエンコード形式は Unicode (UTF-8) のみです。 UTF-8 では、キリル文字、インド文字、日本語をすべて同じページに表示できます。 UTF-8 を使用しない場合は、一度に表示できる言語は 1 つだけです。 ブラウザーの文字セットを設定するには、Response.CharSet プロパティを使用します。

ページ上の静的マルチバイト文字

ページに直接格納されているマルチバイト文字を表示するには、最初に特定のエンコードでページを保存する必要があります。 UTF-8 が最適ですが、特定のコード ページ (文字のコード ページと一致) も機能します。Microsoft Visual InterDev を使用して ASP ファイルを保存しても、Visual InterDev は ANSI 英語または Unicode でのみ保存できるため、ここでは役に立ちません。 Unicode として保存された ASP ページは、ASP ではサポートされていません。Microsoft Visual Studio .NET では、任意のエンコードでファイルを保存できます。 これを行うには、2 つの方法があります。 既定の方法では、ユーザーの現在のコード ページを使用してファイルを保存します。 エンコードを使用してファイルを保存する追加の方法は次のとおりです。 [ ファイル ] メニューの [ 名前を付けてファイルを保存] をクリックします。 [ファイルを名前を付けて保存] ダイアログ ボックスで、[保存] ボタンのドロップダウン矢印をクリックします。 矢印をクリックすると、オプションは[エンコードで保存 および 保存] になります。 [エンコードで保存] をクリックすると、[詳細な保存オプション] ダイアログ ボックスが表示され、コンピューターにインストールされているコード ページの一覧から適用するエンコードの種類を選択できます。注 保存操作のエンコードは変更されますが、1 回限りです。 次の保存は既定値に戻されます。既定のコード ページを変更するには、[ファイル] メニューの [詳細な保存オプション] をクリックします。 [ 詳細な保存オプション] ダイアログ ボックスで、保存操作の既定のエンコードを任意のコード ページに設定できます。これらの方法は、ファイルをディスクに保存する方法に関連しています。 ただし、既に説明したように ASP の出力を制御するには、Session.CodePage プロパティと Response.CharSet プロパティを設定する必要があります。 IIS 5.1 以降のバージョンでは、Response.CodePage プロパティを使用することもできます。

サーバー上の既定の CODEPAGE

ページの既定のロケールと既定のコード ページは、 のレジストリ設定によって異なります。DEFAULT ユーザー。 国際キーは、レジストリ hive HKEY_USERS\.DEFAULT\Control Panel\Internationalにあります。 また、IIS によって選択されたロケールの動作を変更することもできます。ログオンしたユーザーに上記のキーまたはシステムの既定値と同じロケールが設定されている場合は、ユーザー設定が優先されます。例: 既定のロケールの日付形式は 11.1.2004 に設定されていますが、ログオンしているユーザー (同じロケール セット) の日付形式は 2004 年 11 月 1 日です。 2004 年 11 月 1 日の設定は、ASP に対して有効になります。(ASP.NET の場合、これは異なる場合があります。 一部のインストールでは、ASPNET ユーザーは、読み込まれたときにHKEY_USERSの下に表示される独自のプロファイルを持っています。 それ以外の場合は、 を使用します。DEFAULT プロファイル。 <%@ %> 宣言で codepage 属性を使用することもできます。 これは、ファイルが別のエンコードで保存され、コードページ 932 (日本語) などの既定値で保存される場合に使用する必要があります。

コードページの問題とフォント変換の問題: どれがどれですか?

疑問符 (?) 文字や、文字が表示されるボックスが表示されることがあります。

コードページ変換の問題

文字が疑問符 (?) 文字に置き換えられると、これはコードページ変換の問題が発生したことを示しています。 疑問符 (?) は、コード ページ変換の既定の文字であり、基本的には、オペレーティング システムが文字値を処理して変換する方法がわからないことを意味します。 文字の値を疑問符 (?) に置き換えます。 これは、文字がコード ページに無効な値を持っているか、変換に必要なコード ページがインストールされていないことを意味する可能性があります。

フォント変換に関する問題

文字がボックスに置き換えられると、フォント変換の問題が発生したことを示します。 これは、クライアント側で、この文字を正しく表示するための正しいフォントがインストールされていない場合に発生します。 たとえば、文字が日本語文字セットの文字で、クライアントに日本語フォントがインストールされていない場合、日本語文字はボックスとして表示されます。次に、ASP.NET 1.x で状況がどのように変化したか、およびそれらの変化が ASP.NET のコンテキストにおけるグローバリゼーションの問題にどのような影響を与えるかについて説明します。

ASP.NET 1.x でのグローバリゼーションの問題:

ASP.NET では、次の 3 つの優れたことが導入されました。

  • web.config ファイルの <グローバリゼーション> タグ <グローバリゼーション> タグは、コードページと文字セットの一貫性の高い概念から離れ、ASP.NET 内のほとんどのバリアントを制御できます。

  • System.Globalization 名前空間 グローバリゼーション名前空間は、グローバリゼーションを処理するプログラムの機能を提供します。

  • リソース ファイルの概念が大幅に改善されました。ASP では、以前と同様にリソース ファイルを処理しません。 リソース ファイルは、設計および開発時に XML ファイルの形式になり、実行時にアセンブリとして存在します。

グローバリゼーション構成タグ: タグの 2 つの重要な設定は次のとおりです。

<globalization 
            requestEncoding="utf-8" 
            responseEncoding="utf-8"  />

その他の設定領域は次のとおりです。

fileEncoding

.aspx、.asmx、および .asax ファイル解析の既定のエンコードを指定します。 バイト オーダー マーク プレフィックス (署名付き) で保存された Unicode ファイルと UTF-8 ファイルは、fileEncoding の値に関係なく自動的に認識されます。

文化

受信 Web 要求を処理するための既定のカルチャを指定します (System.Globalization 名前空間のクラスのメソッドに適用されます)。

uiCulture

ロケール依存のリソース検索 (サテライト アセンブリ) を処理するための既定のカルチャを指定します。

カルチャ文字列 (カルチャと uiculture の値) の詳細については、次の Microsoft Web サイトを参照してください。

System.Globalization.CultureInfoClasshttp://msdn2.microsoft.com/en-us/library/system.globalization.cultureinfo(vs.71).aspxこれらの設定は、応答が完了した後、および要求がアプリケーションに渡される前に、ASP.NET によって適用されます。 responseEncoding の場合、出力を格納するために作成されたバッファーがこのエンコードに設定されます。 このバッファーに入るすべてのものは、バッファーに挿入されるときに設定に従ってエンコードされます。requestEncoding の場合、ランタイムは要求を読み取り、このセクションの設定に従って解釈します。 ただし、これは問題を引き起こす可能性のある設定です。 次の表は、有効な UTF-8 バイト シーケンスのビット レイアウトを示しています。文字値が ASCII 7 ビット標準に収まる場合、バイト値は変更されません。 値が 127 より上の場合は、次の規則に従う必要があります。 先頭のビット セットは、シーケンス内の文字数を示します。 最初のビットの後の各バイトは、最初のビットを 1 に設定して開始する必要があります。UTF-8 バイト レイアウト:

バイト

ビット

表現

1

7

0vvvvvv

2

11

110vvvvvv 10vvvvv

3

16

1110vvvvv 10vvvvvv 10vvvvv

4

21

11110vvvv 10vvvvvv 10vvvvvv 10vvvvv

ここで問題が発生します。 ブラウザーが 1 バイトエンコード (iso-8859-1 など) に従って要求をエンコードする場合、127 を超える値は上記のレイアウトに従って有効になりません。 UTF-8 バッファーに読み込まれると、無効な文字は出力から削除されます。

ランタイム エンコードの変更

Application_BeginRequest イベントでは、requestEncoding の値を変更し、要求が処理される前に有効にすることができます。 応答の場合、Page_PreRender イベントは、出力のエンコードを変更する最後の機会です。 また、Response.Write は、呼び出すとすぐにこのバッファーに文字を格納するため、Response.Write を使用する前に適切なエンコードが設定されていることを確認してください。

元のデータが Unicode 以外の場合: インターネットエクスプローラーマルチバイト文字セットを解釈する方法

また、必要に応じて、ASP.NET を ASP のように動作させることもできます。 これを行うには、responseEncoding と requestEncoding を windows-1252 (iso-8859-1 よりも完全なエンコード) に設定し、Response.Charset プロパティを使用してテキストを正しく表示する必要があります。 これは、windows-1252 が 1 バイトのエンコード スキームであり、バッファーに追加されたバイトを変更しないために機能します。 したがって、2 バイト文字は一連の単一バイトとして送信されます。 その後、Response.Charset プロパティを使用して、バイトを解釈する方法をエクスプローラーインターネットに伝えることができます。 このシナリオは、COM オブジェクトからの戻り値など、元のデータが Unicode または UTF-8 として格納されていない場合、またはデータが非 N フィールド (varchar など) に Microsoft SQL Serverに格納されている場合に必要になる場合があります。

グローバリゼーションの問題のSQL Serverと ASP.NET

SQL Serverへの Unicode データ入力

SQL Serverにデータを格納する最善の方法は、Unicode を利用することです。 INSERT、UPDATE などを使用する場合、Unicode データの可能性が最も低い場合は、値の前に N を追加する必要があります。 これにより、値が Unicode であることをデータベースに通知します。 その良い例として、ADO オブジェクトがあります。 Recordset オブジェクトを使用して新しいレコードを追加する場合、自動的にこれを行います。次に例を示します。

INSERT INTO MusicAlbum (Album_ID, [Year], Name, Artist_ID, Company_ID) VALUES (12345, 2005, N'Abida', 4653, 403)
Or:
Dim t As String = "INSERT INTO MusicAlbum(Album_ID, [Year], Name, Artist_ID, Company_ID) VALUES (12345, 2005, N'" & TextBox1.Text & "', 4653, 403)"
SQL Serverへの日付/時刻入力

通常、ASP.NET アプリケーション内で解釈される日付/時刻のカルチャとロケールに関する知識があります。 ただし、外部ソースとの間で日付/時刻データをプッシュおよびプルする際に、日付/時刻形式を誤って解釈するリスクが発生します。 これは、外部ソースのカルチャとロケールがアプリケーションと同じであることを常に保証できないためです。 SQL Serverでは、SQL データベースに対して確立されている接続の connectionstring で 'current language' 属性を使用することで解決できます。 接続文字列には、アプリケーションのカルチャと同じ言語設定を指定できます。 SQL Serverは常に上記の設定に同意して日付/時刻データを受け入れて送信するため、誤解のリスクから保護されます。

System.Globalization 名前空間

この名前空間は、.NET Frameworkのグローバリゼーションとローカライズの中核です。 この名前空間で使用されるメイン クラスは CultureInfo クラスです。 日付/時刻形式、数値形式、比較情報、テキスト情報など、カルチャ固有の情報が保持されます。 CultureInfo クラスの詳細については、次の MSDN Web サイトを参照してください。

http://msdn2.microsoft.com/en-us/library/system.globalization.cultureinfo(vs.71).aspxCultureInfo

ニュートラル カルチャと特定のカルチャ

ニュートラル カルチャは、言語に関連付けられているが、特定の国/地域には関連付けられていないカルチャです。 特定のカルチャは、言語と特定の国/地域の両方に関連付けられています。例: "DE" (ニュートラル カルチャ) はドイツ語用ですが、"de-AT" (特定のカルチャ) は、オーストリアで話されているドイツ語用です。 ニュートラル カルチャを書式設定に使用することはできません。

.NET Framework クラスの現在のスレッドとカルチャの認識

出力がカルチャに依存すると予想される.NET Framework ライブラリ内のすべてのクラスとメソッドには、次の 2 つの組み込み動作があります。

  • 引数を指定しながらカルチャ コードを指定し、出力が指定されたカルチャに基づくようにします。 これは省略可能です。

  • これが見逃された場合 (通常はです)、クラスは Thread.CurrentThread.CurrentCulture プロパティにチェックを保持し、それに従って動作するのに十分なインテリジェントです。

このプロパティの値は、次のようなコードで変更できます。

    Dim ci As CultureInfo
        ci = New CultureInfo("de-AT")
        Thread.CurrentThread.CurrentCulture = ci

このコード例では、"de" はドイツ語を表し、"AT" はオーストリアを表します。 そのため、このインスタンスでは DateTime.Now() です。ToString メソッドは、オーストリアのドイツ語で日付と時刻を表現する方法に対応する形式で日付と時刻を返します。フレームワークでは、CurrentCulture プロパティが常に初期化されることが (次のように) 保証されます。

  1. プログラムによって に設定されているもの。

  2. プログラマによって明示的に設定されていない場合、プロパティは構成ファイル (<グローバリゼーション> タグ) から選択されます。

  3. プロパティが存在しない場合は、Web サーバーが実行されているカルチャです。 これは通常、オペレーティング システムの言語に対応するニュートラル カルチャです。

リソース ファイル

ビルド アクション属性が Visual Studio .NET の ASP.NET プロジェクトに追加された埋め込みリソースに設定されているすべての .resx、.resource ファイル、およびファイルは、マニフェストの一部として自動的にコンパイルされ、アプリケーション アセンブリ内に埋め込まれます。 これは、Visual Studio .NET コマンド プロンプトを使用してリソース ファイル ジェネレーター (RESGEN) ユーティリティを使用して手動で実行することもできます。 詳細については、次の MSDN Web サイトを参照してください。

http://msdn2.microsoft.com/en-us/library/ccec7sz1(vs.71).aspxこれは、グローバリゼーションとは無関係のアプリケーション リソースを管理する必要があるときに適用される一般的な概念です。 ただし、グローバリゼーションを実装する場合は、サテライト アセンブリを使用する必要があります。

サテライト アセンブリ

サテライト アセンブリは、次のことが当てはまることを確認するときに、ASP.NET プロジェクトで使用できます。

  1. すべての aspx ファイル内のすべてのユーザー インターフェイス要素には、id 属性と runat=server 属性を装備する必要があります。

  2. 個別の .resx ファイルを作成します。 各カルチャは、アプリケーションでサポートする各カルチャに対応している必要があります。

  3. これらのファイルすべてに共通の名を決定する必要があります。 'Strings'。

  4. 別の .resx ファイルには、次の名前付け規則 commonfirstname という名前を付けます。languagecode-regioncode.resx (例: Strings.de-AT.resx、Strings.en-GB.resx)。

  5. 既定のケースで表示するすべての文字列を含むリソース ファイルcommonfirstname.resx (Strings.resx) が必要です。

  6. ユーザーのカルチャを検出するコードを記述し、それに一致するように Thread.CurrentThread.CurrentUICulture プロパティを設定します。

  7. ResourceManager クラスを使用してリソースを読み込むコードを記述します。

  8. 読み込まれたオブジェクトから文字列を抽出し、ユーザー インターフェイス要素に割り当てるコードを記述します。

これらの手順を実行すると、Visual Studio.NET は Strings.resx をコンパイルし、それをアプリケーション アセンブリ (MyGlobalizationTestProjectName.dll) に埋め込みます。 ただし、他のすべての .resx ファイルでは、実行可能コードを持たないリソース データのみを含む個別の dll ファイルが生成されます。 これらは実際にはサテライト アセンブリと呼ばれます。 また、Visual Studio .NET では、次のようなフォルダー構造にこれらを配置します:MyGlobalizationTestProjectName |------- bin |------en-USMyGlobalizationTestProjectName.resources.dll |------ja-JPMyGlobalizationTestProjectName.resources.dll |------de-AT MyGlobalizationTestProjectName.resources.dll

CurrentCulture と CurrentUICulture の違い

System.Globalization 名前空間のクラスのメソッドは Thread.CurrentThread.CurrentCulture プロパティに依存して出力を提供しますが、リソース アセンブリを読み込む ResourceManager クラスは、適切なサテライト アセンブリを読み込む Thread.CurrentThread.CurrentUICulture プロパティによって異なります。 C# コードの例を次に示します。

using System.Globalization;
using System.Threading;
using System.Resources;

//Load resources. 
protected ResourceManager gStrings = new ResourceManager("MyGlobalizationTestProjectName.strings", typeof(MyTestWebFormName).Assembly);

// Get the user's preferred language.
string sLang = Request.UserLanguages[0];
// Set the thread's culture for formatting, comparisons, etc.   
Thread.CurrentThread.CurrentCulture =  CultureInfo.CreateSpecificCulture(sLang);
// Set the thread's UICulture to load resources
// from satellite assembly.
Thread.CurrentThread.CurrentUICulture = new CultureInfo(sLang);

private void Page_Load(object sender, System.EventArgs e) 

{ 

 if (!IsPostBack)  

 {      
// Get strings from resource file and assign to UI elements.
head1.InnerHtml = gStrings.GetString("satellite.head1");
p1.InnerHtml = gStrings.GetString("satellite.p1");
sp1.InnerHtml = gStrings.GetString("satellite.sp1");
sp2.InnerHtml = gStrings.GetString("satellite.sp2");
butOK.Text = gStrings.GetString("satellite.butOK");
butCancel.Value = gStrings.GetString("satellite.butCancel");
   }

 }

ASP.NET がサテライト アセンブリを選択する順序:

スレッドの CurrentUICulture を設定すると、ASP.NET は一致するリソースを次の順序で自動的に選択します。

  • 一致するカルチャでサテライト アセンブリが見つかった場合は、そのアセンブリのリソースが使用されます。

  • CurrentUICulture に一致するニュートラル カルチャを持つサテライト アセンブリが見つかった場合、そのアセンブリのリソースが使用されます。

  • CurrentUICulture に一致するものが見つからない場合は、実行可能アセンブリに格納されているフォールバック リソースが使用されます。

注 これは、より一般的なリソース フォールバック プロセスに基づいています。 詳細については、次の MSDN Web サイトを参照してください。

http://msdn2.microsoft.com/en-us/library/sb6a8618(vs.71).aspx

サテライト アセンブリを手動で作成する:

このサテライト アセンブリの使用は、Visual Studio .NET によってアセンブリ自体が作成される場所です。 ただし、Visual Studio .NET では、既定ではサテライト アセンブリに厳密な名前は付けられません。 これらのオプションを変更する場合は、サテライト アセンブリを手動で作成する必要があります。 詳細については、次の MSDN Web サイトを参照してください。

http://msdn2.microsoft.com/en-us/library/21a15yht(vs.71).aspx .

グローバリゼーションの面で ASP.NET 2.0 はどうなっていますか?

ASP.NET の広範な使用と、ASP.NET 2.0 のグローバリゼーション機能に関して発生する問題の種類は、まだ少し先にあります。 ただし、グローバリゼーション手法が Web アプリケーションに向かう方向を簡単に見てみると良いでしょう。ASP.NET 2.0 でのグローバリゼーション のサポートは根本的な変更を受け、Web 開発者には、Windows ベースのアプリケーションと同じくらい簡単に Web アプリケーションのローカライズを行う機能が与えられました。 ASP.NET 2.0 のグローバリゼーション手法の基礎となる機能の一覧を次に示します。 厳密に型指定されたリソース .NET Framework 2.0 リリースの中核となるのは、開発者に Intellisense を提供し、実行時にリソースにアクセスするために必要なコードを簡略化する、厳密に型指定されたリソースのサポートです。マネージド リソース エディター Visual Studio .NET 2.0 には、文字列、イメージ、外部ファイル、その他の複合型などのリソース エントリの作成と管理をより適切にサポートする新しいリソース エディターが含まれています。Web Forms Windows フォーム開発者向けのリソース生成は、既に自動国際化の利点を享受しています。 Visual Studio .NET 2005 では、Web Forms、ユーザー コントロール、マスター ページのリソースを自動的に生成することで、迅速な国際化がサポートされるようになりました。改善されたランタイム サポート ResourceManager インスタンスはランタイムによって管理され、よりアクセシビリティの高いプログラミング インターフェイスを使用してサーバー コードに簡単にアクセスできます。ローカライズ式 Web ページのモダン宣言式では、プロパティ、HTML プロパティ、または静的コンテンツ領域を制御するためのリソース エントリのマッピングがサポートされています。 これらの式も拡張可能であり、ローカライズされたコンテンツを HTML 出力にアタッチするプロセスを制御する追加の方法を提供します。カルチャの自動選択 各 Web 要求のカルチャ選択を管理すると、ブラウザーの基本設定に自動的にリンクできます。リソース プロバイダー モデル 新しいリソース プロバイダー モデルを使用すると、開発者はフラット ファイルやデータベース テーブルなどの代替データ ソースでリソースをホストできます。一方、それらのリソースにアクセスするためのプログラミング モデルは一貫性を保ちます。ASP.NET 2.0 のグローバリゼーション手法の詳細については、次の MSDN Web サイトを参照してください。

ASP.NET 2.0 ローカライズ機能: Web アプリケーションのローカライズに関する新しいアプローチhttp://msdn2.microsoft.com/en-us/library/ms379546(VS.80).aspx

まとめ

ここでは、ASP と ASP.NET のグローバリゼーションの問題について説明します。 この記事は、ASP と ASP.NET のグローバリゼーションの問題を解決する前に、いくつかのお客様がMicrosoft サポートに連絡することを選択する前に役立つことを願っています。 私は次の考えで終わります: 「開発を進める場所や場所を問わず、世界中で力を発揮できる何百万人もの人々について考えてください。 ソリューションを世界に向けて準備しましょう。 Microsoft のツールとテクノロジにより、国際化が容易になります。 来月はまた、興味深いトピックで追いつく予定です。お時間をいただきありがとうございました。

ASP と ASP.NET のグローバリゼーションの問題の詳細については、次の Microsoft Web サイトを参照してください。

vbscripthttp://msdn2.microsoft.com/en-us/library/5xf99h19.aspx の SetLocale と GetLocale

グローバリゼーションのステップ バイ ステップhttp://msdn.microsoft.com/en-us/goglobal/bb688110

Go Global: IIS 5.0 と SQL Server を使用した動的Web Appsのローカライズ http://msdn.microsoft.com/msdnmag/issues/01/05/global/default.aspx

グローバル化: グローバリゼーションをサポートする ASP ベースの Web サイトを設計する http://msdn.microsoft.com/msdnmag/issues/0700/localize/default.aspx

315616 IIS http://support.microsoft.com/?id=315616 の [Active Server Pages] ページでクライアント言語を検出する方法

ロケール ID (LCID) グラフhttp://msdn2.microsoft.com/en-us/library/0h88fahh.aspx

System.Globalization 名前空間http://msdn2.microsoft.com/en-us/library/system.globalization(vs.71).aspx

.NET Framework SDKhttp://msdn2.microsoft.com/en-us/library/aa309421(VS.71).aspx を使用したリソースとローカライズ

ASP.NET アプリケーションのリソース http://msdn2.microsoft.com/en-us/library/1ztca10y(vs.71).aspx

ASP.NET <グローバリゼーション> 構成要素http://msdn2.microsoft.com/en-us/library/hy4kkhe0(vs.71).aspx

Web クライアントの設計と実装のガイドライン - グローバリゼーションとローカライズhttp://msdn2.microsoft.com/en-us/library/ms978628.aspx

Microsoft 公式サイト - グローバル開発およびコンピューティング ポータルhttp://msdn.microsoft.com/en-us/goglobal/bb688096

World-Ready Applicationshttp://msdn2.microsoft.com/en-us/library/h6270d0z(vs.71).aspx の開発

ASP.NEThttp://msdn2.microsoft.com/en-us/library/aa478974.aspx のグローバリゼーション アーキテクチャ

Enterprise Localiz Toolkit - ローカライズされた Microsoft ASP.NET アプリケーションを開発するための http://msdn2.microsoft.com/en-us/library/aa479334.aspx

Microsoft の文字体裁http://www.microsoft.com/typography/default.mspx

用語集

ANSI は、アメリカ国立標準研究所を意味します。 このコンテキストでは、特定の言語/文字セットの特定のコード ページを表します。 ほとんどの場合、英語のコードページ (windows-1252) を参照します。ASCII 1 バイト (または 7 ビット) エンコード スキーム。 0 から 127 の範囲の文字のみが標準化されています。 128 から 255 の範囲は ASCII の拡張機能であり、標準の一部ではありません。 この例は、OEM ASCII グラフの上限範囲と VB ASCII グラフの違いです。CharSet 設定は、主にインターネット エクスプローラーと、文字データの解釈方法をブラウザーに指示するブラウザーに使用されます。 例: Response.charSet = "iso-8859-1" Codepage 文字のエンコード方法を指定する変換テーブル (通常はサーバーに使用されます)。グローバリゼーショングローバリゼーションは、文化、地域、または国/地域や言語のニーズが満たされるようにアプリケーションを設計および作成するプロセスです。 つまり、後でローカライズできるようにアプリケーションを設計することはグローバリゼーションです。ロケール/カルチャ言語および地域固有の形式/好み (日付と予定表の形式、時刻形式、通貨形式、大文字と小文字の区別、並べ替え、文字列の比較、アドレス形式、電話番号形式、用紙サイズ、測定単位、書き込み方向など)。 LocaleID (LCID) 言語識別子と並べ替え ID を指定する DWORD 値。 これは、日付/時刻などに応じて書式設定する必要がある特定の地域の形式を指定するために使用できます。ローカライズ性 要求された言語/ロケールのコンテンツを表示するアプリケーションの機能。ローカリゼーションは、ユーザー インターフェイスを特定の言語やロケールに翻訳するプロセスです。マルチバイト文字セット 文字が日本語などの 2 バイト以上で構成される文字セット。 UTF-8 もこのカテゴリに該当します。 (Unicode は技術的にはこのカテゴリにありますが、Windows では独自のカテゴリがあります)。 Unicode 2 バイト エンコード スキーム。 Windows では、Unicode が内部的に使用されます。 Unicode 専用の API は、関数名の末尾に "W" で示されます。 ワイド文字とも呼ばれます。Web アプリケーションから直接使用することはできません。UTF-8 文字を 1 から 6 バイトで表すことができる文字エンコード。 Windows では、範囲は 1 から 3 バイトです。 WEB アプリケーションの NT4 ではサポートされていません。ワイド文字セット Unicode のエイリアス。 DBCS (2 バイト文字セット)、UCS-2、UTF-16 とも呼ばれます。

常に、将来の列またはナレッジ ベースで対処するトピックに関するアイデアを自由に送信するには、Ask For It フォームを使用してください。

ヘルプを表示

その他のオプションが必要ですか?

サブスクリプションの特典の参照、トレーニング コースの閲覧、デバイスのセキュリティ保護方法などについて説明します。