OperationContextScope Construtores
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
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.