IdnMapping.UseStd3AsciiRules Właściwość
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Pobiera lub ustawia wartość wskazującą, czy standardowe lub zrelaksowane konwencje nazewnictwa są używane w operacjach wykonywanych przez elementy członkowskie bieżącego IdnMapping obiektu.
public:
property bool UseStd3AsciiRules { bool get(); void set(bool value); };
public bool UseStd3AsciiRules { get; set; }
member this.UseStd3AsciiRules : bool with get, set
Public Property UseStd3AsciiRules As Boolean
Wartość właściwości
true
jeśli standardowe konwencje nazewnictwa są używane w operacjach; w przeciwnym razie , false
.
Przykłady
Poniższy przykład generuje adresy URL zawierające znaki w zakresie od U+0000 do U+007F i przekazuje je do GetAscii(String) metody dwóch IdnMapping obiektów. Jeden obiekt ma właściwość UseStd3AsciiRules ustawioną na true
, a drugi obiekt ma ustawioną wartość false
. W danych wyjściowych są wyświetlane znaki, które są nieprawidłowe, gdy UseStd3AsciiRules właściwość jest true
prawidłowa, gdy jest false
to .
using System;
using System.Globalization;
public class Example
{
public static void Main()
{
int nFailed = 0;
IdnMapping idnStd = new IdnMapping();
idnStd.UseStd3AsciiRules = true;
IdnMapping idnRelaxed = new IdnMapping();
idnRelaxed.UseStd3AsciiRules = false; // The default, but make it explicit.
for (int ctr = 0; ctr <= 0x7F; ctr++) {
string name = $"Prose{ctr}ware.com";
bool stdFailed = false;
bool relaxedFailed = false;
string punyCode = "";
try {
punyCode = idnStd.GetAscii(name);
}
catch (ArgumentException) {
stdFailed = true;
}
try {
punyCode = idnRelaxed.GetAscii(name);
}
catch (ArgumentException) {
relaxedFailed = true;
}
if (relaxedFailed != stdFailed) {
Console.Write("U+{0:X4} ", ctr);
nFailed++;
if (nFailed % 5 == 0)
Console.WriteLine();
}
}
}
}
// The example displays the following output:
// U+0020 U+0021 U+0022 U+0023 U+0024
// U+0025 U+0026 U+0027 U+0028 U+0029
// U+002A U+002B U+002C U+002F U+003A
// U+003B U+003C U+003D U+003E U+003F
// U+0040 U+005B U+005C U+005D U+005E
// U+005F U+0060 U+007B U+007C U+007D
// U+007E
Imports System.Globalization
Module Example
Public Sub Main()
Dim nFailed As Integer = 0
Dim idnStd As New IdnMapping()
idnStd.UseStd3AsciiRules = True
Dim idnRelaxed As New IdnMapping
idnRelaxed.UseStd3AsciiRules = False ' The default, but make it explicit.
For ctr As Integer = 0 To &h7F
Dim name As String = "Prose" + ChrW(ctr) + "ware.com"
Dim stdFailed As Boolean = False
Dim relaxedFailed As Boolean = False
Dim punyCode As String
Try
punyCode = idnStd.GetAscii(name)
Catch e As ArgumentException
stdFailed = True
End Try
Try
punyCode = idnRelaxed.GetAscii(name)
Catch e As ArgumentException
relaxedFailed = True
End Try
If relaxedFailed <> stdFailed Then
Console.Write("U+{0:X4} ", ctr)
nFailed += 1
If nFailed Mod 5 = 0 Then Console.WriteLine()
End If
Next
End Sub
End Module
' The example displays the following output:
' U+0020 U+0021 U+0022 U+0023 U+0024
' U+0025 U+0026 U+0027 U+0028 U+0029
' U+002A U+002B U+002C U+002F U+003A
' U+003B U+003C U+003D U+003E U+003F
' U+0040 U+005B U+005C U+005D U+005E
' U+005F U+0060 U+007B U+007C U+007D
' U+007E
Uwagi
Nazwy domen zgodne ze standardowymi regułami nazewnictwa składają się z określonego podzestawu znaków w zakresie znaków US-ASCII. Znaki to litery od A do Z, cyfry od 0 do 9, znak łącznika (-) (U+002D) i znak kropki (.). Wielkość znaków nie jest znacząca. Złagodzone konwencje nazewnictwa umożliwiają użycie szerszego zakresu znaków ASCII, w tym znaku spacji (U+0020), wykrzyknika (U+0021) i znaku paska underbar (U+005F). Jeśli UseStd3AsciiRules jest to true
, tylko standardowe znaki mogą być wyświetlane w etykiecie zwróconej przez metodę GetAscii .
Domyślnie wartość UseStd3AsciiRules właściwości to false
, a rozszerzony podzestaw znaków ASCII jest dozwolony w etykiecie.
Uwaga
Klasa IdnMapping zakazuje używania niedisplayable znaków U+0000 do U+001F i U+007F w etykietach nazw domeny niezależnie od ustawienia UseStd3AsciiRules właściwości. Zakaz ten zmniejsza ryzyko ataków zabezpieczających, takich jak fałszowanie nazw.