gpt4 book ai didi

python - Psycopg DB - 向代码添加持久性时出错

转载 作者:太空狗 更新时间:2023-10-30 01:13:30 26 4
gpt4 key购买 nike

我正在处理 Udacity 的在线项目。我正在使用他们配置的 vagrant 来运行包含数据库的服务器。不幸的是,当我试图赋予代码持久性时,服务器每次都会返回错误。我是 python 的新手,所以请原谅任何明显的错误。

这里是错误:

Serving HTTP on port 8000...
Traceback (most recent call last):
File "/usr/lib/python2.7/wsgiref/handlers.py", line 85, in run
self.result = application(self.environ, self.start_response)
File "forum.py", line 95, in Dispatcher
return DISPATCH[page](env, resp)
File "forum.py", line 68, in Post
length = int(env.get('CONTENT_LENGTH', 0))
ValueError: invalid literal for int() with base 10: ''
10.0.2.2 - - [06/Jan/2016 04:44:16] "GET /post HTTP/1.1" 500 59
10.0.2.2 - - [06/Jan/2016 04:44:16] "GET /favicon.ico HTTP/1.1" 404 22

这是我在 forumdb.py 中更改的代码:

#
# Database access functions for the web forum.
#

import psycopg2

## Database connection

def GetAllPosts():
DB = psycopg2.connect("dbname=forum")
c = DB.cursor()
c.execute("SELECT time, content FROM posts ORDER BY time DESC")
posts = ({'content': str(row[1]), 'time': str(row[0])}
for row in c.fetchall())

# This returns a dictionary -- returning just c.fetchall() will return a list of tuples

DB.close()
return posts

def AddPost(content):
DB = psycopg2.connect("dbname=forum")
c = DB.cursor()
c.execute("INSERT INTO posts (content) values ('%s')" % content)
DB.commit()
DB.close()

forum.py - 此文件呈现 html,从数据库中获取数据:http://pastebin.com/ZiHWiiwr

请帮忙!

最佳答案

您正在使用 length = int(env.get('CONTENT_LENGTH', 0)) (forum.py:68) 查询 WSGI 环境。我刚刚运行了一个示例 WSGI 服务器(示例代码取自 python 文档),它根据请求输出所有可用的环境变量:

from wsgiref.util import setup_testing_defaults
from wsgiref.simple_server import make_server

# A relatively simple WSGI application. It's going to print out the
# environment dictionary after being updated by setup_testing_defaults
def simple_app(environ, start_response):
setup_testing_defaults(environ)

status = '200 OK'
headers = [('Content-type', 'text/plain')]

start_response(status, headers)

ret = ["%s: %s\n" % (key, value)
for key, value in environ.iteritems()]
return ret

httpd = make_server('', 8000, simple_app)
print "Serving on port 8000..."
httpd.serve_forever()

我在查询测试服务器时得到的输出是(在许多其他变量中):

SERVER_PORT: 8000
CONTENT_LENGTH:
GLADE_CATALOG_PATH: :

您会看到 CONTENT_LENGTH 变量为空。这似乎也是您的应用程序的情况。

如果现在使用 env.get('CONTENT_LENGTH', 0) 查询 env-dictionary,则 CONTENT_LENGTH-key 实际上是已找到,但它的值为空字符串 - 这就是 get() 方法返回 '' 而不是您指定的默认值 0 的原因。

由于无法将空字符串转换为 int,因此您会收到 ValueError。

try catch 异常,您的代码应该可以工作:

try:
length = int(env.get("CONTENT_LENGTH", 0))
except ValueError:
length = 0

关于python - Psycopg DB - 向代码添加持久性时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34625867/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com