PolicyConversionContext.GetBindingAssertions 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
메타데이터에서 정책 어설션 컬렉션을 가져옵니다.
public:
abstract System::ServiceModel::Description::PolicyAssertionCollection ^ GetBindingAssertions();
public abstract System.ServiceModel.Description.PolicyAssertionCollection GetBindingAssertions ();
abstract member GetBindingAssertions : unit -> System.ServiceModel.Description.PolicyAssertionCollection
Public MustOverride Function GetBindingAssertions () As PolicyAssertionCollection
반환
바인딩 정책 어설션을 포함하는 ICollection<T> 형식의 XmlElement입니다.
예제
다음 코드 예제에서는 콘솔에 모든 정책 어설션을 쓰는 ImportPolicy 메서드 구현을 보여 줍니다. 코드 주석에서는 특정 사용자 지정 정책 어설션을 검색하고, 구현 바인딩 요소를 생성 및 삽입하며, 컬렉션에서 어설션을 제거하는 방법을 설명합니다.
public void ImportPolicy(MetadataImporter importer,
PolicyConversionContext context)
{
Console.WriteLine("The custom policy importer has been called.");
foreach (XmlElement assertion in context.GetBindingAssertions())
{
Console.WriteLine(assertion.NamespaceURI + " : " + assertion.Name);
// locate a particular assertion by Name and NamespaceURI
XmlElement customAssertion = context.GetBindingAssertions().Find(name1, ns1);
if (customAssertion != null)
{
// Found assertion; remove from collection.
context.GetBindingAssertions().Remove(customAssertion);
Console.WriteLine(
"Removed our custom assertion from the imported "
+ "assertions collection and inserting our custom binding element."
);
// Here if you find the custom policy assertion that you are looking for,
// add the custom binding element that handles the functionality that the policy indicates.
// Attach it to the PolicyConversionContext.BindingElements collection.
// For example, if the custom policy had a "speed" attribute value:
/*
string speed
= customAssertion.GetAttribute(SpeedBindingElement.name2, SpeedBindingElement.ns2);
SpeedBindingElement e = new SpeedBindingElement(speed);
context.BindingElements.Add(e);
*/
}
// write assertion name in red.
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine(assertion.NamespaceURI + " : " + assertion.Name);
//write contents in gray.
Console.WriteLine(assertion.OuterXml);
Console.ForegroundColor = ConsoleColor.Gray;
}
}
다음 코드 예제에서는 IPolicyImportExtension 구성 섹션을 사용하여 <policyImporters>
구현을 등록하는 방법을 보여 줍니다.
<configuration>
<system.serviceModel>
<client>
<metadata>
<policyImporters>
<extension type="CustomPolicyImporter, assembly"/>
</policyImporters>
</metadata>
</client>
</system.serviceModel>
</configuration>
다음 코드 예제에서는 사용자 지정 바인딩 요소에서 IPolicyExportExtension을 구현하여 사용자 지정 정책 어설션을 바인딩 어설션에 연결하는 방법을 보여 줍니다.
public class MyBindingElement : BindingElement, IPolicyExportExtension
{
// BindingElement implementation . . .
public void ExportPolicy(
MetadataExporter exporter, PolicyConversionContext context)
{
XmlDocument xmlDoc = new XmlDocument();
XmlElement xmlElement =
xmlDoc.CreateElement("MyPolicyAssertion");
context.GetBindingAssertions().Add(xmlElement);
}
// Note: All custom binding elements must return a deep clone
// to enable the run time to support multiple bindings using the
// same custom binding.
public override BindingElement Clone()
{
// this is just a placeholder
return null;
}
// Call the inner property.
public override T GetProperty<T>(BindingContext context)
{
return context.GetInnerProperty<T>();
}
}
public class Program {
public static void Main(string[] args) {
EndpointAddress address =
new EndpointAddress("http://localhost/metadata");
CustomBinding customBinding =
new CustomBinding(new BasicHttpBinding());
customBinding.Elements.Add(new MyBindingElement());
ContractDescription contract =
ContractDescription.GetContract(typeof(MyContract));
ServiceEndpoint endpoint =
new ServiceEndpoint(contract, customBinding, address);
MetadataExporter exporter = new WsdlExporter();
exporter.ExportEndpoint(endpoint);
}
}
설명
GetBindingAssertions에서 반환되는 컬렉션은 복사본이 아닙니다. 필요한 경우 어설션을 추가 및 제거할 수 있습니다.