Jak zalecałbyś obsługę źródeł danych RSS w ASP.NET MVC? Korzystasz z biblioteki innej firmy? Korzystasz z RSS w BCL? Po prostu tworzysz widok RSS, który renderuje XML? A może coś zupełnie innego?
Jak zalecałbyś obsługę źródeł danych RSS w ASP.NET MVC? Korzystasz z biblioteki innej firmy? Korzystasz z RSS w BCL? Po prostu tworzysz widok RSS, który renderuje XML? A może coś zupełnie innego?
Odpowiedzi:
Oto co polecam:
Gdy zmienisz typ zawartości na rss, będziesz chciał serializować dane do RSS (używając własnego kodu lub innej biblioteki) i napisać do odpowiedzi.
Utwórz akcję na kontrolerze, który chcesz zwrócić rss i ustaw typ zwracania jako RssResult. Pobierz dane z modelu na podstawie tego, co chcesz zwrócić.
Wtedy każde żądanie dotyczące tej akcji otrzyma rss dowolnych danych, które wybierzesz.
Jest to prawdopodobnie najszybszy i możliwy do ponownego użycia sposób zwrócenia odpowiedzi na żądanie w ASP.NET MVC.
base("application/rss+xml")
i uniknąć kroków 3 i 4. Zastępuje on ExecuteResult, ale nie jest to istotne. On również skróty dużo kodu typowo samodziałowego i wykorzystuje 3.5+ cechy SyndicateItem
, SyndicateFeed
oraz Rss20FeedFormatter
.
Platforma .NET udostępnia klasy, które obsługują syndykację: SyndicationFeed itp. Więc zamiast wykonywać renderowanie samodzielnie lub korzystać z innej sugerowanej biblioteki RSS, dlaczego nie pozwolić, aby framework się tym zajął?
Zasadniczo potrzebujesz tylko następującego niestandardowego ActionResult i jesteś gotowy do pracy:
public class RssActionResult : ActionResult
{
public SyndicationFeed Feed { get; set; }
public override void ExecuteResult(ControllerContext context)
{
context.HttpContext.Response.ContentType = "application/rss+xml";
Rss20FeedFormatter rssFormatter = new Rss20FeedFormatter(Feed);
using (XmlWriter writer = XmlWriter.Create(context.HttpContext.Response.Output))
{
rssFormatter.WriteTo(writer);
}
}
}
Teraz w akcji kontrolera możesz po prostu zwrócić:
return new RssActionResult() { Feed = myFeedInstance };
Pełna próbka znajduje się na moim blogu pod adresem http://www.developerzen.com/2009/01/11/aspnet-mvc-rss-feed-action-result/
Zgadzam się z Haackedem. Obecnie wdrażam moją witrynę / blog przy użyciu frameworka MVC i zdecydowałem się na proste podejście do tworzenia nowego widoku dla RSS:
<%@ Page ContentType="application/rss+xml" Language="C#" AutoEventWireup="true" CodeBehind="PostRSS.aspx.cs" Inherits="rr.web.Views.Blog.PostRSS" %><?xml version="1.0" encoding="utf-8"?>
<rss version="2.0">
<channel>
<title>ricky rosario's blog</title>
<link>http://<%= Request.Url.Host %></link>
<description>Blog RSS feed for rickyrosario.com</description>
<lastBuildDate><%= ViewData.Model.First().DatePublished.Value.ToUniversalTime().ToString("r") %></lastBuildDate>
<language>en-us</language>
<% foreach (Post p in ViewData.Model) { %>
<item>
<title><%= Html.Encode(p.Title) %></title>
<link>http://<%= Request.Url.Host + Url.Action("ViewPostByName", new RouteValueDictionary(new { name = p.Name })) %></link>
<guid>http://<%= Request.Url.Host + Url.Action("ViewPostByName", new RouteValueDictionary(new { name = p.Name })) %></guid>
<pubDate><%= p.DatePublished.Value.ToUniversalTime().ToString("r") %></pubDate>
<description><%= Html.Encode(p.Content) %></description>
</item>
<% } %>
</channel>
</rss>
Aby uzyskać więcej informacji, sprawdź (bezwstydna wtyczka) http://rickyrosario.com/blog/creating-an-rss-feed-in-asp-net-mvc
Kolejnym szalonym podejściem, ale ma swoją zaletę, jest użycie normalnego widoku .aspx do renderowania RSS. W swojej metodzie akcji wystarczy ustawić odpowiedni typ zawartości. Jedną z zalet tego podejścia jest to, że łatwo jest zrozumieć, co jest renderowane i jak dodawać niestandardowe elementy, takie jak geolokalizacja.
Z drugiej strony, inne wymienione podejścia mogą być lepsze, po prostu ich nie używałem. ;)
Dostałem to od Erana Kampfa i wideo Scotta Hanselmana (zapomniałem linku), więc różni się tylko nieznacznie od niektórych innych postów tutaj, ale mam nadzieję, że jest pomocny i skopiuj wklej gotowy jako przykładowy kanał rss.
using System;
using System.Collections.Generic;
using System.ServiceModel.Syndication;
using System.Web;
using System.Web.Mvc;
using System.Xml;
namespace MVC3JavaScript_3_2012.Rss
{
public class RssFeed : FileResult
{
private Uri _currentUrl;
private readonly string _title;
private readonly string _description;
private readonly List<SyndicationItem> _items;
public RssFeed(string contentType, string title, string description, List<SyndicationItem> items)
: base(contentType)
{
_title = title;
_description = description;
_items = items;
}
protected override void WriteFile(HttpResponseBase response)
{
var feed = new SyndicationFeed(title: this._title, description: _description, feedAlternateLink: _currentUrl,
items: this._items);
var formatter = new Rss20FeedFormatter(feed);
using (var writer = XmlWriter.Create(response.Output))
{
formatter.WriteTo(writer);
}
}
public override void ExecuteResult(ControllerContext context)
{
_currentUrl = context.RequestContext.HttpContext.Request.Url;
base.ExecuteResult(context);
}
}
}
A kod kontrolera ...
[HttpGet]
public ActionResult RssFeed()
{
var items = new List<SyndicationItem>();
for (int i = 0; i < 20; i++)
{
var item = new SyndicationItem()
{
Id = Guid.NewGuid().ToString(),
Title = SyndicationContent.CreatePlaintextContent(String.Format("My Title {0}", Guid.NewGuid())),
Content = SyndicationContent.CreateHtmlContent("Content The stuff."),
PublishDate = DateTime.Now
};
item.Links.Add(SyndicationLink.CreateAlternateLink(new Uri("http://www.google.com")));//Nothing alternate about it. It is the MAIN link for the item.
items.Add(item);
}
return new RssFeed(title: "Greatness",
items: items,
contentType: "application/rss+xml",
description: String.Format("Sooper Dooper {0}", Guid.NewGuid()));
}