亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

基于C# 網站地圖制作

2024-07-10 13:20:39
字體:
來源:轉載
供稿:網友
1、 我們的網站是用C#開發的,我們采用數據庫存儲所有文章信息。所以我們的文章都是動態地從數據庫中提取出來的。這點很不利于蜘蛛的順藤摸瓜。
2、 這點嘛,嘿嘿,就有些勉強了。做個網站地圖,可以讓用戶對敝網站的內容一目了然,能起到很好的導航作用。
鑒于上述原因,于是乎,俺就決定為俺地“赤兔英語網”做一個網站地圖。由于Google等搜索引擎所需的網站地圖必須是XML文件,所以俺決定做網頁形式和XML形式兩種網站地圖。我們的網站是用C#開發的,當然是使用C#語言來編寫俺地網站地圖了,赫赫。
首先,我們來看看,我們的網站地圖該怎么生成,怎么展現。簡單思考之后,我決定這樣做。網站首頁的菜單中添加“網站地圖”選項,其鏈接著網頁形式的網站地圖,頁面名字為sitemap.html;首頁的底部也添加鏈接“網站地圖”,其鏈接著XML格式的網站地圖,頁面名字為sitemap.xml。這兩個頁面生成程序在后臺添加。設置一個按鈕,管理員在一段時間內點擊該按鈕,直接生成這兩個文件,放在網站的根目錄下,供客戶端隨時調用。
下面,我們來看看生成網站地圖的代碼的具體實現。為了文章可讀性,我們從頂向下來對code實現過程做以介紹。
一、網站地圖的頂層設計
頂層的網站地圖生成按鈕的code為:
protected void BtnGenerateSitemap_Click(object sender, EventArgs e)
{
createHtmlSitemap();
createXMLSitemap();
WebUtility.ResponseScript("網站地圖生成完畢!",0);
}
上面code一目了然,createHtmlSitemap()用來生成html網站地圖,createXMLSitemap()用來生成XML網站地圖。
二、Html網站地圖的生成
我們先介紹Html網站地圖的生成。createHtmlSitemap()的code如下:
public void createHtmlSitemap()
{
FileInfo HtmlFile = null;
StreamWriter WriteHtmlFile = null;
string FilePath = Server.MapPath("sitemap.html");//獲取html文件路徑及名稱
HtmlFile = new FileInfo(FilePath);//創建html文件
WriteHtmlFile = HtmlFile.CreateText();
WriteHtmlFile.WriteLine("<html>");
WriteHtmlFile.WriteLine("<head>");
WriteHtmlFile.WriteLine("<meta http-equiv=Content-Type content=text/html;charset=UTF-8>");
WriteHtmlFile.WriteLine("<title>赤兔英語網 網站地圖</title>");
WriteHtmlFile.WriteLine("</head>");
WriteHtmlFile.WriteLine("<body>");
getHtmlSitemapData(WriteHtmlFile);
WriteHtmlFile.WriteLine("</body>");
WriteHtmlFile.WriteLine("</html>");
WriteHtmlFile.Close();
}
上述code創建了html文件sitemap.html,并使用對象StreamWriter書寫了sitemap.html。函數getHtmlSitemapData(WriteHtmlFile)完成了sitemap.html正文部分的組織。
需要注意的是,如果網站地圖中有中文,必須將charset設置為UTF-8。否則中文不能正常顯示。
public void getHtmlSitemapData(StreamWriter writerFile)
{
string classTableName = "ArticleClass";
string articleItemTableName = "ArticleItem";
string connectionString = ConfigurationManager.AppSettings["SQLConnString"].ToString();
SqlConnection conn = new SqlConnection(connectionString);
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
//查詢大類信息
SqlDataAdapter classDataAdpt = new SqlDataAdapter("SELECT Id, Classname FROM " + classTableName, connectionString);
DataSet classDataSet = new DataSet();
classDataAdpt.Fill(classDataSet, classTableName);
writerFile.WriteLine("<tablecellspacing='0' cellpadding='0'>");
//按照大類信息來查取各個大類下的文章信息
for (int i = 0; i < classDataSet.Tables[0].Rows.Count; i++)
{
string tempsql = "SELECT Id, ArticleTitle, Parentid FROM " + articleItemTableName + " where Parentid = " + classDataSet.Tables[0].Rows[i][0].ToString();
SqlCommand cmd = new SqlCommand(tempsql, conn);
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
if (rdr.HasRows)
{
int classId = 0;
int rowNum = 0;//記錄處理了篇文章信息
int memberInLine = 5;//每行顯示多少篇文章的鏈接信息
while (rdr.Read())
{
//處理大類信息,大類也需要以超鏈接的方式寫入html文件
if (classId != int.Parse(rdr[2].ToString()))
{
rowNum = 0;
classId = int.Parse(rdr[2].ToString());
writerFile.WriteLine("<tr>");
writerFile.WriteLine("<td colspan='5'>");
writerFile.WriteLine("<a target='_blank' + classDataSet.Tables[0].Rows[i][0].ToString() + "'>" + classDataSet.Tables[0].Rows[i][1].ToString() + "</a>");
writerFile.WriteLine("</td>");
writerFile.WriteLine("</tr>");
}
//處理文章信息
rowNum++;
if (1 == (rowNum % memberInLine))//a new line
{
writerFile.WriteLine("<tr>");
}
writerFile.WriteLine("<td>");
writerFile.WriteLine("<a target='_blank' + rdr[0].ToString() + "'>" + rdr[1].ToString() + "</a>");
writerFile.WriteLine("</td>");
if (0 == (rowNum % memberInLine))//a new line
{
writerFile.WriteLine("</tr>");
}
}
}
rdr.Close();
}
writerFile.WriteLine("</table>");
}
三、XML網站地圖的生成
XML網站地圖的生成與Html不同點在于,Google等搜索引擎對這種網站地圖的格式有嚴格的要求,必須遵守,否則不會被他們承認。具體xml文件格式可參考?articleid=18092
createXMLSitemap()函數的實現如下:
public void createXMLSitemap()
{
FileInfo XMLFile = null;
StreamWriter WriteXMLFile = null;
string FilePath = Server.MapPath("sitemap.xml");
XMLFile = new FileInfo(FilePath);
WriteXMLFile = XMLFile.CreateText();
//下面兩句話必須寫,而且不能做任何修改
WriteXMLFile.WriteLine("<?xml version=/"1.0/" encoding=/"UTF-8/"?>");
WriteXMLFile.WriteLine("<urlset xmlns=/"http://www.google.com/schemas/sitemap/0.84/">");
getXMLSitemapData(WriteXMLFile);
WriteXMLFile.WriteLine("</urlset>");//別忘了這句話
WriteXMLFile.Close();
}
createXMLSitemap()的實現如下:
public void getXMLSitemapData(StreamWriter writerFile)
{
string classTableName = "ArticleClass";
string articleItemTableName = "ArticleItem";
string connectionString = ConfigurationManager.AppSettings["SQLConnString"].ToString();
SqlConnection conn = new SqlConnection(connectionString);
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
//查詢大類信息
SqlDataAdapter classDataAdpt = new SqlDataAdapter("SELECT Id, Classname FROM " + classTableName, connectionString);
DataSet classDataSet = new DataSet();
classDataAdpt.Fill(classDataSet, classTableName);
for (int i = 0; i < classDataSet.Tables[0].Rows.Count; i++)
{
string tempsql = "SELECT Id, ArticleTitle, Parentid FROM " + articleItemTableName + " where Parentid = " + classDataSet.Tables[0].Rows[i][0].ToString();
SqlCommand cmd = new SqlCommand(tempsql, conn);
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
if (rdr.HasRows)
{
int subClassId = 0;
while (rdr.Read())
{
//處理大類信息,
if (subClassId != int.Parse(rdr[0].ToString()))
{
subClassId = int.Parse(rdr[0].ToString());
writerFile.WriteLine("<url>");
writerFile.WriteLine("<loc>" + "http://www.chituwang.com/Article/index.aspx?parentid=" + rdr[2].ToString() + "</loc>");
writerFile.WriteLine("<lastmod>" + DateTime.Now.ToShortDateString() + "</lastmod>");
writerFile.WriteLine("<changefreq>daily</changefreq>");
writerFile.WriteLine("<priority>0.5</priority>");
writerFile.WriteLine("</url>");
}
//處理文章信息
writerFile.WriteLine("<url>");
writerFile.WriteLine("<loc>" + "http://www.chituwang.com/Article/index.aspx?articleid=" + rdr[0].ToString() + "</loc>");
writerFile.WriteLine("<lastmod>" + DateTime.Now.ToShortDateString() + "</lastmod>");
writerFile.WriteLine("<changefreq>monthly</changefreq>");
writerFile.WriteLine("<priority>0.4</priority>");
writerFile.WriteLine("</url>");
}
}
rdr.Close();
}
}
通過上面兩個小節的介紹,網頁和XML兩種形式的網站地圖就生成了。
四、網站地圖的提交
向Google提交網站地圖:
  https://www.google.com/webmasters/tools/login?hl=zh_CN
  1、進入這個網址,用你的Google帳戶登錄,然后添加你的網址;
  2、接下來按照Google的要求驗證你網站,你可以選擇html文件驗證。
  3、這時候,按照Google的要求,制作一個Google要求的文件名的html文件
  4、用FTP講這個html文件和你的xml格式的網站地圖文件一起傳到你網站的根目錄
  5、確認驗證,回到控制臺,添加你的地圖文件。很快,Google就會根據網站地圖文件來更新你的網站
向yahoo提交網站地圖:
  英文yahoo提交網址:
  
  首先用FTP講你的網站地圖傳到網站的根目錄。打開網址后,選擇Submit Your Site for Free: 用yahoo帳戶登錄,然后輸入你的網站地圖的URL就可以了。
  中文Yahoo的提交網址:
  
  這個操作和Google的差不多,登錄、驗證網站、提交網址地圖URL。
向MSN提交網站地圖Sitemap: 用URL直接提交:?u=http://your.domainname/sitemap.xml
這是向MSN直接提交網站地圖的后門URL
向ASK提交網站地圖Sitemap: 直接提交。?sitemap=http://your.domainname/sitemap.xml
向網店聯盟提交地址:
向百度Baidu提交網站地圖Sitemap: 沒辦法,現在百度不支持Sitemap。但可通過來提交你的網址。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人精品在线观看| 国产欧美日韩91| 91久久久久久久| 久久久久久久97| 久久艳片www.17c.com| 主播福利视频一区| 91爱爱小视频k| 欧美日本啪啪无遮挡网站| 黄色成人在线免费| 国产成人精品综合久久久| 亚洲国产精品久久久久秋霞不卡| 亚洲欧美日韩精品久久亚洲区| 91av成人在线| 97在线免费观看| 96精品久久久久中文字幕| 91精品国产高清| 欧美国产日韩xxxxx| 91精品综合久久久久久五月天| 亚洲男人的天堂在线播放| 在线观看欧美视频| 国模极品一区二区三区| 日韩欧美精品中文字幕| 综合国产在线视频| 韩剧1988在线观看免费完整版| 欧美视频一区二区三区…| 日韩精品免费看| 91精品国产高清自在线看超| 亚洲激情在线视频| 精品欧美aⅴ在线网站| 国产日本欧美一区二区三区| 国产成人aa精品一区在线播放| 性色av一区二区三区红粉影视| 国产精品国产三级国产专播精品人| 精品成人久久av| 欧美日韩免费观看中文| 欧美精品久久久久久久| 成人性生交大片免费看小说| 久久露脸国产精品| 国产亚洲人成网站在线观看| 亚洲国产欧美日韩精品| 伊人伊人伊人久久| 久久久久久久国产精品视频| 亚洲区中文字幕| 久久久噜噜噜久久| 日韩欧美在线看| 成人黄色网免费| 日韩精品免费综合视频在线播放| 亚洲成人精品视频| 狠狠综合久久av一区二区小说| 日韩欧美在线国产| 欧美日韩在线看| 日韩电影免费观看中文字幕| 国产成人精品免高潮在线观看| 国产精品免费一区二区三区都可以| 国产成人涩涩涩视频在线观看| 高清视频欧美一级| 色久欧美在线视频观看| 久久久在线视频| 中国人与牲禽动交精品| 亚洲午夜未满十八勿入免费观看全集| 第一福利永久视频精品| 久久久久久久影视| 伊人青青综合网站| 欧美电影在线播放| 美女av一区二区| 国产精品视频yy9099| 色偷偷综合社区| 亚洲国产精品久久久| 欧美黑人国产人伦爽爽爽| 日韩av电影在线播放| 日韩av片免费在线观看| 一区二区三区四区在线观看视频| 91亚洲精品一区二区| 中文字幕精品久久| 精品久久久久久电影| 国产精品日韩在线观看| 国产在线精品播放| 精品国产一区久久久| 欧美裸体男粗大视频在线观看| 欧美性xxxx18| 亚洲欧美日韩国产中文| 亚洲三级黄色在线观看| 成人美女免费网站视频| 欧美疯狂xxxx大交乱88av| 国自产精品手机在线观看视频| 亚洲天堂av在线免费观看| 久99九色视频在线观看| 福利视频第一区| 国产一区二区三区在线播放免费观看| 亚洲欧美日韩天堂| 亚洲a区在线视频| 国产一区二区三区三区在线观看| 国产黑人绿帽在线第一区| 欧美激情欧美激情在线五月| 久久综合久久美利坚合众国| 亚洲日韩中文字幕在线播放| 欧美做受高潮电影o| 亚洲色图第一页| 精品中文字幕乱| 2019av中文字幕| 亚洲天堂第一页| 午夜精品久久久99热福利| 97精品久久久中文字幕免费| 91精品视频播放| 欧美在线观看网站| 欧美大片va欧美在线播放| 国产精品久久久久久久久久久久| 亚洲成人xxx| 久久久久久成人精品| 国产综合在线看| 亚洲国产欧美在线成人app| 亚洲91精品在线观看| 亚洲欧美激情精品一区二区| 国产精品久久久久久亚洲调教| 国产精品高潮呻吟视频| 日韩美女中文字幕| 中文字幕精品在线| 日韩中文在线中文网在线观看| 久久久亚洲天堂| 色偷偷9999www| 久久乐国产精品| 久久久久久午夜| 麻豆国产va免费精品高清在线| 国产精品永久在线| 97色在线播放视频| 国产精品吹潮在线观看| 亚洲精品国产精品国产自| 91国产一区在线| 久久精品国产2020观看福利| 日韩男女性生活视频| 欧美尺度大的性做爰视频| 一区二区欧美亚洲| 色妞在线综合亚洲欧美| 在线性视频日韩欧美| 欧美电影免费观看高清完整| 国产男女猛烈无遮挡91| 日韩美女av在线免费观看| 久久久久久久91| 国产成人久久久精品一区| 激情久久av一区av二区av三区| 日韩在线观看免费av| 伊人久久男人天堂| 98精品国产自产在线观看| 中国日韩欧美久久久久久久久| 北条麻妃99精品青青久久| 欧美极品xxxx| 欧美性猛交xxx| 成人h片在线播放免费网站| 欧美视频第一页| 中文字幕av一区中文字幕天堂| 日韩经典第一页| 亚洲一区av在线播放| 精品美女久久久久久免费| 欧美一区三区三区高中清蜜桃| 日本午夜在线亚洲.国产| 国产精品91久久久久久| 日韩欧美一区二区三区| 亚洲精品国产综合久久| 国产精品美女www爽爽爽视频| 日韩毛片在线观看| 亚洲精品福利资源站| 欧美国产日韩免费| 国产精品视频区| 色综合久久88|