程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> 關於C# >> 設計模式(C#) - 代理模式(Proxy Pattern)

設計模式(C#) - 代理模式(Proxy Pattern)

編輯:關於C#

返回“設計模式(C#)系列文章索引”

介紹

為其他對象提供一個代理以控制對這個對象的訪問。

示例

有一個Message實體類,某對象對它的操作有Insert()和Get()方法,用一個代理來控制對這個對象的訪問。

MessageModel

using System;
using System.Collections.Generic;
using System.Text;

namespace Pattern.Proxy
{
  /**//// <summary>
  /// Message實體類
  /// </summary>
  public class MessageModel
  {
    /**//// <summary>
    /// 構造函數
    /// </summary>
    /// <param name="msg">Message內容</param>
    /// <param name="pt">Message發布時間</param>
    public MessageModel(string msg, DateTime pt)
    {
      this._message = msg;
      this._publishTime = pt;
    }

    private string _message;
    /**//// <summary>
    /// Message內容
    /// </summary>
    public string Message
    {
      get { return _message; }
      set { _message = value; }
    }

    private DateTime _publishTime;
    /**//// <summary>
    /// Message發布時間
    /// </summary>
    public DateTime PublishTime
    {
      get { return _publishTime; }
      set { _publishTime = value; }
    }
  }
}

IMessage

using System;
using System.Collections.Generic;
using System.Text;

namespace Pattern.Proxy
{
  /**//// <summary>
  /// 對Message操作的接口
  /// </summary>
  public interface IMessage
  {
    /**//// <summary>
    /// 獲取Message
    /// </summary>
    /// <returns></returns>
    List<MessageModel> Get();

    /**//// <summary>
    /// 插入Message
    /// </summary>
    /// <param name="mm">Message實體對象</param>
    /// <returns></returns>
    bool Insert(MessageModel mm);
  }
}

SqlMessage

using System;
using System.Collections.Generic;
using System.Text;

namespace Pattern.Proxy
{
  /**//// <summary>
  /// Sql方式操作Message
  /// </summary>
  public class SqlMessage : IMessage
  {
    /**//// <summary>
    /// 獲取Message
    /// </summary>
    /// <returns></returns>
    public List<MessageModel> Get()
    {
      List<MessageModel> l = new List<MessageModel>();
      l.Add(new MessageModel("SQL方式獲取Message", DateTime.Now));

      return l;
    }

    /**//// <summary>
    /// 插入Message
    /// </summary>
    /// <param name="mm">Message實體對象</param>
    /// <returns></returns>
    public bool Insert(MessageModel mm)
    {
      // 代碼略
      return true;
    }
  }
}

MessageProxy

using System;
using System.Collections.Generic;
using System.Text;

namespace Pattern.Proxy
{
  /**//// <summary>
  /// 代理類
  /// </summary>
  public class MessageProxy : IMessage
  {
    SqlMessage _sqlMessage;

    /**//// <summary>
    /// 構造函數
    /// </summary>
    public MessageProxy()
    {
      _sqlMessage = new SqlMessage();
    }

    /**//// <summary>
    /// 獲取Message
    /// </summary>
    /// <returns></returns>
    public List<MessageModel> Get()
    {
      return _sqlMessage.Get();
    }

    /**//// <summary>
    /// 插入Message
    /// </summary>
    /// <param name="mm">Message實體對象</param>
    /// <returns></returns>
    public bool Insert(MessageModel mm)
    {
      return _sqlMessage.Insert(mm);
    }
  }
}

client

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

using Pattern.Proxy;

public partial class Proxy : System.Web.UI.Page
{
  protected void Page_Load(object sender, EventArgs e)
  {
    MessageProxy m = new MessageProxy();
    Response.Write(m.Insert(new MessageModel("插入", DateTime.Now)));
    Response.Write("<br />");
    Response.Write(m.Get()[0].Message + " " + m.Get()[0].PublishTime.ToString());
  }
}

運行結果

True

SQL方式獲取Message 2007-4-1 16:31:24

參考

http://www.dofactory.com/Patterns/PatternProxy.aspx

OK

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved