ããŒã¿ããŒã¹ãã Web ãµã€ãã® RSS ãã£ãŒããäœæãã
Claytabaseã«ãããŠã§ããµã€ãã®ãã¶ã€ã³
ãã®ãŠã©ãŒã¯ã¹ã«ãŒãå®è¡ããã«ã¯ã ãã¹ãç°å¢ã®èšå®ã«é¢ããã¬ã€ãã«åŸãããããŒãºã«åãããŠã³ãŒãã調æŽããŠãã ããã
çµéšã¬ãã« - äžçŽ
çŽ
RSS ã¯ããµã€ãã«å ããããæŽæ°ã«é¢ããæ å ±ãæäŸããæšæºåããã XML ããŒã¹ã®ãã¡ã€ã«ã§ãã
ãããã¯ãå€åºããŠãŠãŒã¶ãŒã®ããŸããŸãªãæ°ã«å ¥ãã®ãµã€ãã®å€æŽããã§ãã¯ããäœãæ°ããããšãéç¥ããããŸããŸãªãã¥ãŒã¹éçŽã¢ããªã±ãŒã·ã§ã³ã§äœ¿çšã§ããŸãã
Web ã®éçºã®æ§è³ªäžããããã«ç°ãªã圢åŒãããã€ããããŸãã以äžã®åœ¢åŒã¯ Atom 2.0 ã®ãã®ã§ãã
Sample RSS File
<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"> <channel> <atom:link href="https://ja.claytabase.com/" rel="self" type="application/rss+xml"/> <title/> <link/> <copyright>Copyright Claytabase 2012</copyright> <language/> <description/> <item> <title>Create an RSS Feed for your Website In ASP NET and SQL Server</title> <description>Easy way to create an RSS Feed for your Website in ASP.NET in VB.NET or C#.NET</description> <link>https://www.claytabase.co.uk/Academy/Learning-Web-Design/Using-ASP-NET/Create-an-RSS-Feed-for-your-Website-In-ASP-NET-and-SQL-Server</link> <pubDate>Wed, 15 Dec 2021 09:37:24 GMT</pubDate> <category>monthly</category> <guid>https://www.claytabase.co.uk/A7038527-90D0-4214-8C65-3A2BD831F141</guid> </item> <item> <title>CSS Styling for AJAX Accordion Control</title> <description>Some simple CSS styling rules for an AJAX Accordion Control</description> <link>https://www.claytabase.co.uk/Academy/Learning-Web-Design/Using-CSS/CSS-Styling-for-AJAX-Accordion-Control</link> <pubDate>Tue, 14 Dec 2021 07:00:00 GMT</pubDate> <category>monthly</category> <guid>https://www.claytabase.co.uk/0DB19797-5B3A-45F0-B3E6-2A8080DA60EE</guid> </item> </channel></rss>
USE ClaytabaseAcademyGOCREATE TABLE RSSPages(PageGUID UNIQUEIDENTIFIER CONSTRAINT DF_PageGUID DEFAULT NEWSEQUENTIALID() CONSTRAINT PK_PageGUID PRIMARY KEY,PageTitle NVARCHAR(200),PageDescription NVARCHAR(500),PageURL NVARCHAR(500),PageLanguage NVARCHAR(2),PageDate DATETIME,ChangeFrequency NVARCHAR(20))GOINSERT INTO RSSPages(PageTitle,PageDescription,PageURL,PageDate,PageLanguage,ChangeFrequency)SELECT 'Create an RSS Feed for your Website from a database','Walkthrough: Creating an RSS Feed for your Website in ASP.NET using VB.NET or C#.NET from an SQL Server database','https://www.claytabase.co.uk/Academy/Learning-Web-Design/Using-ASP-NET/Create-an-RSS-Feed-for-your-Website-In-ASP-NET-and-SQL-Server','2021-12-15 10:00:00','en','Weekly'INSERT INTO RSSPages(PageTitle,PageDescription,PageURL,PageDate,PageLanguage,ChangeFrequency)SELECT 'CSS Styling for AJAX Accordion Control','Some simple CSS styling rules for an AJAX Accordion Control','https://www.claytabase.co.uk/Academy/Learning-Web-Design/Using-CSS/CSS-Styling-for-AJAX-Accordion-Control',GETDATE(),'en','Monthly'INSERT INTO RSSPages(PageTitle,PageDescription,PageURL,PageDate,PageLanguage,ChangeFrequency)SELECT 'We''ll take the strain while you do what you are good at','A Multi-National team with over 20 years of experience specialising in Web, Database, Cloud services and bespoke Business Management Software','https://www.claytabase.co.uk/',GETDATE(),'en','Daily'INSERT INTO RSSPages(PageTitle,PageDescription,PageURL,PageDate,PageLanguage,ChangeFrequency)SELECT 'Wir nehmen Ihnen die Anstrengung, wÀhrend Sie das tun, was Sie gut können','Ein multinationales Team mit ÃŒber 20 Jahren Erfahrung, das sich auf Web-, Datenbank-, Cloud-Dienste und maÃgeschneiderte Business-Management-Software spezialisiert hat','https://de.claytabase.com/',GETDATE(),'de','Daily'INSERT INTO RSSPages(PageTitle,PageDescription,PageURL,PageDate,PageLanguage,ChangeFrequency)SELECT 'Nos esforzaremos mientras haces lo que se te da bien','Un equipo multinacional con más de 20 años de experiencia especializado en Web, bases de datos, servicios en la nube y software de gestión empresarial a medida.','https://de.claytabase.com/',GETDATE(),'es','Daily'GOCREATE PROC GetRSSPages(@Language NVARCHAR(2)) AS BEGINSELECT * FROM RSSPagesWHERE PageLanguage=@LanguageENDGOEXEC GetRSSPages 'de'
Visual Studio ã§æ°ãã Web ãã©ãŒã ãè¿œå ãã
VS ã§ãPages ãã©ã«ããŒãå³ã¯ãªãã¯ãã[è¿œå ]ã[Web ãã©ãŒã ] ã®é ã«éžæããŠãWeb ãã©ãŒã ãè¿œå ããŸãã
ã³ãŒã ããã€ã³ãã«é²ã¿ããã®ã§ãæ°ããããŒãžãå³ã¯ãªãã¯ã㊠[ã³ãŒãã®è¡šç€º] ãéžæããŸãã
ã³ãŒãã¯ããããå®éãããã¯ããã«è€éã«èŠããã®ã§ããã®æ©èœãèŠãŠã¿ãŸãããã
ãŸããSQL ãš XML ã®åå空éãã€ã³ããŒãããŸãã
次ã«ãããŒã¿ããŒã¹ãžã®æ¥ç¶ãèšå®ãããŸããããã¯ããã®ã€ã³ã¹ã¿ã³ã¹ã® Web æ§æããååŸãããŸãã
VB
Imports System.Data.SqlClientImports System.XmlPublic Class RSS Inherits System.Web.UI.Page Dim con As New SqlConnection(ConfigurationManager.ConnectionStrings("SqlConnection").ConnectionString) Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load Dim RSSLanguage As String = "en" Dim BaseURL As String = "https://www.claytabase.co.uk/" Dim MyTitle As String = "Academy Title" Dim MyDescr As String = "Academy Description"
'Clear any previous output from the buffer Response.ClearContent() Response.ContentType = "text/xml" Response.Charset = "Utf-8" Dim xtwFeed As XmlTextWriter = New XmlTextWriter(Response.OutputStream, Encoding.UTF8) xtwFeed.WriteStartDocument() 'The mandatory rss tag xtwFeed.WriteStartElement("rss") xtwFeed.WriteAttributeString("version", "2.0") xtwFeed.WriteAttributeString("xmlns:atom", "https://www.w3.org/2005/Atom") 'The channel tag contains RSS feed details xtwFeed.WriteStartElement("channel") xtwFeed.WriteRaw("<atom:link href="https://ja.claytabase.com/"" & BaseURL & RSSLanguage & "/rss"" rel=""self"" type=""application/rss+xml"" />") xtwFeed.WriteElementString("title", MyTitle) xtwFeed.WriteElementString("link", BaseURL) xtwFeed.WriteElementString("copyright", "Copyright Claytabase 2012") xtwFeed.WriteElementString("language", RSSLanguage) xtwFeed.WriteElementString("description", MyDescr)
'Objects needed for connecting to the SQL Using com As New SqlCommand("EXEC GetRSSPages '" + RSSLanguage + "'", con) If con.State = ConnectionState.Closed Then con.Open() Else End If Using dr = com.ExecuteReader() 'Loop through the content of the database and add them to the RSS feed While dr.Read() xtwFeed.WriteStartElement("item") xtwFeed.WriteElementString("title", dr.Item("PageTitle").ToString()) xtwFeed.WriteElementString("description", dr.Item("PageDescription").ToString()) xtwFeed.WriteElementString("link", dr.Item("PageURL").ToString()) xtwFeed.WriteElementString("pubDate", Format(dr.Item("PageDate"), "ddd, dd MMM yyyy hh:mm:ss") + " GMT") xtwFeed.WriteElementString("category", dr.Item("ChangeFrequency").ToString()) xtwFeed.WriteElementString("guid", BaseURL + "/" + dr.Item("PageGUID").ToString()) xtwFeed.WriteEndElement() End While End Using End Using 'Close all tags xtwFeed.WriteEndElement() xtwFeed.WriteEndElement() xtwFeed.WriteEndDocument() xtwFeed.Flush() xtwFeed.Close() Response.End() End SubEnd Class
C#
using System.Text;using Microsoft.VisualBasic;using System.Data.SqlClient;using System.Xml;public class RSS : System.Web.UI.Page{ private SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings("SqlConnection").ConnectionString); protected void Page_Load(object sender, System.EventArgs e) { string RSSLanguage = "en"; string BaseURL = "https://www.claytabase.co.uk/"; string MyTitle = "Academy Title"; string MyDescr = "Academy Description";
// Clear any previous output from the buffer System.Web.UI.Page.Response.ClearContent(); System.Web.UI.Page.Response.ContentType = "text/xml"; System.Web.UI.Page.Response.Charset = "Utf-8"; XmlTextWriter xtwFeed = new XmlTextWriter(System.Web.UI.Page.Response.OutputStream, Encoding.UTF8); xtwFeed.WriteStartDocument(); // The mandatory rss tag xtwFeed.WriteStartElement("rss"); xtwFeed.WriteAttributeString("version", "2.0"); xtwFeed.WriteAttributeString("xmlns:atom", "https://www.w3.org/2005/Atom"); // The channel tag contains RSS feed details xtwFeed.WriteStartElement("channel"); xtwFeed.WriteRaw("<atom:link href=\"" + BaseURL + RSSLanguage + "/rss\" rel=\"self\" type=\"application/rss+xml\" />"); xtwFeed.WriteElementString("title", MyTitle); xtwFeed.WriteElementString("link", BaseURL); xtwFeed.WriteElementString("copyright", "Copyright Claytabase 2012"); xtwFeed.WriteElementString("language", RSSLanguage); xtwFeed.WriteElementString("description", MyDescr);
// Objects needed for connecting to the SQL using (SqlCommand com = new SqlCommand("EXEC GetRSSPages '" + RSSLanguage + "'", con)) { if (con.State == ConnectionState.Closed) con.Open(); else { } using (var dr = com.ExecuteReader()) { // Loop through the content of the database and add them to the RSS feed while (dr.Read()) { xtwFeed.WriteStartElement("item"); xtwFeed.WriteElementString("title", dr.Item["PageTitle"].ToString()); xtwFeed.WriteElementString("description", dr.Item["PageDescription"].ToString()); xtwFeed.WriteElementString("link", dr.Item["PageURL"].ToString()); xtwFeed.WriteElementString("pubDate", Strings.Format(dr.Item["PageDate"], "ddd, dd MMM yyyy hh:mm:ss") + " GMT"); xtwFeed.WriteElementString("category", dr.Item["ChangeFrequency"].ToString()); xtwFeed.WriteElementString("guid", BaseURL + "/" + dr.Item["PageGUID"].ToString()); xtwFeed.WriteEndElement(); } } } // Close all tags xtwFeed.WriteEndElement(); xtwFeed.WriteEndElement(); xtwFeed.WriteEndDocument(); xtwFeed.Flush(); xtwFeed.Close(); System.Web.UI.Page.Response.End(); }}
ãŸãšã
ããŒãžã®èªã¿èŸŒã¿ããã³ãŒãã«ç§»ããŸããããã¯ãããå°ãã¯ãªãšã€ãã£ããªéšåã§ãã
ãã£ãŒã«ã RSSLanguage 㯠CMS ã§äœ¿çšãããåãªã¯ãšã¹ãã«äœ¿çšãããŠããèšèªãã·ã¹ãã ã«äŒããããŒã¹ URL ãå ¥åãããŸãããã®äŸã§ã¯ãããããéçãã£ãŒã«ãã«ããŸããã
次ã®æ°è¡ã®ã³ãŒãã§ã¯ããšã³ã³ãŒãã£ã³ã°ãšå¿çã¿ã€ããèšå®ããXML ã©ã€ã¿ãŒãéããå¿ èŠãªèŠåºããããã€ãèšå®ããŸãããããã¯ãã£ãã«å€æŽãããªããããæåã§èšå®ããŸããã
ããŒã¿ã®èªã¿åãã«ç§»ãããšãã§ããã®ã§ãæåã®ä»äºã¯ SQL ã³ãã³ããäœæããããšã§ãããã®å Žåãèšèªå ¥åã«å¿ããŠããŒã¿ããŒã¹ããå¿ èŠãªãã£ãŒã«ããè¿ãã¹ãã¢ã ããã·ãŒãžã£ãåŒã³åºãã ãã§ãã
次ã«ãSQL æ¥ç¶ãéããããŒã¿ããŒã¹ããã®çµæã»ãããã«ãŒãããããŒã¿ ãªãŒããŒã宣èšããŸãã
XML ã¿ã°ãåããã¥ã¡ã³ãã®ã¢ã€ãã ã§ããããšã¯æ¢ã«ããã£ãŠããã®ã§ãããã«éãããšãã§ããŸãã
次ã«ãå¿ èŠãªåé ç®ã«ããŒã¿ãå ¥åããæ¥ä»ãæ£ãã圢åŒã§ããããšã確èªããŠãããWriteEndElement ã䜿çšããŠã¿ã°ãéããŸãã
ããŒã¿ããã¹ãŠèªã¿åããããšãã³ãŒãã¯ããŒã¿ ãªãŒããŒãšæ¥ç¶ãéãã以åã«éããåèŠçŽ ã®çµäºã¿ã°ãæžã蟌ã¿ãŸãã
äœæããŠå ¬éããããå¿ ãW3C RSS Validator ã§ç¢ºèªããŠãã ããã
Claytabaseã«ãããŠã§ããµã€ãã®ãã¶ã€ã³
ããã¯ãåœç€Ÿã® Web ãµã€ã ãã¶ã€ã³ ãµãŒãã¹ã®äžéšã§ãããåžå Žã§æãé«éã§æé©åãããã·ã¹ãã ã® 1 ã€ã§ãã Ousia ã³ã³ãã³ã管çã·ã¹ãã ã³ãŒãããå€æŽãããã³ãŒãã®ã»ã¯ã·ã§ã³ã§ãã
ãããã¯ãçŽÂ£500ããå§ãŸããµã€ãã§å©çšã§ããŸã.