Эквивалентность тестового значения оператора ==
. Оператор is
проверяет идентичность объекта, Python проверяет, действительно ли эти два являются одним и тем же объектом (т. Е. Живут по одному и тому же адресу в памяти).
>>> a = 'banana'
>>> b = 'banana'
>>> a is b
True
В этом примере Python создал только одну строку объект, и оба a
и b
ссылаются на него. Причина в том, что Python внутренне кэширует и использует несколько строк в качестве оптимизации, на самом деле в памяти есть только строка «банан», разделяемая a и b; Чтобы вызвать нормальное поведение, вам нужно использовать более длинные строки:
>>> a = 'a longer banana'
>>> b = 'a longer banana'
>>> a == b, a is b
(True, False)
Когда вы создаете два списка, вы получаете два объекта:
>>> a = [1, 2, 3]
>>> b = [1, 2, 3]
>>> a is b
False
В этом случае мы сказали бы: что эти два списка эквивалентны, потому что они имеют одинаковые элементы, но не идентичны, потому что они не являются одним и тем же объектом. Если два объекта идентичны, они также эквивалентны, но если они эквивалентны, они не обязательно идентичны.
Если a
ссылается на объект и вы назначаете b = a
, то обе переменные ссылаются на тот же объект:
>>> a = [1, 2, 3]
>>> b = a
>>> b is a
True
Вся информация о конечной точке доступна в метаданных сервиса, можно ли записать клиенту, что исследует метаданные сервиса и настроит клиент. Для примера кода можно изучить это превосходное Проводник Mex от Juval Lowy.
Спасибо, который был полезным кодом (+1).
Это более, чем немного грязно, хотя, имеет некоторые ошибки (чувствительные к регистру проверки, которые не должны быть, например), имеет загрузку функциональности UI, в которой я не нуждаюсь, и повторяет много кода.
я взял от него фактический механизм обнаружения, переписал его и почти получил его работа (подключения, но нуждается в некотором ухищрении).
Сначала некоторые функции util, используемые основным методом:
/// <summary>If the url doesn't end with a WSDL query string append it</summary>
static string AddWsdlQueryStringIfMissing( string input )
{
return input.EndsWith( "?wsdl", StringComparison.OrdinalIgnoreCase ) ?
input : input + "?wsdl";
}
/// <summary>Imports the meta data from the specified location</summary>
static ServiceEndpointCollection GetEndpoints( BindingElement bindingElement, Uri address, MetadataExchangeClientMode mode )
{
CustomBinding binding = new CustomBinding( bindingElement );
MetadataSet metadata = new MetadataExchangeClient( binding ).GetMetadata( address, mode );
return new WsdlImporter( metadata ).ImportAllEndpoints();
}
Тогда метод, который пробует различный способ соединиться и возвращает конечные точки:
public static ServiceEndpointCollection Discover( string url )
{
Uri address = new Uri( url );
ServiceEndpointCollection endpoints = null;
if ( string.Equals( address.Scheme, "http", StringComparison.OrdinalIgnoreCase ) )
{
var httpBindingElement = new HttpTransportBindingElement();
//Try the HTTP MEX Endpoint
try { endpoints = GetEndpoints( httpBindingElement, address, MetadataExchangeClientMode.MetadataExchange ); }
catch { }
//Try over HTTP-GET
if ( endpoints == null )
endpoints = GetEndpoints( httpBindingElement,
new Uri( AddWsdlQueryStringIfMissing( url ) ), MetadataExchangeClientMode.HttpGet );
}
else if ( string.Equals( address.Scheme, "https", StringComparison.OrdinalIgnoreCase ) )
{
var httpsBindingElement = new HttpsTransportBindingElement();
//Try the HTTPS MEX Endpoint
try { endpoints = GetEndpoints( httpsBindingElement, address, MetadataExchangeClientMode.MetadataExchange ); }
catch { }
//Try over HTTP-GET
if ( endpoints == null )
endpoints = GetEndpoints( httpsBindingElement,
new Uri( AddWsdlQueryStringIfMissing( url ) ), MetadataExchangeClientMode.HttpGet );
}
else if ( string.Equals( address.Scheme, "net.tcp", StringComparison.OrdinalIgnoreCase ) )
endpoints = GetEndpoints( new TcpTransportBindingElement(),
address, MetadataExchangeClientMode.MetadataExchange );
else if ( string.Equals( address.Scheme, "net.pipe", StringComparison.OrdinalIgnoreCase ) )
endpoints = GetEndpoints( new NamedPipeTransportBindingElement(),
address, MetadataExchangeClientMode.MetadataExchange );
return endpoints;
}
Теперь есть другой способ сделать это, который был недоступен, когда я задавал исходный вопрос. Microsoft теперь поддерживает REST для служб WCF.
Вам понадобится новая ссылка в System.ServiceModel.Web
Отметьте свои операции с помощью WebInvoke
или WebGet
//get a user - note that this can be cached by IIS and proxies
[WebGet]
User GetUser(string id )
//post changes to a user
[WebInvoke]
void SaveUser(string id, User changes )
. Добавить их на сайт очень просто - добавьте .svc
file:
<%@ServiceHost
Service="MyNamespace.MyServiceImplementationClass"
Factory="System.ServiceModel.Activation.WebServiceHostFactory" %>
Строка factory сообщает ASP.net, как активировать конечную точку - вам вообще не нужна конфигурация на стороне сервера!
Тогда создание вашей ChannelFactory
практически не изменится, за исключением того, что вы не