Uri Класс

Определение

Предоставляет представление объекта универсального идентификатора ресурса (URI) и простого доступа к частям URI.

public ref class Uri
public ref class Uri : IEquatable<Uri ^>, ISpanFormattable, System::Runtime::Serialization::ISerializable
public ref class Uri : System::Runtime::Serialization::ISerializable
public ref class Uri : ISpanFormattable, System::Runtime::Serialization::ISerializable
public ref class Uri : MarshalByRefObject, System::Runtime::Serialization::ISerializable
public class Uri
public class Uri : IEquatable<Uri>, ISpanFormattable, System.Runtime.Serialization.ISerializable
public class Uri : System.Runtime.Serialization.ISerializable
public class Uri : ISpanFormattable, System.Runtime.Serialization.ISerializable
[System.Serializable]
public class Uri : MarshalByRefObject, System.Runtime.Serialization.ISerializable
[System.Serializable]
[System.ComponentModel.TypeConverter(typeof(System.UriTypeConverter))]
public class Uri : System.Runtime.Serialization.ISerializable
type Uri = class
type Uri = class
    interface IEquatable<Uri>
    interface IFormattable
    interface ISpanFormattable
    interface ISerializable
type Uri = class
    interface ISerializable
type Uri = class
    interface ISpanFormattable
    interface IFormattable
    interface ISerializable
type Uri = class
    interface IFormattable
    interface ISpanFormattable
    interface IEquatable<Uri>
    interface ISerializable
[<System.Serializable>]
type Uri = class
    inherit MarshalByRefObject
    interface ISerializable
[<System.Serializable>]
[<System.ComponentModel.TypeConverter(typeof(System.UriTypeConverter))>]
type Uri = class
    interface ISerializable
Public Class Uri
Public Class Uri
Implements IEquatable(Of Uri), ISerializable, ISpanFormattable
Public Class Uri
Implements ISerializable
Public Class Uri
Implements ISerializable, ISpanFormattable
Public Class Uri
Inherits MarshalByRefObject
Implements ISerializable
Наследование
Uri
Наследование
Атрибуты
Реализации

Примеры

В следующем примере создается экземпляр Uri класса и он используется для выполнения запроса GET с HttpClientпомощью .

Uri siteUri = new Uri("http://www.contoso.com/");

// HttpClient lifecycle management best practices:
// https://learn.microsoft.com/dotnet/fundamentals/networking/http/httpclient-guidelines#recommended-use
HttpClient client = new HttpClient();
HttpRequestMessage request = new HttpRequestMessage(HttpMethod.Get, siteUri);
HttpResponseMessage response = client.Send(request);
let siteUri = Uri "http://www.contoso.com/"

// HttpClient lifecycle management best practices:
// https://learn.microsoft.com/dotnet/fundamentals/networking/http/httpclient-guidelines#recommended-use
use client = new HttpClient ()
use request = new HttpRequestMessage (HttpMethod.Get, siteUri)
use response = client.Send request
Dim siteUri As New Uri("http://www.contoso.com/")

' HttpClient lifecycle management best practices:
' https://learn.microsoft.com/dotnet/fundamentals/networking/http/httpclient-guidelines#recommended-use
Dim client As New HttpClient()
Dim request As New HttpRequestMessage(HttpMethod.Get, siteUri)
Dim response As HttpResponseMessage = client.Send(request)

В следующем фрагменте кода показаны примеры значений различных свойств класса.

Uri uri = new Uri("https://user:password@www.contoso.com:80/Home/Index.htm?q1=v1&q2=v2#FragmentName");

Console.WriteLine($"AbsolutePath: {uri.AbsolutePath}");
Console.WriteLine($"AbsoluteUri: {uri.AbsoluteUri}");
Console.WriteLine($"DnsSafeHost: {uri.DnsSafeHost}");
Console.WriteLine($"Fragment: {uri.Fragment}");
Console.WriteLine($"Host: {uri.Host}");
Console.WriteLine($"HostNameType: {uri.HostNameType}");
Console.WriteLine($"IdnHost: {uri.IdnHost}");
Console.WriteLine($"IsAbsoluteUri: {uri.IsAbsoluteUri}");
Console.WriteLine($"IsDefaultPort: {uri.IsDefaultPort}");
Console.WriteLine($"IsFile: {uri.IsFile}");
Console.WriteLine($"IsLoopback: {uri.IsLoopback}");
Console.WriteLine($"IsUnc: {uri.IsUnc}");
Console.WriteLine($"LocalPath: {uri.LocalPath}");
Console.WriteLine($"OriginalString: {uri.OriginalString}");
Console.WriteLine($"PathAndQuery: {uri.PathAndQuery}");
Console.WriteLine($"Port: {uri.Port}");
Console.WriteLine($"Query: {uri.Query}");
Console.WriteLine($"Scheme: {uri.Scheme}");
Console.WriteLine($"Segments: {string.Join(", ", uri.Segments)}");
Console.WriteLine($"UserEscaped: {uri.UserEscaped}");
Console.WriteLine($"UserInfo: {uri.UserInfo}");

// AbsolutePath: /Home/Index.htm
// AbsoluteUri: https://user:password@www.contoso.com:80/Home/Index.htm?q1=v1&q2=v2#FragmentName
// DnsSafeHost: www.contoso.com
// Fragment: #FragmentName
// Host: www.contoso.com
// HostNameType: Dns
// IdnHost: www.contoso.com
// IsAbsoluteUri: True
// IsDefaultPort: False
// IsFile: False
// IsLoopback: False
// IsUnc: False
// LocalPath: /Home/Index.htm
// OriginalString: https://user:password@www.contoso.com:80/Home/Index.htm?q1=v1&q2=v2#FragmentName
// PathAndQuery: /Home/Index.htm?q1=v1&q2=v2
// Port: 80
// Query: ?q1=v1&q2=v2
// Scheme: https
// Segments: /, Home/, Index.htm
// UserEscaped: False
// UserInfo: user:password
let uri = Uri "https://user:password@www.contoso.com:80/Home/Index.htm?q1=v1&q2=v2#FragmentName"

printfn $"AbsolutePath: {uri.AbsolutePath}"
printfn $"AbsoluteUri: {uri.AbsoluteUri}"
printfn $"DnsSafeHost: {uri.DnsSafeHost}"
printfn $"Fragment: {uri.Fragment}"
printfn $"Host: {uri.Host}"
printfn $"HostNameType: {uri.HostNameType}"
printfn $"IdnHost: {uri.IdnHost}"
printfn $"IsAbsoluteUri: {uri.IsAbsoluteUri}"
printfn $"IsDefaultPort: {uri.IsDefaultPort}"
printfn $"IsFile: {uri.IsFile}"
printfn $"IsLoopback: {uri.IsLoopback}"
printfn $"IsUnc: {uri.IsUnc}"
printfn $"LocalPath: {uri.LocalPath}"
printfn $"OriginalString: {uri.OriginalString}"
printfn $"PathAndQuery: {uri.PathAndQuery}"
printfn $"Port: {uri.Port}"
printfn $"Query: {uri.Query}"
printfn $"Scheme: {uri.Scheme}"
printfn $"""Segments: {String.Join(", ", uri.Segments)}"""
printfn $"UserEscaped: {uri.UserEscaped}"
printfn $"UserInfo: {uri.UserInfo}"

// AbsolutePath: /Home/Index.htm
// AbsoluteUri: https://user:password@www.contoso.com:80/Home/Index.htm?q1=v1&q2=v2#FragmentName
// DnsSafeHost: www.contoso.com
// Fragment: #FragmentName
// Host: www.contoso.com
// HostNameType: Dns
// IdnHost: www.contoso.com
// IsAbsoluteUri: True
// IsDefaultPort: False
// IsFile: False
// IsLoopback: False
// IsUnc: False
// LocalPath: /Home/Index.htm
// OriginalString: https://user:password@www.contoso.com:80/Home/Index.htm?q1=v1&q2=v2#FragmentName
// PathAndQuery: /Home/Index.htm?q1=v1&q2=v2
// Port: 80
// Query: ?q1=v1&q2=v2
// Scheme: https
// Segments: /, Home/, Index.htm
// UserEscaped: False
// UserInfo: user:password

Комментарии

Дополнительные сведения об этом API см. в дополнительных примечаниях API для URI.

Конструкторы

Имя Описание
Uri(SerializationInfo, StreamingContext)
Устаревшие..

Инициализирует новый экземпляр Uri класса из указанных экземпляров SerializationInfo и StreamingContext классов.

Uri(String, Boolean)
Устаревшие..
Устаревшие..
Устаревшие..
Устаревшие..

Инициализирует новый экземпляр Uri класса с указанным универсальным кодом ресурса (URI) с явным контролем экранирования символов.

Uri(String, UriCreationOptions)

Инициализирует новый экземпляр Uri класса с указанным универсальным кодом ресурса (URI) и дополнительным UriCreationOptions.

Uri(String, UriKind)

Инициализирует новый экземпляр Uri класса с указанным универсальным кодом ресурса (URI). Этот конструктор позволяет указать, является ли строка URI относительной URI, абсолютным универсальным кодом ресурса (URI) или неопределенной.

Uri(String)

Инициализирует новый экземпляр Uri класса с указанным универсальным кодом ресурса (URI).

Uri(Uri, String, Boolean)
Устаревшие..
Устаревшие..
Устаревшие..
Устаревшие..

Инициализирует новый экземпляр класса на основе указанных базовых Uri и относительных URI с явным контролем экранирования символов.

Uri(Uri, String)

Инициализирует новый экземпляр класса на основе указанного Uri базового URI и относительной строки URI.

Uri(Uri, Uri)

Инициализирует новый экземпляр класса на основе сочетания указанного базового Uri экземпляра Uri и относительного Uri экземпляра.

Поля

Имя Описание
SchemeDelimiter

Задает символы, разделяющие схему протокола связи от части адреса URI. Это поле может использоваться только для чтения.

UriSchemeData

Предоставляет представление объекта универсального идентификатора ресурса (URI) и простого доступа к частям URI.

UriSchemeFile

Указывает, что универсальный код ресурса (URI) является указателем на файл. Это поле может использоваться только для чтения.

UriSchemeFtp

Указывает, что URI осуществляется через ПРОТОКОЛ передачи файлов (FTP). Это поле может использоваться только для чтения.

UriSchemeFtps

Указывает, что URI осуществляется через протокол FTPS. Это поле может использоваться только для чтения.

UriSchemeGopher

Указывает, что URI осуществляется через протокол Gopher. Это поле может использоваться только для чтения.

UriSchemeHttp

Указывает, что URI осуществляется через протокол HTTP. Это поле может использоваться только для чтения.

UriSchemeHttps

Указывает, что URI осуществляется через протокол HTTPS. Это поле может использоваться только для чтения.

UriSchemeMailto

Указывает, что универсальный код ресурса (URI) является адресом электронной почты и осуществляется через протокол SMTP. Это поле может использоваться только для чтения.

UriSchemeNetPipe

Указывает, что URI осуществляется через схему NetPipe, используемую Windows Communication Foundation (WCF). Это поле может использоваться только для чтения.

UriSchemeNetTcp

Указывает, что URI осуществляется через схему NetTcp, используемую Windows Communication Foundation (WCF). Это поле может использоваться только для чтения.

UriSchemeNews

Указывает, что универсальный код ресурса (URI) — это группа новостей Интернета, доступ к которому осуществляется через протокол NNTP. Это поле может использоваться только для чтения.

UriSchemeNntp

Указывает, что универсальный код ресурса (URI) — это группа новостей Интернета, доступ к которому осуществляется через протокол NNTP. Это поле может использоваться только для чтения.

UriSchemeSftp

Указывает, что URI осуществляется через протокол SSH-передачи файлов (SFTP). Это поле может использоваться только для чтения.

UriSchemeSsh

Указывает, что URI осуществляется через протокол Secure Socket Shell (SSH). Это поле может использоваться только для чтения.

UriSchemeTelnet

Указывает, что URI осуществляется через протокол Telnet. Это поле может использоваться только для чтения.

UriSchemeWs

Указывает, что URI осуществляется через протокол WebSocket (WS). Это поле может использоваться только для чтения.

UriSchemeWss

Указывает, что URI осуществляется через протокол WebSocket Secure (WSS). Это поле может использоваться только для чтения.

Свойства

Имя Описание
AbsolutePath

Возвращает абсолютный путь URI.

AbsoluteUri

Возвращает абсолютный универсальный код ресурса (URI).

Authority

Возвращает имя узла или IP-адрес системы доменных имен (DNS) и номер порта для сервера.

DnsSafeHost

Возвращает имя узла, которое после того, как не было отложено при необходимости, безопасно использовать для разрешения DNS.

Fragment

Возвращает escape-фрагмент URI, включая ведущий символ #, если он не пуст.

Host

Возвращает узел этого экземпляра.

HostNameType

Возвращает тип имени узла, указанного в URI.

IdnHost

Возвращает международное доменное имя узла RFC 3490, используя Punycode соответствующим образом. Эта строка после того, как не будет отключена при необходимости, безопасно использовать для разрешения DNS.

IsAbsoluteUri

Возвращает значение, указывающее, является ли Uri экземпляр абсолютным.

IsDefaultPort

Возвращает значение, указывающее, является ли значение порта URI по умолчанию для этой схемы.

IsFile

Возвращает значение, указывающее, является ли указанный Uri универсальный код ресурса (URI) файла.

IsLoopback

Возвращает значение, указывающее, ссылается ли указанный Uri узел на локальный узел.

IsUnc

Возвращает значение, указывающее, является ли указанный Uri путь универсальным соглашением об именовании (UNC).

LocalPath

Возвращает локальное представление имени файла операционной системы.

OriginalString

Возвращает исходную строку URI, переданную конструктору Uri .

PathAndQuery

AbsolutePath Возвращает свойства, Query разделенные вопросительным знаком (?).

Port

Возвращает номер порта этого URI.

Query

Получает все сведения о запросе, включенные в указанный URI, включая ведущий символ "?", если не пуст.

Scheme

Возвращает имя схемы для этого URI.

Segments

Возвращает массив, содержащий сегменты пути, составляющие указанный универсальный код ресурса (URI).

UserEscaped

Возвращает значение, указывающее, была ли строка URI полностью экранирована до создания экземпляра Uri .

UserInfo

Возвращает имя пользователя, пароль или другие сведения, связанные с указанным универсальным кодом ресурса (URI).

Методы

Имя Описание
Canonicalize()
Устаревшие..
Устаревшие..
Устаревшие..

Преобразует внутренний URI в каноническую форму.

CheckHostName(String)

Определяет, является ли указанное имя узла допустимым DNS-именем.

CheckSchemeName(String)

Определяет, является ли указанное имя схемы допустимым.

CheckSecurity()
Устаревшие..
Устаревшие..
Устаревшие..

Вызов этого метода не действует.

Compare(Uri, Uri, UriComponents, UriFormat, StringComparison)

Сравнивает указанные части двух URI с помощью указанных правил сравнения.

CreateObjRef(Type)

Создает объект, содержащий все соответствующие сведения, необходимые для создания прокси-сервера, используемого для взаимодействия с удаленным объектом.

(Унаследовано от MarshalByRefObject)
Equals(Object)

Сравнивает два Uri экземпляра для равенства.

Equals(Uri)

Сравнивает два Uri экземпляра для равенства.

Escape()
Устаревшие..
Устаревшие..
Устаревшие..

Преобразует все небезопасные или зарезервированные символы в компонент пути в шестнадцатеричные представления символов.

EscapeDataString(ReadOnlySpan<Char>)

Преобразует диапазон в его экранированное представление.

EscapeDataString(String)

Преобразует строку в его экранированное представление.

EscapeString(String)
Устаревшие..
Устаревшие..
Устаревшие..
Устаревшие..

Преобразует строку в его экранированное представление.

EscapeUriString(String)
Устаревшие..
Устаревшие..

Преобразует строку URI в его escape-представление.

FromHex(Char)

Возвращает десятичное значение шестнадцатеричной цифры.

GetComponents(UriComponents, UriFormat)

Возвращает указанные компоненты текущего экземпляра с помощью указанного экранирования для специальных символов.

GetHashCode()

Возвращает хэш-код для URI.

GetLeftPart(UriPartial)

Возвращает указанную часть экземпляра Uri .

GetLifetimeService()
Устаревшие..

Извлекает текущий объект службы времени существования, который управляет политикой времени существования для этого экземпляра.

(Унаследовано от MarshalByRefObject)
GetObjectData(SerializationInfo, StreamingContext)

Возвращает данные, необходимые для сериализации текущего экземпляра.

GetType()

Возвращает Type текущего экземпляра.

(Унаследовано от Object)
HexEscape(Char)

Преобразует указанный символ в шестнадцатеричный эквивалент.

HexUnescape(String, Int32)

Преобразует указанное шестнадцатеричное представление символа в символ.

InitializeLifetimeService()
Устаревшие..

Получает объект службы времени существования для управления политикой времени существования для этого экземпляра.

(Унаследовано от MarshalByRefObject)
IsBadFileSystemCharacter(Char)
Устаревшие..
Устаревшие..
Устаревшие..

Указывает, является ли символ недопустимым в имени файловой системы.

IsBaseOf(Uri)

Определяет, является ли текущий Uri экземпляр базой указанного Uri экземпляра.

IsExcludedCharacter(Char)
Устаревшие..
Устаревшие..
Устаревшие..

Определяет, следует ли экранировать указанный символ.

IsHexDigit(Char)

Определяет, является ли указанный символ допустимым шестнадцатеричным числом.

IsHexEncoding(String, Int32)

Определяет, закодирован ли символ в строке шестнадцатеричным.

IsReservedCharacter(Char)
Устаревшие..
Устаревшие..
Устаревшие..

Определяет, является ли указанный символ зарезервированным символом.

IsWellFormedOriginalString()

Указывает, является ли строка, используемая для построения этой Uri строки, хорошо сформирована и не требует дальнейшего экранирования.

IsWellFormedUriString(String, UriKind)

Указывает, является ли строка хорошо сформированной, пытаясь создать универсальный код ресурса (URI) со строкой и гарантирует, что строка не требует дальнейшего экранирования.

MakeRelative(Uri)
Устаревшие..
Устаревшие..
Устаревшие..
Устаревшие..

Определяет разницу между двумя Uri экземплярами.

MakeRelativeUri(Uri)

Определяет разницу между двумя Uri экземплярами.

MemberwiseClone()

Создает неглубокую копию текущей Object.

(Унаследовано от Object)
Parse()
Устаревшие..
Устаревшие..
Устаревшие..

Анализирует URI текущего экземпляра, чтобы убедиться, что он содержит все части, необходимые для допустимого URI.

ToString()

Возвращает каноническое представление строки для указанного Uri экземпляра.

TryCreate(String, UriCreationOptions, Uri)

Создает новый Uri экземпляр с помощью указанного String экземпляра и UriCreationOptions.

TryCreate(String, UriKind, Uri)

Создает новый Uri с помощью указанного String экземпляра и экземпляра UriKind.

TryCreate(Uri, String, Uri)

Создает новое Uri с помощью указанных базовых и относительных String экземпляров.

TryCreate(Uri, Uri, Uri)

Создает новое Uri с помощью указанных базовых и относительных Uri экземпляров.

TryEscapeDataString(ReadOnlySpan<Char>, Span<Char>, Int32)

Пытается преобразовать диапазон в его экранированное представление.

TryFormat(Span<Char>, Int32)

Пытается отформатировать каноническое строковое представление экземпляра Uri в указанный диапазон.

TryUnescapeDataString(ReadOnlySpan<Char>, Span<Char>, Int32)

Пытается преобразовать диапазон в его неопакованное представление.

Unescape(String)
Устаревшие..
Устаревшие..
Устаревшие..

Преобразует указанную строку, заменив все escape-последовательности их незакрытым представлением.

UnescapeDataString(ReadOnlySpan<Char>)

Преобразует диапазон в его неискаченное представление.

UnescapeDataString(String)

Преобразует строку в неопакованное представление.

Операторы

Имя Описание
Equality(Uri, Uri)

Определяет, имеют ли два экземпляра одно Uri и то же значение.

Inequality(Uri, Uri)

Определяет, не имеют ли два Uri экземпляра одно и то же значение.

Явные реализации интерфейса

Имя Описание
IFormattable.ToString(String, IFormatProvider)

Форматирует значение текущего экземпляра с помощью указанного формата.

ISerializable.GetObjectData(SerializationInfo, StreamingContext)

Возвращает данные, необходимые для сериализации текущего экземпляра.

ISpanFormattable.TryFormat(Span<Char>, Int32, ReadOnlySpan<Char>, IFormatProvider)

Пытается отформатировать значение текущего экземпляра в предоставленный диапазон символов.

Применяется к

Потокобезопасность

Все члены Uri являются потокобезопасными и могут использоваться одновременно из нескольких потоков.

См. также раздел