为Python博客生成XML / Feed

时间:2012-05-05 08:11:23

标签: python xml webapp2

我一直在尝试在我的博客中添加RSS源(webapp2应用程序 - Jinja2模板),这就是我所拥有的:

class XMLHandler(Handler):
    def get(self):
        posts = db.GqlQuery("SELECT * FROM Post WHERE is_draft = FALSE ORDER BY created DESC")
        self.render("xmltemplate.xml", posts=posts, mimetype='application/xml')

xmltemplate.xml如下所示:

<?xml version="1.0" encoding="utf-8"?>
<feed xmlns="http://www.w3.org/2005/Atom">
    <channel>
        <title>Blag</title>
        <link>http://www.blagonudacity.appspot.com/</link>
        <description>Yet Another Blag</description>
        {%for post in posts %}
        <entry>
            <title>{{post.subject}}></title>
            <link href="http://www.blagonudacity.appspot.com/post/{{ post.key().id()}}" rel="alternate" />
            <updated>{{post.created}}</updated>
            <author><name>Prakhar Srivastav</name></author>
            <summary type="html"> {{ post.content }} </summary>
        </entry>
        {%endfor%}
    </channel>
</feed>

迁移到相关网页/feeds/all.atom.xml时,我在浏览器中收到的内容  只是一个带有标记的html页面。它看起来不像XML页面在浏览器中的外观。我在这做错了什么? Here is the demo

1 个答案:

答案 0 :(得分:1)

我看到该页面的内容类型是text / html,这可能是一个问题,我建议您将其设置为text / xml(可以找到更多详细信息here

此外,它在很大程度上取决于浏览器显示的方式,我猜你使用的是chrome(像我一样),你提供的链接看起来就像一个网页,如果你在firefox中打开它,你会看到“实时书签” “样式页面,但条目不显示。我不确定这是因为你的标记有些问题还是firefox和atom feed的一些问题。

xml文件本身似乎没问题(使用w3 validator检查)。

UPDATE :好的,您的原子XML似乎有问题(它是有效的xml,如上所述)但是它似乎不是有效的Atom数据(根据{{ 3}})。 我试图在firefox中将它加入书签并且它不显示任何条目(就像上面提到的预览一样)。 所以我认为你应该看看原子饲料,例如feed validatorthis可以提供帮助。

我不太确定,但在查看XML时,我认为您可能会混淆Atom和Rss。