zoukankan      html  css  js  c++  java
  • 微博回调接口

    1.微博回调接口

    1.1 oauth/urls.py 中添加路由

    1
    2
    3
    4
    urlpatterns = [
      path('weibo/callback/', views.OauthWeiboCallback.as_view()), #
    /oauth/weibo/callback/
    ]

      

    1.2 oauth/views.py 中添加试图函数

    http://192.168.56.100:8888/oauth/weibo/callback/

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    from .models import OauthUser
    from rest_framework_jwt.serializers import jwt_payload_handler,
    jwt_encode_handler
    from user.utils import jwt_response_payload_handler
     
     
    # 通过vue前端传入的code,微博身份验证
    class OauthWeiboCallback(APIView):
        # 自定义权限类
        permission_classes = (AllowAny,)
    def post(self, request):
        # 接收vue端传过来的code(微博的用户code)
        # 1.使用微博用户code+微博开发者账号信息换取微博的认证access_token
        code = request.data.get('code')
        data = {
            'client_id''3516473472',
            'client_secret''7862ee35a0dc6f0345d0464dc34f14fc',
            'grant_type''authorization_code',
            'code': code,
            'redirect_uri''http://127.0.0.1:8888/oauth/callback/',
        }
        url = 'https://api.weibo.com/oauth2/access_token'
        data = requests.post(url=url, data=data).json() # 拿取请求的返回结果
        access_token = data.get('uid'# 获取到的微博token
        weibo_uid = data.get('access_token'# 获取到少码用户的id
         
         
        # 2. 根据uid 查询绑定情况
        try:
            oauth_user = OauthUser.objects.get(uid=weibo_uid, oauth_type='1')
        except Exception as e:
            oauth_user = None
        # 返回动作, 登录成功/需要绑定用户 type 0 登录成功, 1, 授权成功, 需要绑定
        if oauth_user:
            # 4. 如果绑定了, 返回token, 登录成功
            user = oauth_user.user
     
     
            payload = jwt_payload_handler(user)
            token = jwt_encode_handler(payload)
            # jwt_response_payload_handler为user模块定义的jwt返回的信息
            data = jwt_response_payload_handler(token, user)
            data['type'= '0' # 指定为登录成功
            return Response({'code'0'msg''登录成功''data': data})
        else:
            # 5. 如果没绑定, 返回标志, 让前端跳转到绑定页面
            return Response({'code'0'msg''授权成功''data': {'type''1',
    'uid': weibo_uid}})
  • 相关阅读:
    概要设计
    JNI内存泄露
    Flash 与 JS 交互
    Lucene.net 实现全文搜索(转)
    自动打开登录游戏的代码
    Ajax,网站改版的一种方法
    IE6/IE7和Firefox对Div处理的差异(转)
    搜VC里找到的
    C# 尝试读取或写入受保护的内存。这通常指示其他内存已损坏
    HTML特殊转义字符列表
  • 原文地址:https://www.cnblogs.com/ngngng/p/13805334.html
Copyright © 2011-2022 走看看