javascript - 如何结合 Tornado 身份验证和 AngularJS?

标签 javascript python angularjs tornado

我正在使用 Tornado 文档中作为示例提供的身份验证系统。当我想将它与 AngularJS 结合使用时 - AngularJS 提示跨域请求。

如何结合 Tornado 的身份验证系统和 AngularJS?

身份验证处理程序

class BaseHandler(tornado.web.RequestHandler):

    def get_current_user(self):
        user_json = self.get_secure_cookie("my_app")
        if not user_json: return None
        return tornado.escape.json_decode(user_json)


class AuthGoogleLoginHandler(BaseHandler, tornado.auth.GoogleMixin):
    '''
    The Google OAuth Handler.

    The `AuthGoogleLoginHandler` redirects each accepted user
    to the index /.
    '''
    @gen.coroutine
    def get(self):

        if self.get_argument("openid.mode", None):
            user = yield self.get_authenticated_user()
            self.set_secure_cookie("my_app",
                                   tornado.escape.json_encode(user))
            self.current_user = user
            email = user.get('email')

            try:
                usr = models.User.objects.get(email=email)

            except mongoengine.DoesNotExist as e:

                # there is no user with the wished email address
                # let's create a new one.
                new_user = models.User()
                new_user.email = user.get('email')
                new_user.first_name = user.get('first_name')
                new_user.last_name = user.get('last_name')
                new_user.locale = user.get('locale')

                new_user.save()

            self.redirect(self.get_argument('next', '/'))
            return

        self.authenticate_redirect()

配置文件处理器

class ProfileHandler(BaseHandler):
    '''
    returns the username of the current user so that it can be used by the AngularJS Templates
    '''

    @tornado.web.authenticated
    def get(self):

        if not self.get_current_user():
            response = json.dumps({"userdetails":"my dummy user"})
            self.write(response)

        # user actually exists
        else:
            response = json.dumps({"userdetails":self.get_current_user()})
            self.write(response)

最佳答案

我认为您需要启用跨源请求,wiki CORS 以获取更多信息:

class BaseHandler(tornado.web.RequestHandler):
    def set_default_headers(self):
        self.set_header("Access-Control-Allow-Origin", "http://yoursite.com")

此外,我花了一些时间才弄清楚这一点,但当 Angular 与 RESTful API 交互时,正常 session 不起作用。您想要的是在每个请求的 HTTP 授权 header 中发送凭据。检查一下:

http://wemadeyoulook.at/en/blog/implementing-basic-http-authentication-http-requests-angular/

希望对您有所帮助!

关于javascript - 如何结合 Tornado 身份验证和 AngularJS?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23592606/

相关文章:

angularjs - Angular ng-repeat 列出对象中属性名称未知的所有项目

javascript - 单击父级时调用子级单击事件

javascript - 删除在 HTML5 Canvas 中制作的圆圈

python - Pandas 中的数据透视表出现意外输出

javascript - window.location和$ location.path有什么区别?

AngularJS - 不使用 JS/脚本隐藏和显示元素

javascript - mongodb按范围查询分页与另一个排序字段

javascript - VS 2013 查找并替换 document.getElementById ("elementId").value 为 $("#elementId).val()

python - 如何在 python 中为电子邮件创建消息 ID?

python - 从二叉树获取列表,TypeError