OperationBehaviorAttribute Sınıf
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Bir hizmet yönteminin yerel yürütme davranışını belirtir.
public ref class OperationBehaviorAttribute sealed : Attribute, System::ServiceModel::Description::IOperationBehavior
[System.AttributeUsage(System.AttributeTargets.Method)]
public sealed class OperationBehaviorAttribute : Attribute, System.ServiceModel.Description.IOperationBehavior
[<System.AttributeUsage(System.AttributeTargets.Method)>]
type OperationBehaviorAttribute = class
inherit Attribute
interface IOperationBehavior
Public NotInheritable Class OperationBehaviorAttribute
Inherits Attribute
Implements IOperationBehavior
- Devralma
- Öznitelikler
- Uygulamalar
Örnekler
Aşağıdaki kod örneği, zorunlu bir dağıtılmış işlem içinde yürütülen bir işlemi gösterir. TransactionScopeRequired özelliği, yönteminin çağıranın işlemi altında yürütüldüğünü, TransactionAutoComplete özelliği ise işlenmeyen özel durum oluşmazsa işlemin otomatik olarak yürütüldüğünü belirtir. İşlenmeyen bir özel durum oluşursa işlem durdurulür.
using System;
using System.ServiceModel;
using System.Transactions;
namespace Microsoft.WCF.Documentation
{
[ServiceContract(Namespace="http://microsoft.wcf.documentation", SessionMode=SessionMode.Required)]
public interface IBehaviorService
{
[OperationContract]
string TxWork(string message);
}
// Note: To use the TransactionIsolationLevel property, you
// must add a reference to the System.Transactions.dll assembly.
/* The following service implementation:
* -- Processes messages on one thread at a time
* -- Creates one service object per session
* -- Releases the service object when the transaction commits
*/
[ServiceBehavior(
ConcurrencyMode=ConcurrencyMode.Single,
InstanceContextMode=InstanceContextMode.PerSession,
ReleaseServiceInstanceOnTransactionComplete=true
)]
public class BehaviorService : IBehaviorService, IDisposable
{
Guid myID;
public BehaviorService()
{
myID = Guid.NewGuid();
Console.WriteLine(
"Object "
+ myID.ToString()
+ " created.");
}
/*
* The following operation-level behaviors are specified:
* -- Always executes under a transaction scope.
* -- The transaction scope is completed when the operation terminates
* without an unhandled exception.
*/
[OperationBehavior(
TransactionAutoComplete = true,
TransactionScopeRequired = true
)]
[TransactionFlow(TransactionFlowOption.Mandatory)]
public string TxWork(string message)
{
// Do some transactable work.
Console.WriteLine("TxWork called with: " + message);
// Display transaction information.
TransactionInformation info = Transaction.Current.TransactionInformation;
Console.WriteLine("The distributed tx ID: {0}.", info.DistributedIdentifier);
Console.WriteLine("The tx status: {0}.", info.Status);
return String.Format("Hello. This was object {0}.",myID.ToString()) ;
}
public void Dispose()
{
Console.WriteLine(
"Service "
+ myID.ToString()
+ " is being recycled."
);
}
}
}
Imports System.ServiceModel
Imports System.Transactions
Namespace Microsoft.WCF.Documentation
<ServiceContract(Namespace:="http://microsoft.wcf.documentation", SessionMode:=SessionMode.Required)> _
Public Interface IBehaviorService
<OperationContract> _
Function TxWork(ByVal message As String) As String
End Interface
' Note: To use the TransactionIsolationLevel property, you
' must add a reference to the System.Transactions.dll assembly.
' The following service implementation:
' * -- Processes messages on one thread at a time
' * -- Creates one service object per session
' * -- Releases the service object when the transaction commits
<ServiceBehavior(ConcurrencyMode:=ConcurrencyMode.Single, InstanceContextMode:=InstanceContextMode.PerSession, _
ReleaseServiceInstanceOnTransactionComplete:=True)> _
Public Class BehaviorService
Implements IBehaviorService, IDisposable
Private myID As Guid
Public Sub New()
myID = Guid.NewGuid()
Console.WriteLine("Object " & myID.ToString() & " created.")
End Sub
'
' * The following operation-level behaviors are specified:
' * -- Always executes under a transaction scope.
' * -- The transaction scope is completed when the operation terminates
' * without an unhandled exception.
'
<OperationBehavior(TransactionAutoComplete:=True, TransactionScopeRequired:=True), _
TransactionFlow(TransactionFlowOption.Mandatory)> _
Public Function TxWork(ByVal message As String) As String Implements IBehaviorService.TxWork
' Do some transactable work.
Console.WriteLine("TxWork called with: " & message)
' Display transaction information.
Dim info As TransactionInformation = Transaction.Current.TransactionInformation
Console.WriteLine("The distributed tx ID: {0}.", info.DistributedIdentifier)
Console.WriteLine("The tx status: {0}.", info.Status)
Return String.Format("Hello. This was object {0}.", myID.ToString())
End Function
Public Sub Dispose() Implements IDisposable.Dispose
Console.WriteLine("Service " & myID.ToString() & " is being recycled.")
End Sub
End Class
End Namespace
Açıklamalar
OperationBehaviorAttribute yürütülürken işlemin hangi işleme özgü yürütme davranışına sahip olduğunu belirtmek için özniteliğini kullanın. (Hizmet düzeyinde yürütme davranışını belirtmek için özniteliğini ServiceBehaviorAttribute kullanın.)
Not
Çift yönlü istemci uygulamasında geri çağırma sözleşmesi işlemini yapılandırmak için de kullanabilirsiniz OperationBehaviorAttribute . Bir geri çağırma işleminde kullanıldığında, özelliğin ReleaseInstanceMode olması None gerekir veya çalışma zamanında bir InvalidOperationException özel durum oluşturulur.
özniteliği, geliştiricilerin OperationBehaviorAttribute aksi takdirde kendilerini uygulaması gereken ortak özellikleri etkinleştiren bir Windows Communication Foundation (WCF) programlama modeli özelliğidir.
özelliği, AutoDisposeParameters bir işleme geçirilen parametre nesnelerinin işlem tamamlandığında atılıp atılmayacağını denetler.
özelliği, TransactionAutoComplete işlenemeyen özel durumlar oluşmazsa yöntemin yürütüldiği işlemin otomatik olarak işlenip işlenmeyeceğini belirtir.
TransactionScopeRequired özelliği, bir yöntemin bir işlem içinde yürütülmesi gerekip gerekmediğini belirtir.
Impersonation özelliği, hizmet işleminin çağıranın kimliğini taklit edip edemeyeceğini belirtir.
özelliği, ReleaseInstanceMode yöntem çağırma işlemi sırasında hizmet nesnelerinin geri dönüştürülme zamanlarını belirtir.
Oluşturucular
OperationBehaviorAttribute() |
OperationBehaviorAttribute sınıfının yeni bir örneğini başlatır. |
Özellikler
AutoDisposeParameters |
Parametrelerin otomatik olarak atılıp atılmayacağını belirten bir değer alır veya ayarlar. |
Impersonation |
İşlemin desteklediği çağıran kimliğe bürünme düzeyini gösteren bir değer alır veya ayarlar. |
ReleaseInstanceMode |
Hizmet nesnesini geri dönüştürmek için bir işlem çağrısı sırasında ne zaman olduğunu belirten bir değeri alır veya ayarlar. |
TransactionAutoComplete |
İşlenmeyen özel durumlar oluşmazsa geçerli işlem kapsamının otomatik olarak tamamlanıp tamamlanmayacağını belirten bir değer alır veya ayarlar. |
TransactionScopeRequired |
Yönteminin yürütülmesi için bir işlem kapsamı gerekip gerekmediğini belirten bir değer alır veya ayarlar. |
TypeId |
Türetilmiş bir sınıfta uygulandığında, bu Attributeiçin benzersiz bir tanımlayıcı alır. (Devralındığı yer: Attribute) |
Yöntemler
Equals(Object) |
Bu örneğin belirtilen bir nesneye eşit olup olmadığını gösteren bir değeri döndürür. (Devralındığı yer: Attribute) |
GetHashCode() |
Bu örneğe ilişkin karma kodu döndürür. (Devralındığı yer: Attribute) |
GetType() |
Type Geçerli örneğini alır. (Devralındığı yer: Object) |
IsDefaultAttribute() |
Türetilmiş bir sınıfta geçersiz kılındığında, bu örneğin değerinin türetilmiş sınıf için varsayılan değer olup olmadığını gösterir. (Devralındığı yer: Attribute) |
Match(Object) |
Türetilmiş bir sınıfta geçersiz kılındığında, bu örneğin belirtilen bir nesneye eşit olup olmadığını gösteren bir değer döndürür. (Devralındığı yer: Attribute) |
MemberwiseClone() |
Geçerli Objectöğesinin sığ bir kopyasını oluşturur. (Devralındığı yer: Object) |
ToString() |
Geçerli nesneyi temsil eden dizeyi döndürür. (Devralındığı yer: Object) |