龙卷风抛出可以'完成后写()()

时间:2016-05-03 09:22:05

标签: python tornado tornado-motor

我有一个自定义身份验证的装饰器,并在每个get和post方法上添加进行身份验证,经过身份验证后,执行一些数据库查询和更新,但是当我使用motor生成update()时,throw()完成后无法写入错误

帐户/ utils.py:

def authentication(fun):
    """
    decorator for authenticating  whether a user is logged in or not

    :param fun:
    :return:
    """
    @tornado.gen.coroutine
    def wrapper(self, *args, **kwargs):
        db = self.application.settings['db']

        if kwargs['token'] != None:
            session = yield db.session.find_one({'token': kwargs['token']},{'uid'})
            if session != None:
                kwargs['uid'] = session['uid']
                raise gen.Return(fun(self, *args, **kwargs))
            else:
                self.write({'status':0,'message':'请登录',"data":{}})
        else:
            self.write({'status':0, 'message':'请登录', 'data':{}})
    return wrapper

wall.handlers.py:

@account.utils.authentication
    @gen.coroutine
    def post(self, *args, **kwargs):
        """
        post a new kuolie card
        :param args:
        :param kwargs:
        :return:
        """
        print('sss')
        db = self.settings['db']
        up = upyun.UpYun('kuolie-img', username='jinpeng', password='jinpengjinpeng')
        uid = kwargs['uid']
        request_data = json.loads(self.request.body)

        user_docs = dict(

        )
        if 'nickname' in request_data.keys():
            user_docs['nickname'] = request_data['nickname']
        if 'qq' in request_data.keys():
            user_docs['qq'] = request_data['qq']
        if 'phone' in request_data.keys():
            user_docs['phone'] = request_data['phone']
        if 'weibo' in request_data.keys():
            user_docs['weibo'] = request_data['weibo']
        if 'weixin' in request_data.keys():
            user_docs['weixin'] = request_data['weixin']
        if 'level' in request_data.keys():
            user_docs['level'] = request_data['level']
        if 'meta' in request_data.keys():
            user_docs['meta'] = request_data['meta']
        if 'avatar' in request_data.keys():
            user_docs['avatar'] = request_data['avatar']
        if 'gender' in request_data.keys():
            user_docs['gender'] = request_data['gender']
        if 'kuolietext' in request_data.keys():
            user_docs['kuolietext'] = request_data['kuolietext']
        if 'kuolieimage' in request_data.keys():
            user_docs['kuolieimage'] = request_data['kuolieimage']
        if 'kuolieaudio' in request_data.keys():
            user_docs['kuolieaudio'] = request_data['kuolieaudio']


        user_docs['time'] = int(time.time())
        result = yield db.user.update({'uid': uid}, {'$set': user_docs })
        print result
        if result['updatedExisting'] == True:
            print('true')
            self.write({'status':1,'message':'添加成功','data':{}})

当邮件请求到达时,装饰者验证用户,如果经过验证,则进行更新,但是有错误:

  

[E 160503 17:16:00并发:124]未来的例外从未如此   检索:Traceback(最近一次调用最后一次):         文件“/Users/moonmoonbird/Documents/kuolie/lib/python2.7/site-packages/tornado/gen.py”,   第1017行,在运行中           yielded = self.gen.send(value)         文件“/Users/moonmoonbird/Documents/kuolie/kuolie/wall/handlers.py”,行   65,在得到           self.write({ '状态':1, '消息': '认证通过', “数据”:{ “一个”: 'B'}})         文件“/Users/moonmoonbird/Documents/kuolie/lib/python2.7/site-packages/tornado/web.py”,   第685行,写在           引发RuntimeError(“在finish()之后无法写()”)       RuntimeError:在finish()

之后无法写入()

我做错了,有人可以帮助我,提前谢谢。

1 个答案:

答案 0 :(得分:2)

在调用yield时,包装器需要使用fun,这也是一个协程:

raise gen.Return(yield fun(self, *args, **kwargs))

如果需要使用相同的包装器支持协同程序和非协同程序,请检查返回值:

ret = fun(self, *args, **kwargs)
if ret is not None:  # handlers are not supposed to return anything but None
    ret = yield ret
raise gen.Return(ret)