Aracılığıyla paylaş


OperationBehaviorAttribute Sınıf

Tanım

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
OperationBehaviorAttribute
Ö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)

Belirtik Arabirim Kullanımları

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Bir ad kümesini karşılık gelen bir dağıtma tanımlayıcısı kümesine eşler.

(Devralındığı yer: Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Bir arabirimin tür bilgilerini almak için kullanılabilecek bir nesnenin tür bilgilerini alır.

(Devralındığı yer: Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Bir nesnenin sağladığı tür bilgisi arabirimlerinin sayısını alır (0 ya da 1).

(Devralındığı yer: Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Bir nesne tarafından sunulan özelliklere ve yöntemlere erişim sağlar.

(Devralındığı yer: Attribute)
IOperationBehavior.AddBindingParameters(OperationDescription, BindingParameterCollection)

AddBindingParameters(OperationDescription, BindingParameterCollection) yöntemini uygular.

IOperationBehavior.ApplyClientBehavior(OperationDescription, ClientOperation)

İstemci işlemi davranışını uygular.

IOperationBehavior.ApplyDispatchBehavior(OperationDescription, DispatchOperation)

Hizmet işlemi davranışını uygular.

IOperationBehavior.Validate(OperationDescription)

Doğrulama davranışını uygular.

Şunlara uygulanır