开发者

Working with OAuth python

I'm am using OAuth to allow my user to OAuth with Hunch, on my webpage I have a button to allow the user to go to Hunch and enter their details

    <form action="/hunch" method="post" align = "right">
        <div>
            <input type="submit" value="Login using Hunch">
        </div>
    </form>

How can I call a method here rather than a handler? as it is currently calling this:

class hunch(webapp.RequestHandler):
    def post(self):
        url = 'http://hunch.com/authorize/v1/?app_id=123&next=/get-recs'
        self.redirect(url)  
        logging.info("url2 = " + url2)

        auth_token_key = self.request.get('auth_token_key')
        logging.info("auth_token_key = " + auth_token_key)

but when I print the url2 it just prints /hunch? I hope this makes sense.

Also should this auth_token_key = self.request.get('auth_token_key') get information from the url that the user is directed to after they have entered their cre开发者_如何转开发dentials?


Please read the documentation for Hunch OAuth.

Rather than intercepting the form on the backend, send the user directly to

http://hunch.com/authorize/v1/?app_id=12345 (providing your own app_id and an optional next parameter).

If the user authorizes your application, they will be redirected to the redirect_url registered for your application along with an auth_token_key. For example, an app with a redirect_url of http://your-domain.com/authorized/ will be redirected to

http://your-domain.com/authorized/?auth_token_key=7a1b2c3&auth_sig=941bc415af782a8d93a83c874922ae1b30e92a70

At this point you can exchange the auth_token_key for an auth_token.

The Hunch sample app on Github has an example of how this should be done. The authorize function generates a page asking the user to Hunch connect, and the authorized function exchanges the auth_token_key for an auth_token.


When GAE (using OpenId) logs in a user, it relies on the /_ah/login_required page.

To get a user to enter their own credentials, you should create a page containing links to log in with the different providers you wish to use. You must then override the /_ah/login_required mapping in your url mapping file to use your own custom login page rather than the default.

This is a very good tutorial I used for this.

Google now offers their own official tutorial.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜