OperationContextScope Construtores

Definição

Inicializa uma nova instância da OperationContextScope classe.

Sobrecargas

Name Description
OperationContextScope(IContextChannel)

Inicializa uma nova instância da OperationContextScope classe que usa o especificado IContextChannel para criar uma nova OperationContext para o escopo.

OperationContextScope(OperationContext)

Inicializa uma nova instância da OperationContextScope classe para criar um escopo para o objeto especificado OperationContext .

OperationContextScope(IContextChannel)

Origem:
OperationContextScope.cs
Origem:
OperationContextScope.cs
Origem:
OperationContextScope.cs

Inicializa uma nova instância da OperationContextScope classe que usa o especificado IContextChannel para criar uma nova OperationContext para o escopo.

public:
 OperationContextScope(System::ServiceModel::IContextChannel ^ channel);
public OperationContextScope(System.ServiceModel.IContextChannel channel);
new System.ServiceModel.OperationContextScope : System.ServiceModel.IContextChannel -> System.ServiceModel.OperationContextScope
Public Sub New (channel As IContextChannel)

Parâmetros

channel
IContextChannel

O canal a usar ao criar o escopo para um novo OperationContext.

Exemplos

O exemplo seguinte mostra como usar o OperationContextScope para criar um novo contexto numa aplicação cliente para adicionar um cabeçalho personalizado à mensagem de saída.

SampleServiceClient wcfClient = new SampleServiceClient(new InstanceContext(this));
try
{
  using (OperationContextScope scope = new OperationContextScope(wcfClient.InnerChannel))
  {
    MessageHeader header
      = MessageHeader.CreateHeader(
      "Service-Bound-CustomHeader",
      "http://Microsoft.WCF.Documentation",
      "Custom Happy Value."
      );
    OperationContext.Current.OutgoingMessageHeaders.Add(header);

    // Making calls.
    Console.WriteLine("Enter the greeting to send: ");
    string greeting = Console.ReadLine();

    //Console.ReadLine();
    header = MessageHeader.CreateHeader(
        "Service-Bound-OneWayHeader",
        "http://Microsoft.WCF.Documentation",
        "Different Happy Value."
      );
    OperationContext.Current.OutgoingMessageHeaders.Add(header);

    // One-way
    wcfClient.Push(greeting);
    this.wait.WaitOne();

    // Done with service.
    wcfClient.Close();
    Console.WriteLine("Done!");
    Console.ReadLine();
  }
}
catch (TimeoutException timeProblem)
{
  Console.WriteLine("The service operation timed out. " + timeProblem.Message);
  Console.ReadLine();
  wcfClient.Abort();
}
catch (CommunicationException commProblem)
{
  Console.WriteLine("There was a communication problem. " + commProblem.Message);
  Console.ReadLine();
  wcfClient.Abort();
}
Dim wcfClient As New SampleServiceClient(New InstanceContext(Me))
Try
  Using scope As New OperationContextScope(wcfClient.InnerChannel)
            Dim header As MessageHeader = MessageHeader.CreateHeader("Service-Bound-CustomHeader", _
                                "http://Microsoft.WCF.Documentation", "Custom Happy Value.")
    OperationContext.Current.OutgoingMessageHeaders.Add(header)

    ' Making calls.
    Console.WriteLine("Enter the greeting to send: ")
    Dim greeting As String = Console.ReadLine()

    'Console.ReadLine();
            header = MessageHeader.CreateHeader("Service-Bound-OneWayHeader", _
                                                "http://Microsoft.WCF.Documentation", "Different Happy Value.")
    OperationContext.Current.OutgoingMessageHeaders.Add(header)

    ' One-way
    wcfClient.Push(greeting)
    Me.wait.WaitOne()

    ' Done with service. 
    wcfClient.Close()
    Console.WriteLine("Done!")
    Console.ReadLine()
  End Using
Catch timeProblem As TimeoutException
  Console.WriteLine("The service operation timed out. " & timeProblem.Message)
  Console.ReadLine()
  wcfClient.Abort()
Catch commProblem As CommunicationException
  Console.WriteLine("There was a communication problem. " & commProblem.Message)
  Console.ReadLine()
  wcfClient.Abort()
End Try

Observações

Use o OperationContextScope construtor para criar um novo OperationContext canal cliente que possa ser usado para adicionar ou modificar cabeçalhos de mensagens de saída, ler cabeçalhos de mensagens recebidas ou aceder a outras propriedades de tempo de execução do OperationContextcanal .

Os cabeçalhos adicionados à OperationContext.IncomingMessageHeaders propriedade do recém-criado OperationContext aplicam-se apenas ao canal que foi passado ao OperationContextScope construtor. Se o utilizador criar um novo canal dentro do seu âmbito, então os cabeçalhos não são aplicados às mensagens enviadas no novo canal.

Aplica-se a

OperationContextScope(OperationContext)

Origem:
OperationContextScope.cs
Origem:
OperationContextScope.cs
Origem:
OperationContextScope.cs

Inicializa uma nova instância da OperationContextScope classe para criar um escopo para o objeto especificado OperationContext .

public:
 OperationContextScope(System::ServiceModel::OperationContext ^ context);
public OperationContextScope(System.ServiceModel.OperationContext context);
new System.ServiceModel.OperationContextScope : System.ServiceModel.OperationContext -> System.ServiceModel.OperationContextScope
Public Sub New (context As OperationContext)

Parâmetros

context
OperationContext

O ativo OperationContext no âmbito criado.

Observações

Use o OperationContextScope construtor para criar um bloco de código dentro do qual o objeto especificado OperationContextScope é o âmbito atual.

Aplica-se a