天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

基于C# 網(wǎng)站地圖制作

1、 我們的網(wǎng)站是用C#開發(fā)的,我們采用數(shù)據(jù)庫存儲所有文章信息。所以我們的文章都是動態(tài)地從數(shù)據(jù)庫中提取出來的。這點很不利于蜘蛛的順藤摸瓜。
2、 這點嘛,嘿嘿,就有些勉強了。做個網(wǎng)站地圖,可以讓用戶對敝網(wǎng)站的內(nèi)容一目了然,能起到很好的導航作用。
鑒于上述原因,于是乎,俺就決定為俺地“赤兔英語網(wǎng)”做一個網(wǎng)站地圖。由于Google等搜索引擎所需的網(wǎng)站地圖必須是XML文件,所以俺決定做網(wǎng)頁形式和XML形式兩種網(wǎng)站地圖。我們的網(wǎng)站是用C#開發(fā)的,當然是使用C#語言來編寫俺地網(wǎng)站地圖了,赫赫。
首先,我們來看看,我們的網(wǎng)站地圖該怎么生成,怎么展現(xiàn)。簡單思考之后,我決定這樣做。網(wǎng)站首頁的菜單中添加“網(wǎng)站地圖”選項,其鏈接著網(wǎng)頁形式的網(wǎng)站地圖,頁面名字為sitemap.html;首頁的底部也添加鏈接“網(wǎng)站地圖”,其鏈接著XML格式的網(wǎng)站地圖,頁面名字為sitemap.xml。這兩個頁面生成程序在后臺添加。設置一個按鈕,管理員在一段時間內(nèi)點擊該按鈕,直接生成這兩個文件,放在網(wǎng)站的根目錄下,供客戶端隨時調(diào)用。
下面,我們來看看生成網(wǎng)站地圖的代碼的具體實現(xiàn)。為了文章可讀性,我們從頂向下來對code實現(xiàn)過程做以介紹。
一、網(wǎng)站地圖的頂層設計
頂層的網(wǎng)站地圖生成按鈕的code為:
protected void BtnGenerateSitemap_Click(object sender, EventArgs e)
{
createHtmlSitemap();
createXMLSitemap();
WebUtility.ResponseScript("網(wǎng)站地圖生成完畢!",0);
}
上面code一目了然,createHtmlSitemap()用來生成html網(wǎng)站地圖,createXMLSitemap()用來生成XML網(wǎng)站地圖。
二、Html網(wǎng)站地圖的生成
我們先介紹Html網(wǎng)站地圖的生成。createHtmlSitemap()的code如下:
public void createHtmlSitemap()
{
FileInfo HtmlFile = null;
StreamWriter WriteHtmlFile = null;
string FilePath = Server.MapPath("sitemap.html");//獲取html文件路徑及名稱
HtmlFile = new FileInfo(FilePath);//創(chuàng)建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>赤兔英語網(wǎng) 網(wǎng)站地圖</title>");
WriteHtmlFile.WriteLine("</head>");
WriteHtmlFile.WriteLine("<body>");
getHtmlSitemapData(WriteHtmlFile);
WriteHtmlFile.WriteLine("</body>");
WriteHtmlFile.WriteLine("</html>");
WriteHtmlFile.Close();
}
上述code創(chuàng)建了html文件sitemap.html,并使用對象StreamWriter書寫了sitemap.html。函數(shù)getHtmlSitemapData(WriteHtmlFile)完成了sitemap.html正文部分的組織。
需要注意的是,如果網(wǎng)站地圖中有中文,必須將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("<table border='1' width='1000px'cellspacing='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 style='font-size:15px;font-weight:bold;' target='_blank' href='http://www.chituwang.com/Article/index.ASPx?parentid=" + 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 style='width:200px'>");
writerFile.WriteLine("<a target='_blank' href='http://www.chituwang.com/Article/index.ASPx?articleid=" + 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網(wǎng)站地圖的生成
XML網(wǎng)站地圖的生成與Html不同點在于,Google等搜索引擎對這種網(wǎng)站地圖的格式有嚴格的要求,必須遵守,否則不會被他們承認。具體xml文件格式可參考http://www.chituwang.com/Article/WZJS/detail.ASPx?articleid=18092
createXMLSitemap()函數(shù)的實現(xiàn)如下:
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()的實現(xiàn)如下:
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();
}
}
通過上面兩個小節(jié)的介紹,網(wǎng)頁和XML兩種形式的網(wǎng)站地圖就生成了。
四、網(wǎng)站地圖的提交
向Google提交網(wǎng)站地圖:
  https://www.google.com/webmasters/tools/login?hl=zh_CN
  1、進入這個網(wǎng)址,用你的Google帳戶登錄,然后添加你的網(wǎng)址;
  2、接下來按照Google的要求驗證你網(wǎng)站,你可以選擇html文件驗證。
  3、這時候,按照Google的要求,制作一個Google要求的文件名的html文件
  4、用FTP講這個html文件和你的xml格式的網(wǎng)站地圖文件一起傳到你網(wǎng)站的根目錄
  5、確認驗證,回到控制臺,添加你的地圖文件。很快,Google就會根據(jù)網(wǎng)站地圖文件來更新你的網(wǎng)站
向yahoo提交網(wǎng)站地圖:
  英文yahoo提交網(wǎng)址:
  http://search.yahoo.com/info/submit.html
  首先用FTP講你的網(wǎng)站地圖傳到網(wǎng)站的根目錄。打開網(wǎng)址后,選擇Submit Your Site for Free: 用yahoo帳戶登錄,然后輸入你的網(wǎng)站地圖的URL就可以了。
  中文Yahoo的提交網(wǎng)址:
  http://sitemap.cn.yahoo.com/mysites
  這個操作和Google的差不多,登錄、驗證網(wǎng)站、提交網(wǎng)址地圖URL。
向MSN提交網(wǎng)站地圖Sitemap: 用URL直接提交:http://api.moreover.com/ping?u=http://your.domainname/sitemap.xml
這是向MSN直接提交網(wǎng)站地圖的后門URL
向ASK提交網(wǎng)站地圖Sitemap: 直接提交。http://submissions.ask.com/ping?sitemap=http://your.domainname/sitemap.xml
向網(wǎng)店聯(lián)盟提交地址:http://www.dianmeng.com/
向百度Baidu提交網(wǎng)站地圖Sitemap: 沒辦法,現(xiàn)在百度不支持Sitemap。但可通過http://www.baidu.com/search/url_submit.html來提交你的網(wǎng)址。

AspNet技術基于C# 網(wǎng)站地圖制作,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品女主播主要上线 | 老板揉搓秘书丰满大乳 | 法国剧丝袜情版h级在线电影 | 日本国产成人精品无码区在线网站 | 国产曰批试看免费视频播放免费 | 国产乱人精品视频AV麻豆 | 欧美日韩北条麻妃一区二区 | 亚洲精品拍拍央视网出文 | 免费观看视频成人国产 | 国产视频a在线观看v | 超碰caopro熟女m超碰分类 | 国产97视频在线观看 | 飘雪在线观看免费完整版 | 亚洲欧美日韩精品久久奇米色影视 | 美女胸被男子强捏视频 | 国产三级在线观看视频 | 午夜福利电影网站鲁片大全 | av视频在线免播放观看 | 久久青青草原精品国产软件 | 乱码中字在线观看一二区 | 国产WW高清大片免费看 | 99精品视频在线免费观看 | 伊人网综合网 | 日日射日日操 | 午夜视频无码国产在线观看 | 99re5久久热在线 | 国产呦精品一区二区三区网站 | 久热久热精品在线观看 | 日本综艺大尺度无删减版在线 | 精品亚洲麻豆1区2区3区 | 亚洲精品在线影院 | 最近2019中文字幕免费版视频 | 受喷汁红肿抽搐磨NP双性 | 快播理论片 | 亚洲男人的天堂久久精品麻豆 | 欧美色图一区二区三区 | 金发欧美一区在线观看 | 漂亮的av女演员 | 使劲别停好大好深好爽动态图 | 李亚男三级 | 午夜影院一区二区三区 |