我的代码:
#!/bin/python
import os,sys
from datetime import datetime
from flask import Flask
from database import db_session,init_db
from models import Node
version = '0.1'
app = Flask(__name__)
@app.route("/")
def index():
return "hello"
@app.route("/add")
def add():
node = Node('test','test','this is a test',1)
db_session.add(node)
db_session.commit()
return 'is ok'
@app.teardown_request
def shutdown_session(exception=None):
print "Teardown 1 {0!r}".format(exception)
db_session.remove()
if __name__ == "__main__":
app.run(debug=True)
Run Code Online (Sandbox Code Playgroud)
我的models.py,这是一个简单的模型,只是一个节点
from sqlalchemy import Column,Integer,String,Text
from database import Base
class Node(Base):
__tablename__ = 'nodes'
id = Column(Integer, primary_key=True)
title = Column(String(300))
tagnames = Column(String(125))
body = Column(Text())
nodetype=Column('node_type',Integer(11))
def __init__(self,title=None,tagnames=None,body=None,nodetype=0):
self.title = title
self.tagnames = tagnames
self.body = body
self.nodetype = nodetype
def __repr__(self):
return '<Node %r>' % (self.title)
Run Code Online (Sandbox Code Playgroud)
我的database.py,我没有使用flask-sqlalchemy
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker
from sqlalchemy.ext.declarative import declarative_base
engine = create_engine('mysql://root:123456@127.0.0.1:3306/test', echo=True,convert_unicode=True)
db_session = scoped_session(sessionmaker(autocommit=False,autoflush=False,bind=engine))
Base = declarative_base()
Base.query = db_session.query_property()
def init_db():
import flaskq.models
Base.metadata.create_all(bind=engine,checkfirst=True)
Run Code Online (Sandbox Code Playgroud)
当我第一次请求“http://127.0.0.1:5000/add”时,此代码抛出:AttributeError: 'NoneType' object has no attribute 'request'
再次请求?一切正常。
显然您缺少一个应该具有 request 属性的对象。有可能,在您的添加方法中的某个地方您需要对请求对象/上下文的引用。(这真的是整个错误报告吗?部分错误报告很少有用!)我猜你在这里使用 django 库,也许Flask 与 SQLite3-Example可能对你有用。通过teardown_request,请求上下文会自动建立,这可能是它在第一次调用时失败的原因。
根据Context-Locals,有时需要一个显式的请求上下文(无论这意味着什么,我无法详细解释),也许以下内容会有所帮助:
from flask import request
...
def add():
with app.request_context(environ):
node = Node('test','test','this is a test',1)
db_session.add(node)
db_session.commit()
return 'is ok'
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9101 次 |
| 最近记录: |