0

これまでに Udacity で学んだスキルを使用するために、単純なブログ アプリケーションを構築しようとしています。ただし、データベースからデータを取得してユーザーに表示するのに問題があります。現在、私のブログには、ユーザーが送信したばかりの投稿を表示するパーマリンクと、最新の 10 件の投稿を降順で表示するメインのブログ ページがあります。しかし、投稿を送信すると、投稿はデータベースに正常に保存され、パーマリンクにリダイレクトされます。ただし、送信したばかりの投稿ではなく、空白のページしか表示されません。

また、メインのブログ ページに戻ると、ユーザーが送信したすべての投稿ではなく、次のように表示されます。

ここに画像の説明を入力

主な Python コードは次のとおりです。

import os
import re
import webapp2
import jinja2
from string import letters
from google.appengine.ext import db

template_dir = os.path.join(os.path.dirname(__file__), 'templates')
jinja_env = jinja2.Environment(loader = jinja2.FileSystemLoader(template_dir),     autoescape=True)

def render_str(template, **params):
    t = jinja_env.get_template(template)
    return t.render(params)

class Handler(webapp2.RequestHandler):
    def write(self, *a, **kw):
        self.response.out.write(*a, **kw)

    def render_str(self, template, **params):
        return render_str(template, **params)

    def render(self, template, **kw):
        self.write(self.render_str(template, **kw))

def render_post(response, post):
    response.out.write('<b>' + post.subject + '</b><br>')
    response.out.write(post.content)

def post_key(name = "dad"):
    return db.Key.from_path('blog', name)

class Blogger(db.Model):
    name = db.StringProperty()
    content = db.TextProperty()
    created = db.DateTimeProperty(auto_now_add = True)

    def render(self):
        self._render_text = self.content.replace('\n', '<br>')
        return render_str("post.html", p = self)

class MainPage(Handler):
    def get(self):
        self.response.write("Visit our blog")

class BlogHandler(Handler):
    def get(self):
        posts = db.GqlQuery("SELECT * FROM Blogger order by created desc")
        self.render("frontblog.html", posts = posts)    

class SubmitHandler(Handler):
    def get(self):
        self.render("temp.html")    
    def post(self):
        name = self.request.get("name")
        content = self.request.get("content")
        if name and content:
            a = Blogger(parent = post_key(), name = name, content = content)
            a.put()
            self.redirect('/blog/%s' % str(a.key().id()))
        else:
            error = "Fill in both the columns!"
            self.render("temp.html", name = name, content = content, error = error)        

class DisplayPost(Handler):
    def get(self, post_id):
        post_id = self.request.get("post_id")
        if post_id:
            po = Blogger.get_by_id(int(post_id), parent = post_key())
            if po:
                self.render("perma.html", po = po)   
            self.response.write("No")  


app = webapp2.WSGIApplication([('/', MainPage),
                          ('/blog', BlogHandler), 
                          ('/blog/submit', SubmitHandler),
                          (r'/blog/<post_id:([0-9]+)>', DisplayPost)], debug=True)

すべての HTML ページのベースとなる HTML コードは次のとおりです。

<!DOCTYPE html>
<html>
<head>
  <link type="text/css" rel="stylesheet" href="/static/main.css" />

  <title>CS 253 Blog</title>
</head>

<body>
  <a href="/blog" class="main-title">
    CS 253 Blog
  </a>

  <div id="content">
  {% block content %}
  {% endblock %}
  </div>
</body>

</html>

パーマリンク ページの HTML コードは次のとおりです。

{% extends "base.html" %}

{% block content %}
  {{po.render() | safe}}
{% endblock %}

ブログのフロントの HTML コード:

{% extends "base.html" %}

{% block content %}

  {% for p in posts %}
    {{ p.render() | safe }}
    <br><br>
  {% endfor %}

{% endblock %}

私はこれに2日以上苦労しています。ログにもバグはありません。問題に見えるのは?


編集:

以下の回答に基づいてソースコードを編集しました。ただし、まだ 404 エラーが発生します。

4

1 に答える 1