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

    1. 微博回调接口

    1.1 oauth/urls.py中添加路由

    urlpatterns = [
        path('weibo/callback/', views.OauthWeiboCallback.as_view()), 
    ]
    

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

    http://192.168.56.100:8888/oauth/weibo/callback/
    
    # 通过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': '2567752731',
                'client_secret': 'f6367081e73b7a74b593039189a039a8',
                '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}})
    
    

    1.3 oauth/models.py中添加模型

    class OauthUser(models.Model):
        OAUTHTYPE = (
            ('1', 'weibo'),
            ('2', 'weixin'),
        )
        uid = models.CharField('三方用户id', max_length=64)  # 三方用户id
        # 本地用户外键,关联User表
        user = models.ForeignKey('user.User', on_delete=models.CASCADE)  
        oauth_type = models.CharField('认证类型', max_length=10, choices=OAUTHTYPE)
    
    

    1.4 迁移数据库

    python manage.py makemigrations
    python manage.py migrate
    

    2.vue微博回调空页面

    <template>
      <div>
        <p>跳转中....</p>
      </div>
    
    </template>
    <script>
      import { oauth_callback_post, oauth_binduser_post, user_count } from './axios_api/api'
      export default {
        data() {
          return {
            visiable: false, // 绑定用户窗口
            uid: '', // weibo_uid
            username: '',
            password: '',
            username_message: '',
            username_error: false
          }
        },
        mounted() {
          this.getCode()
        },
        methods: {
          getCode() {
            // 获取url中的code 信息
            // 当前url 是  http://mysyl.com:8080/oauth/callback/?code=fe6cbe07708aecf4a2b3d942ed692c4c
            let code = this.$route.query.code
            console.log(this.$route.query)
            // 给后端发送code
            let params = { code: code }
            oauth_callback_post(params).then((resp) => {
              console.log(resp)
              // code: 0
              // msg: "授权成功"
              // data: {type: "1", uid: "7410919278"}
              if (resp.data.type == '0') {
                // code: 0
                // msg: "登录成功"
                // data: {
                // authenticated: "true"
                // email: ""
                // id: 1
                // name: "admin"
                // role: null
                // token: "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoxLCJ1c2VybmFtZSI6ImFkbWluIiwiZXhwIjoxNTk3OTAwNTcyLCJlbWFpbCI6IiIsIm9yaWdfaWF0IjoxNTk3ODE0MTcyfQ.aQT7GSR_xQBPMlB4_k8-zTHnx0ow3OC2KHa3C8MgilY"
                // type: "0"
                // username: "admin"}
                let res = resp.data
                localStorage.setItem('username', res.username)
                // localStorage.setItem('img', res.img)
                localStorage.setItem('token', res.token)
                localStorage.setItem('uid', res.id)
                this.login_username = res.username
                this.opened = false
                // alert(res.message)
                this.$router.push('/')
    
              }
              if (resp.data.type == '1') {
                this.visiable = true
                this.uid = resp.data.uid
              }
            })
          },
        }
      }
    </script>
    
    
  • 相关阅读:
    Alpha冲刺
    Alpha冲刺
    抽奖系统(记一次未完成的教训)
    Alpha冲刺
    软件工程
    软工实践
    软工实践
    软工实践
    软工实践
    软工实践
  • 原文地址:https://www.cnblogs.com/fiee/p/13792721.html
Copyright © 2011-2022 走看看