欢迎光临
我们一直在努力

在asp.net atlas中调用web service—应用cache减小服务器开销_asp.net技巧

建站超值云服务器,限时71元/月

作者:Dflying Chen (http://dflying.cnblogs.com/


对于一些复杂的,需要较长时间完成,并且对实时性要求不是很高的服务,选择Cache往往是一个有效的提高效率的方法。.NET的Web Service实现充分考虑了对Cache的需求,您只需要简单的设定即可启用Cache。Atlas中对Web Service的调用也可以利用这一Cache机制,以减少服务器端不必要的开销。


要启用Web Service的Cache,您只需要在WebMethod的声明中添加如下属性:


[WebMethod(CacheDuration = 5)]


其中CacheDuration的值代表Cache的时间,单位为秒。


但这种Cache的方法是Web Service提供的,Atlas对此一无所知,每次调用还是被发送给服务器。所以对于网络上延迟对用户的影响,这种Cache没有办法改善。


让我们通过一个示例程序进一步了解Web Service的Cache。


首先编写一个Web Service,返回当前时间,并指定CacheDuration为5秒:


[WebService(Namespace = “http://tempuri.org/“)]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class CachedWebService : System.Web.Services.WebService
{
    [WebMethod(CacheDuration = 5)]
    public DateTime GetGurrentTime()
    {
        return DateTime.Now;
    }
}



然后创建一个Atlas页面,添加ScriptManager并在其中引用这个Web Service:


<atlas:ScriptManager runat=”server” ID=”scriptManager”>
    <Services>
        <atlas:ServiceReference Path=”CachedWebService.asmx” />
    </Services>
</atlas:ScriptManager>


再添加一些HTML标记用来调用这个Web Service并且显示结果:


<input id=”btnInvoke” type=”button” value=”Invoke” onclick=”return btnInvoke_onclick()” />
<div id=”result”>
</div>


最后是JavaScript部分,这里我们将每一次调用的结果都显示到页面上,便于分析:


function btnInvoke_onclick() {
    CachedWebService.GetGurrentTime(onCompleted);
}
function onCompleted(result) {
    $(result).innerHTML += result + “<br />”;
}


 


下面在浏览器中测试一下,在多次点击按钮后,结果如下,可以看到Cache的作用:
在asp.net atlas中调用web service—应用cache减小服务器开销_asp.net技巧 
同时,在Fiddler中可以看到,实际上这些请求还是被发送到了服务器,Cache只是服务器端的实现:


在asp.net atlas中调用web service—应用cache减小服务器开销_asp.net技巧
本示例的源代码可以在此下载:http://www.cnblogs.com/Files/dflying/CachedWebServiceDemo.zip

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 在asp.net atlas中调用web service—应用cache减小服务器开销_asp.net技巧
分享到: 更多 (0)