青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

流量統計:
Rixu Blog (日需博客)
日需博客,每日必需來踩踩哦..
posts - 108,comments - 54,trackbacks - 0

大家說我說的跟.net一點關系都沒有,可是第一篇我也說了啊,僅僅是一個HELLO的例子啊?,F在哪個人不忙啊。只能一點一點的寫了。。

好了,廢話少說,我們先看看實際的情況,然后根據情況來寫一個小小的例子吧,這次有Demo下載嘍。。。

現實項目中的情況:

現實的項目中,我們不可能是有著一堆的XML的,這些XML有可能一部分是來自于現有的文檔,有一部分可能是從其它服務提供者那里得到的,當然也有可能是自己寫的服務提供的……

總之一句話,不到真正開始了,天曉得xml是哪里來的。

現實很殘酷,我們也很聰明,辦法總是有的,而且非常簡單,這里我建立了一個Index.xml,一個Index.xslt文件放到網站的Album目錄中:

可以通過一個配置文檔來配置所有XML的URL,從而增進可維護性。

Index.xml文件的內容:

<?xml version="1.0" encoding="utf-8" ?>
<?xml-stylesheet type="text/xsl" href="Index.xslt"?>
<services>
<album>XML FILE URL</album>
</services>

Index.xslt文件的內容:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="html" indent="yes" doctype-public="-//W3C//DTD XHTML 1.1//EN" doctype-system="http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"/>
<xsl:template match="services">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Index</title>
</head>
<body>
<h1>
<xsl:value-of select="album"/>
</h1>
</body>
</html>
</xsl:template>
</xsl:stylesheet>

當確認上述兩敗個文檔都正確建立后,再建立一個Index.ashx文件,用于提供XML數據,并且將Index.xml文件的album元素的值改為Index.ashx的URL。

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/xml";
context.Response.ContentEncoding = Encoding.UTF8;
List<Album> albums = new AlbumBusiness().Select("ArtistId=1");
XmlSerializer albumXmlSerializer = new XmlSerializer(albums.GetType(), new XmlRootAttribute("Albums"));
albumXmlSerializer.Serialize(context.Response.OutputStream, albums);
}

準備工作都做好了,看看輸出的XML大致的樣式吧:

<?xml version="1.0"?>
<Albums xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Album>
<AlbumId>386</AlbumId>
<GenreId>1</GenreId>
<ArtistId>1</ArtistId>
<Title>For Those About To Rock We Salute You</Title>
<Price>8.99</Price>
<AlbumArtUrl>/Content/Images/placeholder.gif</AlbumArtUrl>
</Album>
<Album>
<AlbumId>387</AlbumId>
<GenreId>1</GenreId>
<ArtistId>1</ArtistId>
<Title>Let There Be Rock</Title>
<Price>8.99</Price>
<AlbumArtUrl>/Content/Images/placeholder.gif</AlbumArtUrl>
</Album>
</Albums>

XSL通過variable標記聲明變量。

這里要說到xsl和變量和函數了,將下面的內容添加到Index.xslt文檔的template下面:

<xsl:variable name="AlbumServiceUrl" select="album"></xsl:variable>
<xsl:variable name="Albums" select="document($AlbumServiceUrl)/Albums/Album"></xsl:variable>

xsl:variable 標記用于聲明變量。其name屬性用于指定此變量的名稱,select屬性用于選擇變量的內容,在這里不難看出,它是選擇了services節點下的album節點的值。這里使用的是相對path。其文檔來源由所在的template來決定。

Albums變量的select中使用了document函數,此函數使用一個文檔路徑的參數來載入一個xml文檔。其后面跟著的“/Albums/Album” XPpath指定了選擇我們指定的那個文檔下面所有的Album節點存放在此變量中。

在XSL中,引用變量的方式是在變量名前面加一個$符號。

如上面的$AlbumServiceUrl.

接下來要輸出些東西了,我們還要再看一個新的XSL標記:xsl:for-each:

<ul>
<xsl:for-each select="$Albums">
<li>
<xsl:value-of select="Title"/>
</li>
</xsl:for-each>
</ul>

前面已經說過,我們是把所有Album節點都存到了Albums變量中了,那么這里也應當很容易看得出我們是在遍歷所有Album節點,然后把其子元素Title的值以li的形式輸出。再加上最外面包圍的一個ul,整個一個無序列表就出來了。

這里無需編譯,可以直接運行Index.xml以查看結果,我們可以把這些內容直接返還給客戶端。樣式表(xslt)文件因為是靜態的,所以客戶端只需要下載一次既可,可以暫時認為和css文件類似,只是其功能側重點不同而已。

我想,看到這里,你一定會想到,如果做分布式的話,xslt確實可以給出不錯的解決方案。

問題像是已經都解決了。但由于返回的只是xml和xslt文檔,加上搜索引擎對xml和xslt支持并不怎么樣,還可能有一些瀏覽器根本不支持xslt的情況,那么就要用到服務器端的編譯了:

再建立一個Transform.ashx文件:

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/html";
context.Response.ContentEncoding = Encoding.UTF8;

string xmlUrl = context.Server.MapPath(@"Index.xml");
string xsltUrl = context.Server.MapPath(@"Index.xslt");
XslCompiledTransform trans = new XslCompiledTransform();
trans.Load(xsltUrl, new XsltSettings() { EnableDocumentFunction = true, EnableScript = true }, new XmlUrlResolver());
trans.Transform(xmlUrl, null, context.Response.OutputStream);
}

還有一個問題就是怎么知道是蜘蛛訪問的還是用戶訪問的呢?目前我是使用的檢查UserAgent里面的值。之前在XSLT 入門--實際應用中使用的是排除蜘蛛的方式,這里要使用排除已知支持XSLT的瀏覽器的方式:

在web.config中appSettings節點下加入如下值:

<add key="XsltSupportBrowsers" value="Chrome|MSIE 9.0"/>

然后將Transform.ashx中ProcessRequest方法更改如下:

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/html";
context.Response.ContentEncoding = Encoding.UTF8;

string[] xsltSupportBrowsers = ConfigurationManager.AppSettings["XsltSupportBrowsers"].Split('|');
foreach (var xsltSupportBrowser in xsltSupportBrowsers)
{
if (context.Request.UserAgent.Contains(xsltSupportBrowser))
{
context.Response.ContentType = "text/xml";
context.Response.WriteFile(context.Server.MapPath("Index.xml"));
 return;
}
}

string xmlUrl = context.Server.MapPath(@"Index.xml");
string xsltUrl = context.Server.MapPath(@"Index.xslt");
XslCompiledTransform trans = new XslCompiledTransform();
trans.Load(xsltUrl, new XsltSettings() { EnableDocumentFunction = true, EnableScript = true }, new XmlUrlResolver());
trans.Transform(xmlUrl, null, context.Response.OutputStream);
}

Index.xml文件和Index.xslt文件的路徑是固定的,不會改變的,可以直接寫。

通過httpHandlers配置節點將請求映射到處理程序。

那么我們也可以把所有請求都交給一個Handler來處理,xslt和xml文件我們都放到同一個目錄的情況下可以這樣做:

在httpHandlers配置節點中加入一條配置,將所有對.xhtml文件的請求都交給我們的Transform Handler來處理:

<add verb="*" path="*.xhtml" type="MusicStore.Web.Albums.Transform"/>

.ashx文檔(一般處理程序)可大大簡化xslt的實施。

然后將Transform.ashx中ProcessRequest方法也可以再次更改成通用的方式,在這里沒有做異常處理,因為僅僅是為了說明能這樣做:

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/html";
context.Response.ContentEncoding = Encoding.UTF8;
string requestPhysicalPath = context.Request.PhysicalPath;
string requestFileName = requestPhysicalPath.Substring(0, requestPhysicalPath.LastIndexOf("."));
string xmlUrl = requestFileName + ".xml";
string xsltUrl = requestFileName + ".xslt";
string[] xsltSupportBrowsers = ConfigurationManager.AppSettings["XsltSupportBrowsers"].Split('|');
foreach (var xsltSupportBrowser in xsltSupportBrowsers)
{
if (context.Request.UserAgent.Contains(xsltSupportBrowser))
{
context.Response.ContentType = "text/xml";
context.Response.WriteFile(xmlUrl);
return;
}
}
XslCompiledTransform trans = new XslCompiledTransform();
trans.Load(xsltUrl, new XsltSettings() { EnableDocumentFunction = true, EnableScript = true }, new XmlUrlResolver());
trans.Transform(xmlUrl, null, context.Response.OutputStream);
}

都搞定了,不過還有個問題還是現在說一下吧,那就是不是所有時候我們都愿意把所有的內容都寫到一個xslt中。例如:網站的頁頭和頁腳難道每個XSLT文件中都復制粘貼一份?這里再建立一個Albums.xslt來解決這個問題:

可以通過指定xslt模板的name屬性來聲明一個可訪問的xslt模板。

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<xsl:output method="html" indent="yes"/>
<xsl:template name="Albums" match="album">
<xsl:variable name="AlbumServiceUrl" select="album"></xsl:variable>
<xsl:variable name="Albums" select="document($AlbumServiceUrl)/Albums/Album"></xsl:variable>
<ul>
<xsl:for-each select="$Albums">
<li>
<xsl:value-of select="Title"/>
</li>
</xsl:for-each>
</ul>
</xsl:template>
</xsl:stylesheet>

這里最主要的是使用了template的name屬性,也就是給模板起個名字??梢韵日J為就像.net里的服務器控件,給它起個ID就可以訪問。但性質是完全不同的。

call-template標記通過name屬性指定模板名稱來調用xslt模板。

調用xslt模板的方式也有多種:

這里使用<xsl:call-template />標記:

<xsl:call-template name="Albums" />

由于我們將此模板放到了Albums.xslt文件中,而不是在當前文檔中,所以得使用另一個標記來引入外部的xslt文件,

Import標記通過href屬性指定xslt URL來引入外部XSLT文件。

將此標記放到Index.xslt文檔的output標記之前:

<xsl:import href="Albums.xslt"/>


此時再將Index.xslt中的變量聲明與ul下的所有內容注釋或刪除。仍然可以得到想要的結果。

下載此項目源代碼


Logo
作者:Gezidan
出處:http://www.rixu.net    
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。

本文轉載自 http://www.cnblogs.com/javennie/archive/2011/09/28/xsltinaspnet.html
posted on 2011-09-28 10:33 日需博客 閱讀(455) 評論(0)  編輯 收藏 引用 所屬分類: C# 、技術文章 、轉載
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久男人资源视频| 久久综合九色综合网站| 亚洲免费一级电影| 欧美国内亚洲| 久久美女艺术照精彩视频福利播放| 欧美高清在线播放| 亚洲国产成人久久综合| 久久免费视频网站| 亚洲一区二区三区高清| 欧美日韩1区2区3区| 亚洲精品视频免费| 亚洲国内自拍| 麻豆精品视频在线| 在线欧美日韩| 女女同性女同一区二区三区91| 欧美一区三区三区高中清蜜桃| 国产精品日本精品| 亚洲一区综合| 亚洲综合社区| 国产一区二区三区视频在线观看| 欧美一区二区三区免费大片| 亚洲男女自偷自拍| 国产午夜亚洲精品不卡| 久久久午夜视频| 久久综合伊人77777尤物| 亚洲欧洲精品一区二区三区| 亚洲成人自拍视频| 欧美日韩免费看| 亚洲免费一级电影| 欧美一区=区| 一区一区视频| 亚洲国产视频a| 欧美色网一区二区| 欧美综合二区| 久久综合婷婷| 亚洲视频欧洲视频| 亚洲一区二区三区国产| 国内精品视频久久| 欧美激情一区二区在线 | 亚洲视频精品| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲第一色中文字幕| 欧美日韩一区二区在线观看 | 亚洲黄一区二区三区| 欧美久久在线| 欧美在线视频不卡| 免费国产自线拍一欧美视频| 一区二区欧美日韩视频| 亚洲欧美视频一区二区三区| 久久九九精品99国产精品| 久久国产手机看片| 亚洲精品视频免费观看| 亚洲天堂成人在线观看| 尤物yw午夜国产精品视频| 亚洲久久在线| 极品尤物av久久免费看| 亚洲美女啪啪| 在线观看视频一区二区| 亚洲一区精品视频| 亚洲区在线播放| 欧美一级黄色网| 在线亚洲免费| 免费试看一区| 久久在线视频在线| 国产美女一区| 亚洲精品视频免费观看| 韩国福利一区| 亚洲欧美精品| 亚洲一区久久久| 欧美国产欧美亚洲国产日韩mv天天看完整| 午夜日韩福利| 欧美日韩在线影院| 亚洲国产天堂久久综合网| 激情久久综艺| 欧美在线免费观看视频| 欧美一区二区精品在线| 欧美色精品天天在线观看视频 | 国产精品99久久久久久有的能看 | 亚洲二区精品| 欧美在线3区| 欧美亚洲免费在线| 国产精品草莓在线免费观看| 最新亚洲视频| 日韩亚洲精品在线| 欧美激情1区2区3区| 亚洲成人在线视频播放| 亚洲福利专区| 美日韩丰满少妇在线观看| 男女视频一区二区| 激情婷婷久久| 久久久综合网| 欧美第一黄色网| 亚洲破处大片| 欧美1区2区3区| 最新成人在线| 中日韩男男gay无套| 欧美视频一区二区三区| 99亚洲视频| 午夜精品久久久久久久99樱桃 | 欧美日韩在线影院| 国产精品99久久久久久久久久久久| 99伊人成综合| 国产精品久久777777毛茸茸| 亚洲一区影音先锋| 久久精品国产免费| 一区二区在线看| 免费欧美日韩国产三级电影| 亚洲欧洲精品一区二区三区| 亚洲美女一区| 国产精品99久久久久久有的能看| 亚洲一区二区3| 国产欧美精品国产国产专区| 性久久久久久久久久久久| 久久精品中文| 亚洲黑丝在线| 欧美亚男人的天堂| 欧美一区二区黄色| 亚洲第一毛片| 亚洲欧美一区二区三区极速播放| 国产一区二区三区高清| 乱码第一页成人| 在线一区二区三区四区| 久久久久久久综合| 亚洲美女在线视频| 国产农村妇女精品一区二区| 久久精品国产精品亚洲综合| 亚洲成人资源网| 午夜亚洲视频| 亚洲激情影视| 国产精品午夜在线观看| 美女黄网久久| 这里只有精品电影| 欧美~级网站不卡| 亚洲综合精品四区| 亚洲福利电影| 国产精品一区二区久久精品| 久久亚洲图片| 亚洲在线观看免费| 91久久久久久国产精品| 久久精品免费观看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲一区精彩视频| 国内精品视频久久| 欧美三级视频| 欧美成人精品一区二区三区| 亚洲伊人久久综合| 亚洲欧洲在线一区| 麻豆成人在线播放| 久久成人18免费观看| 一区二区欧美亚洲| 亚洲欧洲一区二区天堂久久| 国产欧美一区二区三区国产幕精品 | 久久亚洲风情| 亚洲欧美日韩国产一区二区| 91久久精品国产91性色tv| 欧美一区二区三区四区在线观看| 亚洲激情网站免费观看| 国产一区二区三区成人欧美日韩在线观看 | 国产欧美日韩麻豆91| 欧美黄免费看| 久久亚洲精品视频| 久久高清国产| 午夜视频久久久| 亚洲一区二区高清| 夜夜嗨一区二区| 亚洲美女诱惑| 亚洲人成亚洲人成在线观看| 在线视频精品一区| 91久久久久久久久| 亚洲国产精品va| 亚洲第一区在线| 久久免费的精品国产v∧| 午夜精品久久久久久久99热浪潮| 亚洲图片欧洲图片av| 亚洲美女精品一区| 日韩亚洲国产精品| 一区二区三区久久| 一本一本久久| 一区二区欧美国产| 亚洲图片在区色| 香蕉尹人综合在线观看| 午夜精品福利一区二区蜜股av| 亚洲一区影院| 欧美一区二区三区四区在线观看地址 | 欲香欲色天天天综合和网| 狠狠色狠狠色综合日日91app| 激情久久综合| 亚洲精品一区二区三区蜜桃久 | 亚洲婷婷在线| 亚洲男女自偷自拍| 香蕉久久一区二区不卡无毒影院| 午夜久久久久久久久久一区二区| 先锋资源久久| 老司机午夜精品视频| 亚洲成色999久久网站| 日韩视频一区二区| 亚洲丝袜av一区| 午夜久久久久久| 久久女同互慰一区二区三区| 欧美国产一区视频在线观看|