1

我可以成功地让 OutputCache 为 Query 操作工作,但我无法让缓存为我的 Invoke 操作工作,即使我标记为 HasNoSideEffect=true (HTTP GET)。

这是我的服务代码:

[EnableClientAccess]
public class MyDomainService:DomainService
{
    [OutputCache(OutputCacheLocation.Server, 60, UseSlidingExpiration = true)]
    public IQueryable<MyEntity1> GetMyItems(string parameter)
    {
        var res = new List<MyEntity1>();
        var dtNow = DateTime.Now;
        for (int i = 0; i < 5; i++)
        {
            var newItem = new MyEntity1();
            newItem.Id = i;
            newItem.InstantiatedTime = dtNow;
            newItem.ParameterValue = parameter;
            res.Add(newItem);
        }
        Thread.Sleep(3000);
        return res.AsQueryable();
    }

    [System.ServiceModel.DomainServices.Server.Invoke(HasSideEffects = false)]
    [OutputCache(OutputCacheLocation.Any, 60, UseSlidingExpiration = true)]
    public IEnumerable<string> MyInvokeOperation(string parameter)
    {
        var res = new List<string>();
        var dtNow = DateTime.Now;
        for (int i = 0; i < 5; i++)
        {
            var newItem = i.ToString();
            newItem += dtNow.ToString() + parameter;
            res.Add(newItem);
        }
        Thread.Sleep(3000);
        return res;
    }
}

[DataContract]
public class MyEntity1
{
    [Key]
    [DataMember]
    public int Id { get; set; }
    [DataMember]
    public DateTime InstantiatedTime { get; set; }
    [DataMember]
    public string ParameterValue{get;set;}
}

以下是网络流量的结果:

来自 IE10 的网络流量图像

正如您所见,Query 的第二次执行只需要不到一秒,而 Invoke 的执行又需要 3 秒。

如何使 RIA OutputCache 用于 Invoke 操作?

4

0 回答 0