CoOLeR

CoOLeR

导航

使用ASP.NET 2.0提供的WebResource管理资源(转)

Posted on 2009-05-22 14:56  ImCoOLeR  阅读(174)  评论(0编辑  收藏  举报
使用ASP.NET 2.0提供的WebResource管理资源
    ASP.NET(1.0/1.1)给我们提供了一个开发WebControl的编程模型,于是我们摆脱了asp里面的include模式的复用方式。不过1.0/1.1提供的Web控件开发模型对于处理没有image、css等外部资源的组件还算比较得心应手,script虽然很多时候也是外部资源,但在开发控件的时候我们习惯把script使用Page.Register...Script()来嵌入模块,因为紧凑的东西更便于我们复用,用一个dll就可以解决问题又何必要节外生枝呢。

     ASP.NET 2.0提供的Web Resources管理模型,很好的解决了image、css、script等外部资源的管理问题。现在只需要在solution explorer把资源文件的build action属性设为Embedded Resource。然后在assemblyinfo.cs里添加一句:
[assemblyWebResource("WebCtrl.cutecat.jpg""image/jpg")]
    我们可以看msdn里有WebResource的参数说明:第一个是资源的名字,第二个是资源的mime-type名。
    其实这个语句放任何cs文件里,保证放在最高级namespace外就行。

    然后在程序中调用如下:
m_Image.ImageUrl = this.Page.GetWebResourceUrl(typeof(WebCustom), "WebCtrl.cutecat.jpg");
    GetWebResourceUrl的第一个参数是用户定义的类型(这个是用来确定assembly用的),第二个参数是资源名。

    上面的语句返回给browser的代码是:
<img src="WebResource.axd?a=pWebCtrl&amp;r=WebCtrl.cutecat.jpg&amp;t=632390947985312500" style="border-width:0px;" />
    其中的src就是GetWebesourceUrl执行后返回的,它有3个参数(这里的&被解析成了&amp;,不过IIS也认的),第一个参数a是就是通过typeof(WebCustom)来确定的assembly的名字,第二个参数r很明显就是资源的名字了,第三个参数t是一个a所指的assembly的timestamp。这个t是为了让资源的引用能享用browser缓存的优化,因为IE对相同的url有自己的cache机制。又因为这个r同时又是用户assembly文件的timestamp,如果用户更新了代码,重新编译后t也会变化,这样也就保证了browser能获得最新的资源更新。如果我们能确定嵌入资源是确实不用再更新的,我们可以在typeof()里写一个bcl里的类型,比如typeof(string),那么他将只在freamwork升级后才会变动这个t。

    当然这个WebResource.axd是不存在的,它只是IIS中的一个ISAPI影射。

    使用示例代码如下:
#region WebResource Demo

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using System.Web.UI;
using System.Web.UI.WebControls;

[assembly: WebResource(
"WebCtrl.cutecat.jpg""image/jpg")]

namespace WebCtrl
{
    [DefaultProperty(
"Text")]
    [ToolboxData(
"<{0}:WebCustom runat=server></{0}:WebCustom>")]
    
public class WebCustom : WebControl
    
{
        
private string text;
        
private Image m_Image;

        [Bindable(
true)]
        [Category(
"Appearance")]
        [DefaultValue(
"")]
        
public string Text
        
{
            
get return text; }
            
set { text = value; }
        }


        
protected override void CreateChildControls()
        
{
            m_Image 
= new Image();
            
this.Controls.Add(m_Image);
        }


        
protected override void Render(HtmlTextWriter output)
        
{
            m_Image.ImageUrl 
= this.Page.GetWebResourceUrl(typeof(WebCustom), "WebCtrl.cutecat.jpg");
            
this.RenderChildren(output);
        }

    }

}

#endregion