我可以成功地让 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;}
}
以下是网络流量的结果:
正如您所见,Query 的第二次执行只需要不到一秒,而 Invoke 的执行又需要 3 秒。
如何使 RIA OutputCache 用于 Invoke 操作?