在上一篇,我感觉有的地方不是太好理解,所以我在这里修改了一下,更通俗易懂了,为了让更容易理解。web.config中configSections中添加这个这个节点,根据这个节点 ,你可以看出创建自定义的节点是什么样子的,~/About-(\d+).html ~\About.aspx?id=$1 ~/About-(\d+)-(\d+).html ~\About.aspx?id=$1&t=$2
这一点他们必须相同。
同样的你必须创建一个RewriterConfigSerializerSectionHandler去实IConfigurationSectionHandler接口 public class RewriterConfigSerializerSectionHandler : IConfigurationSectionHandler { public object Create(object parent, object configContext, XmlNode section) { Create an instance of XmlSerializer based on the RewriterConfiguration type... //XmlSerializer ser = new XmlSerializer(typeof(RewriterConfigss)); Return the Deserialized object from the Web.config XML //return ser.Deserialize(new XmlNodeReader(section)); RewriterRule para = null; IListlist = new List (); for (int i = 0; i < section.ChildNodes.Count; i++) { para = new RewriterRule(); XmlNode xm = section.ChildNodes[i]; para.SendTo= xm.SelectSingleNode("SendTo").InnerText; para.LookFor = xm.SelectSingleNode("LookFor").InnerText; list.Add(para); } return list; } }上面注释是url重写的源码,在这里大家可以看出我修改了。这个样子更容易被理解 public class RewriterConfigss { //public RewriterRuleCollection Rules { get; set; } /// /// 该方法从web.config中读取规则集合,并使用了Cache以避免频繁IO操作 /// ///public static IList GetConfig() { //使用缓存 if (HttpContext.Current.Cache["RewriterRule"] == null) HttpContext.Current.Cache.Insert("RewriterRule", ConfigurationManager.GetSection("RewriterConfig/Rule")); return ((IList )HttpContext.Current.Cache["RewriterRule"]); } }
}
ConfigurationManager.GetSection("RewriterConfig/Rule")就这点要注意的是,这么写是为了他直接获得就是里面那些RewriterRule节点集合
就这些了,其他地方和上一遍中的代码一样。