Udostępnij za pośrednictwem


IdnMapping.UseStd3AsciiRules Właściwość

Definicja

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 falseto .

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.

Dotyczy