다음을 통해 공유


세션

세션 샘플은 세션이 필요한 계약을 구현하는 방법을 보여 줍니다. 세션은 여러 작업을 수행하기 위한 컨텍스트를 제공합니다. 이렇게 하면 서비스가 지정된 세션과 상태를 연결할 수 있으므로 후속 작업에서 이전 작업의 상태를 사용할 수 있습니다. 이 샘플은 계산기 서비스를 구현하는 시작 서비스를 기반으로 합니다. ICalculator 실행 결과를 유지하면서 산술 연산 집합을 수행할 수 있도록 계약이 수정되었습니다. 이 기능은 계약에 의해 정의됩니다 ICalculatorSession . 서비스는 계산을 수행하기 위해 여러 서비스 작업이 호출되기 때문에 클라이언트의 상태를 유지 관리합니다. 클라이언트는 Result()를 호출하여 현재 결과를 검색하고 Clear()를 호출하여 결과를 0으로 지울 수 있습니다.

이 샘플에서 클라이언트는 콘솔 애플리케이션(.exe)이며 서비스는 IIS(인터넷 정보 서비스)에서 호스팅됩니다.

비고

이 샘플에 대한 설치 절차 및 빌드 지침은 이 항목의 끝에 있습니다.

계약의 SessionMode을(를) Required로 설정하면 계약이 특정 바인딩을 통해 노출될 때 바인딩이 세션을 지원하도록 보장합니다. 바인딩이 세션을 지원하지 않는 경우 예외가 발생합니다. 인터페이스는 ICalculatorSession 다음 샘플 코드와 같이 실행 중인 결과를 수정하는 하나 이상의 작업을 호출할 수 있도록 정의됩니다.

[ServiceContract(Namespace="http://Microsoft.ServiceModel.Samples", SessionMode=SessionMode.Required)]
public interface ICalculatorSession
{
    [OperationContract(IsOneWay=true)]
    void Clear();
    [OperationContract(IsOneWay = true)]
    void AddTo(double n);
    [OperationContract(IsOneWay = true)]
    void SubtractFrom(double n);
    [OperationContract(IsOneWay = true)]
    void MultiplyBy(double n);
    [OperationContract(IsOneWay = true)]
    void DivideBy(double n);
    [OperationContract]
    double Result();
}

서비스는 InstanceContextMode을(를) 사용하여 PerSession을(를) 지정된 서비스 인스턴스 컨텍스트를 들어오는 각 세션에 바인딩합니다. 이를 통해 서비스는 로컬 멤버 변수의 각 세션에 대해 실행 중인 결과를 유지할 수 있습니다.

[ServiceBehavior(InstanceContextMode=InstanceContextMode.PerSession)]
public class CalculatorService : ICalculatorSession
{
    double result = 0.0D;

    public void Clear()
    {  result = 0.0D; }

    public void AddTo(double n)
    {  result += n;   }

    public void SubtractFrom(double n)
    {  result -= n;   }

    public void MultiplyBy(double n)
    {  result *= n;   }

    public void DivideBy(double n)
    {  result /= n;   }

    public double Result()
    {  return result; }
}

샘플을 실행할 때 클라이언트는 서버에 여러 요청을 수행하고 결과를 요청합니다. 그러면 클라이언트 콘솔 창에 표시됩니다. 클라이언트 창에서 Enter 키를 눌러 클라이언트를 종료합니다.

(((0 + 100) - 50) * 17.65) / 2 = 441.25
Press <ENTER> to terminate client.

샘플을 설정, 빌드 및 실행하려면

  1. Windows Communication Foundation 샘플 에 대한One-Time 설정 절차를 수행했는지 확인합니다.

  2. 솔루션의 C# 또는 Visual Basic .NET 버전을 빌드하려면 Windows Communication Foundation 샘플빌드의 지침을 따릅니다.

  3. 단일 또는 컴퓨터 간 구성에서 샘플을 실행하려면 Windows Communication Foundation 샘플실행의 지침을 따릅니다.