Если вы ищете что-то нестандартное, на RIAForge есть несколько проектов, быстрый поиск выдал эти два, но я предполагаю, что вы могли бы найти больше:
http://cfrss.riaforge.org/
http://rssville.riaforge.org/
Если вы готовы создать свой собственный канал (я знаю, что вы сказали, что не предпочитаете его), не могли бы вы просто запросить ленту следующим образом:
<cfhttp
url = "http://example.com"
resolveurl="no"
throwOnError = "yes"
timeout = "10" >
</cfhttp>
и проанализируйте результаты:
<cfset feedData = CFHTTP.FileContent>
<cfset xmlData = XMLParse(feedData)>
Переберите:
<cfset result = queryNew("title,description")>
<cfset items = xmlSearch(xmlData,"//*[local-name() = 'item']")>
<cfloop index="x" from="1" to="#arrayLen(items)#">
<cfif structKeyExists(items[x],"title")>
<cfset node.title = items[x].title.XmlText>
<cfelse>
<cfset node.title = "">
</cfif>
<cfif structKeyExists(items[x],"description")>
<cfset node.description = items[x].description.XmlText>
<cfelse>
<cfset node.description = "">
</cfif>
<cfset queryAddRow(result)>
<cfset querySetCell(result,"title",node.title)>
<cfset querySetCell(result,"description",node.description)>
</cfloop>
Выход:
<cfoutput query="result">
<ul>
<li><strong>#title#</strong> - #description#</li>
</ul>
</cfoutput>
Очевидно, непроверенная, но тем не менее идея. Использовал что-то подобное, чтобы получить мои последние вкусные закладки. Что касается кэширования, есть несколько разных способов справиться с этим. Я бы, вероятно, запустил запланированную задачу, чтобы попасть в этот файл и записать вывод в отдельный файл, который включен. Я уверен, что есть лучшие способы, но это быстро и грязно, имхо.
person
jyoseph
schedule
11.08.2009