zoukankan      html  css  js  c++  java
  • 三方登录逻辑

    三方登录逻辑

    理解第三方登录的流程:

    用户向本地应用商城发起请求,我要用微博进行登录

    我们的商城凑一个url让用户跳转到第三方应用的url(微博的登录页面)

    用户在该界面点击输入用户名密码之后,点击授权。

    微博有个回调url指向我们的应用。

    我们的应用就可以获取到用户的基本信息等。

    微博接口文档 : https://open.weibo.com/wiki/%E9%A6%96%E9%A1%B5

    使用逻辑:

    1、首先要去微博开发者页面,完成验证,才可以新建应用

    2、建好应用之后就可以拿到应用的App KeyApp Secret,需要设置好回调地址

    3、要是系统还没开发完成,可以使用测试模式,需要自己手动添加可以登录的微博账号

        """

        client_id   必填  string  申请应用时分配的AppKey

        redirect_uri    必填  string  授权回调地址,站外应用需与设置的回调地址一致。

        """

    #获取微博登录页面url

    def get_auth_url():

        weibo_auth_url = "https://api.weibo.com/oauth2/authorize"

        redirect_url = "http://127.0.0.1:8001/complete/weibo/"

        client_id = "AppKey"

        auth_url = weibo_auth_url + "?client_id={client_id}&redirect_uri={re_url}".format(client_id=client_id,

                                                                                          re_url=redirect_url)

        print(auth_url)

    #获取登录的token,这里是拿到登录的code

    #code会拼接在回调地址后面返回http://127.0.0.1:8001/complete/weibo/?code=c53bd7b5af51ec985952a3c03de3b

    def get_access_token(code):

        access_token_url = "https://api.weibo.com/oauth2/access_token"

        import requests

        re_dict = requests.post(access_token_url,data={

            "client_id": AppKey,

            "client_secret": "App Secret",

            "grant_type": "authorization_code",

            "code": code,

            "redirect_uri": "http://127.0.0.1:8001/complete/weibo/",

        })

       # '{"access_token":"2.00oneFMeMfeS0889036fBNW_B","remind_in":"15799","expires_in":15799,"uid":"5675652","isRealName":"true"}'

        pass

    #获取带有微博用户json信息的url

    def get_user_info(access_token):

        user_url = "https://api.weibo.com/2/users/show.json"

        uid = "5675652"

        get_url = user_url + "?access_token={at}&uid={uid}".format(at=access_token, uid=uid)

        print(get_url)

    if __name__ == '__main__':

        # get_auth_url()

        #通过code获取access_token

        # get_access_token("c53bd7b5af51ec985952a3c03de3b")

        #通过access_token获取用户的信息

        get_user_info("2.00oneFMeMfeS0889036fBNW_B")

  • 相关阅读:
    前端PHP入门-001-为什么学习PHP?
    PowerDesigner逆向生成
    Tomcat7项目迁移到Tomcat8中文乱码问题
    通过反射获取T.class代码片段
    pdf预览-js版本
    一般处理程序下载
    .net预览功能
    资源整理
    二、编译安装LAMP之httpd-2.4.4
    HTTP之缓存
  • 原文地址:https://www.cnblogs.com/wjohh/p/10640041.html
Copyright © 2011-2022 走看看