前言

还是得弱弱的写下这个技术的背后,大概是这个样子的,看到OAuth这个单词,我就想到了权限这个词,不知道为什么,又想起了第三方登录这个技术,于是自己脑补了一下,应该这两个东西是有关系的。再就是去动手查了查。

内容

看了关于腾讯开发官方文档的好多文档,以及尝试了好多次创建个人的开发平台,但是都是在最后提交的时候,出现了错误,按照错误源头查官方文档,文档上说给某某发邮件即可。于是我就等到了现在,所以自己上网搜了一下,别人获取的appkey和appsecret,开心的开始玩弄这些代码。终于折腾出来了。个人感觉这个就是一个登录授权的过程,那么我自己把它理解为了两个步骤。

  • 第一个:申请腾讯开发平台,获取appkey和appsecret。
  • 第二个:授权获取accesstoken,然后授权成功后,就可以从第三方库里调用个人登录信息。

上网查了查,国内授权方式有很多种,其中我了解到的有:

1、Authorization Code方式;

据说这种授权方式专门提供给web开发用的,这种授权方式将咱们通过授权请求到的带有用户信息的调出许可的accesstoken,而且不用暴露用户的密码。

2、Implicit Grant方式;

这种方式允许accesstoken。

大家可能对这个accesstoken的重要性不太清楚,看下面这个图就知道,这个accesstoken代表着什么。

整体走向:

授权的过程:

通过上面的图解,这下是不是对这个东西更加了解了,其实当你认真观察过授权过程中地址的变化,你会发现,你对这个东西的了解更近了一步。

我做了一个demo,通过页面之间的跳转,你会发现我想表达的东西吗?

第三方登录页:

当前网址为:

http://localhost:62219/Home/About

授权界面:

当前网址为:

https://open.t.qq.com/cgi-bin/oauth2/authorize?client_id=801152319&response_type=code&redirect_uri=http://localhost:62219/Tencent/Index

授权成功,调转界面:

当前网址为:

http://localhost:62219/Tencent/Index?code=8519295ab1b8bc64fba705384a466650&openid=F3237095EED6DA1FCDB5C027D5013B2E&openkey=F1281E05C8C424698A00ED5610129165&state=

看到这几个链接地址,大家试想一下,是不是我只是拼接想要的字符串地址,就可以达到页面调转的目的,大家可以看到,链接地址上面有上图说说到的code,但是accesstoken没有在链接地址上显示出来,其实它确实已经在授权服务器上获取到了。只不过,由于咱们用到的是code方式授权,所以安全性的考虑,没有将accesstoken暴露出来。下面给大家上代码,这里需要引用一个dll文件:dotNetDR_OAuth2,这里的代码部分主要展示网址拼接转换以及部分变量的获取。

第一个网络地址获取:

//生成主机头
var hostPath = AccessTokenToolkit.GenerateHostPath(Request.Url); //定义授权成功后返回的url地址
var tencentRedirectUrl = hostPath + Url.Action("Index", "Tencent");

第二个网络地址获取,在第一个基础上:

            //
model.TencentLink = tencent.GenerateCodeUrl(tencentRedirectUrl);

第三个网络地址获取:

                   //
var redirectUrl = AccessTokenToolkit.GenerateHostPath(Request.Url) + Url.Action("Index"); var accessToken = _authCode.GetResult(_authCode.GenerateAccessTokenUrl(redirectUrl, code));

小结

上面的东西,还是得实际实践体会比较深,加油!

感谢您的宝贵时间···

OAuth实现腾讯微博第三方登录的更多相关文章

  1. django项目微博第三方登录

    此处咱们用到的是 social_django,所以要把此应用注册到配置文件中, INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.a ...

  2. yii2微博第三方登录

    原作者:杜文建 原博客:http://www.cnblogs.com/dwj97/p/6530568.html yii2微博第三方登录   微博登录是最常用的第三方账号登录之一.由于其网站用户量大,可 ...

  3. 微博第三方登录时,域名使用错误报错, Laravel \ Socialite \ Two \ InvalidStateException No message

    使用微博第三方登录时,报错 Laravel \ Socialite \ Two \ InvalidStateException No message Laravel \Socialite \Two \ ...

  4. Django 2.0.4 微博第三方登录

    三方登录逻辑 理解第三方登录的流程: 用户向本地应用商城发起请求,我要用微博进行登录 我们的商城凑一个url让用户跳转到第三方应用的url(微博的登录页面) 用户在该界面点击输入用户名密码之后,点击授 ...

  5. Django rest framework集成微博第三方登录

    Django restframework 集成第三方登录(微博.微信.QQ等) 友情链接 python-social-auth-app官方文档 微博开放者平台 QQ开放者平台 准备工作 1.注册微博开 ...

  6. Unity利用Share SDK实现QQ、微信及微博第三方登录及定制内容分享(附代码)

    最近因为公司的项目需要添加一些实用性的功能,需要添加第三方登录及分享,采用的是Mob的SDK,可以先到其官网下载对应的SDK 点击这里,为了方便后期进行数据统计和分析,所以可以先添加一个应用,添加成功 ...

  7. OAuth2.0 social_django微博第三方登录

    python网站第三方登录,social-auth-app-django模块, social-auth-app-django模块是专门用于Django的第三方登录OAuth2协议模块 目前流行的第三方 ...

  8. 微博第三方登录使用social_django实现显示登陆的用户名

    首先修改social_soce源码,将用户信息添加进cookie 将其修改为:  response =  backend.strategy.redirect(url)    payload = jwt ...

  9. 【Demo】QQ,github,微博第三方社交登录

    本文主要讲解 集成 第三方社交账号登录 为什么会有这个需求? 主要是因为目前互联网的网站数量太多,如果在各个站点都注册一个账号 用户非常不容易记住每个账号的用户名和密码,并且非常难保证每个账号的密码足 ...

随机推荐

  1. Mina2中IoService

    Apache MINA 2 是一个开发高性能和高可伸缩性网络应用程序的网络应用框架.它提供了一个抽象的事件驱动的异步 API,可以使用 TCP/IP.UDP/IP.串口和虚拟机内部的管道等传输方式. ...

  2. 怎样在win7中 安装Tomcat7.0

    Tomcat 服务器是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器. 我们可以到官方网站下载Tomcat7 工具/原料 win7 Tomcat7.0 方法/步骤 1 在官网下载软件: ...

  3. [JAVA反序列化DEMO]利用RMI进行反序列化一键启动工具

    功能: 命令行启动jar包,用户自定义启动RMI端口.默认内置Apache Commons Collections.只需一键启动即可测试java反序列化漏洞. 启动服务: [root@sevck_v3 ...

  4. Winsock 传输文件

    文件传输的原理:发送方把文件读到socket发送端缓冲区中,接收方把socket接收端缓端冲区中的数据写到一个新文件中.当然了,大文件需要循环读写! 服务器端为发送端: #include " ...

  5. jQuery实现页内锚点平滑跳转

    当页面内容长多,导致页面高度过高或过宽是,浏览起来就有点费劲,不过使用了锚点平滑跳转效果可以实现页面的跳转,从而加快速浏览想要浏览的模块.具体做法如下: 首先是菜单(锚点)的写法 <a href ...

  6. Delphi XE2 新控件 布局Panel TGridPanel TFlowPanel

    Delphi XE2 新控件 Firemonkey 布局Panel Windows平台VCl TGridPanel TFlowPanel FMX 跨平台 TLayout TGridLayout TFl ...

  7. 修改LINUX ROOT密码

    Connecting to 10.10.70.22:22... Connection established. To escape to local shell, press 'Ctrl+Alt+]' ...

  8. 使用Java建立聊天客户端

    ---------------siwuxie095                             关于 聊天服务器,详见本人博客的分类:来一杯Java, 里面的 使用ServerSocket ...

  9. OpenStack基础及概念

    一.云计算基本概念解析        1.1什么是云计算 云计算:代表计算资源向云水循环一样,按需分配,循环利用. 1.2.云计算分类 狭义:IT基础设施的交互和使用模式,通过网络以按需,易扩展的方式 ...

  10. 杭电ACM刷题(1):1002,A + B Problem II 标签: acmc语言 2017-05-07 15:35 139人阅读 评

    最近忙于考试复习,没有多少可供自己安排的时间,所以我利用复习之余的空闲时间去刷刷杭电acm的题目,也当对自己编程能力的锻炼吧. Problem Description I have a very si ...