第三方OAuth授权登录,QQ、微信(WeChat)、微博、GitHub、码云(Gitee)、淘宝(天猫)、微软(Microsoft )、钉钉、谷歌(Google)、支付宝(AliPay)、StackOverflow
Netnr.Login
第三方OAuth授权登录
支持第三方登录
| 三方 | 参考文档 |
|---|---|
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 | |
| 参考文档 |
安装 (NuGet)
Install-Package Netnr.Login
修改配置信息(密钥、回调等)
提醒:一般所有第三方登录都有一个 state 参数,用于防止CSRF攻击(防伪),可以利用该参数添加 登录、注册 的标注前缀
框架
- .NETStandard 2.1
- .NETFramework 4.0
使用
/*
* 这是测试代码,只为调通每一个接口,拿到 唯一标识
* 实际应用中还要处理昵称、邮箱、头像等,可参考个站开源项目:https://github.com/netnr/blog
*/
using System;
namespace Netnr.Login.Sample
{
class Program
{
static void Main(string[] args)
{
var lc = new LoginClient(LoginBase.LoginType.StackOverflow);
//拷贝授权链接在浏览器打开,授权后拿到code,并手动赋值,手动赋值需解码
var url = lc.Auth();
var ar = new LoginBase.AuthorizeResult();
ar.code = "";
//此处打断点,赋值上面拿到的code再继续
ar.code = ar.code.ToDecode();
lc.AuthCallback(ar);
}
public class LoginClient
{
private LoginBase.LoginType? loginType;
public LoginClient(LoginBase.LoginType _loginType)
{
loginType = _loginType;
// 配置
QQConfig.APPID = "XXX";
QQConfig.APPKey = "XXX";
//回调地址,与申请填写的地址保持一致
QQConfig.Redirect_Uri = "https://rf2.netnr.com/account/authcallback/qq";
WeChatConfig.AppId = "";
WeChatConfig.AppSecret = "";
WeChatConfig.Redirect_Uri = "";
WeiboConfig.AppKey = "";
WeiboConfig.AppSecret = "";
WeiboConfig.Redirect_Uri = "";
GitHubConfig.ClientID = "";
GitHubConfig.ClientSecret = "";
GitHubConfig.Redirect_Uri = "";
//申请的应用名称,非常重要
GitHubConfig.ApplicationName = "netnrf";
TaoBaoConfig.AppKey = "";
TaoBaoConfig.AppSecret = "";
TaoBaoConfig.Redirect_Uri = "";
MicroSoftConfig.ClientID = "";
MicroSoftConfig.ClientSecret = "";
MicroSoftConfig.Redirect_Uri = "";
DingTalkConfig.appId = "";
DingTalkConfig.appSecret = "";
DingTalkConfig.Redirect_Uri = "";
GiteeConfig.ClientID = "";
GiteeConfig.ClientSecret = "";
GiteeConfig.Redirect_Uri = "";
GoogleConfig.ClientID = "";
GoogleConfig.ClientSecret = "";
GoogleConfig.Redirect_Uri = "";
AliPayConfig.AppId = "";
AliPayConfig.AppPrivateKey = "";
AliPayConfig.Redirect_Uri = "";
StackOverflowConfig.ClientId = "";
StackOverflowConfig.ClientSecret = "";
StackOverflowConfig.Key = "";
StackOverflowConfig.Redirect_Uri = "";
}
/// <summary>
/// 生成请求链接
/// </summary>
/// <param name="authType">在防伪参数追加信息(可用于登录、注册、绑定、解绑区分)</param>
/// <returns></returns>
public string Auth(string authType = "")
{
var url = string.Empty;
switch (loginType)
{
case LoginBase.LoginType.QQ:
{
var reqe = new QQ_Authorization_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = QQ.AuthorizationHref(reqe);
}
break;
case LoginBase.LoginType.WeiBo:
{
var reqe = new Weibo_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = Weibo.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.GitHub:
{
var reqe = new GitHub_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = GitHub.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.TaoBao:
{
var reqe = new TaoBao_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = TaoBao.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.MicroSoft:
{
var reqe = new MicroSoft_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = MicroSoft.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.WeChat:
{
var reqe = new WeChat_Authorization_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = WeChat.AuthorizationHref(reqe);
}
break;
case LoginBase.LoginType.DingTalk:
{
var reqe = new DingTalk_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
//扫描模式
url = DingTalk.AuthorizeHref_ScanCode(reqe);
//密码模式
//url = DingTalk.AuthorizeHref_Password(reqe);
}
break;
case LoginBase.LoginType.Gitee:
{
var reqe = new Gitee_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = Gitee.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.Google:
{
var reqe = new Google_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = Google.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.AliPay:
{
var reqe = new AliPay_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = AliPay.AuthorizeHref(reqe);
}
break;
case LoginBase.LoginType.StackOverflow:
{
var reqe = new StackOverflow_Authorize_RequestEntity();
if (!string.IsNullOrWhiteSpace(authType))
{
reqe.state = authType + reqe.state;
}
url = StackOverflow.AuthorizeHref(reqe);
}
break;
}
return url;
}
/// <summary>
/// 回调方法
/// </summary>
/// <param name="authorizeResult">接收授权码、防伪参数</param>
public void AuthCallback(LoginBase.AuthorizeResult authorizeResult)
{
if (string.IsNullOrWhiteSpace(authorizeResult.code))
{
//打开链接没登录授权
}
else
{
//唯一标示
string OpenId = string.Empty;
switch (loginType)
{
case LoginBase.LoginType.QQ:
{
//获取 access_token
var tokenEntity = QQ.AccessToken(new QQ_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 OpendId
var openidEntity = QQ.OpenId(new QQ_OpenId_RequestEntity()
{
access_token = tokenEntity.access_token
});
//获取 UserInfo
_ = QQ.OpenId_Get_User_Info(new QQ_OpenAPI_RequestEntity()
{
access_token = tokenEntity.access_token,
openid = openidEntity.openid
});
//身份唯一标识
OpenId = openidEntity.openid;
}
break;
case LoginBase.LoginType.WeiBo:
{
//获取 access_token
var tokenEntity = Weibo.AccessToken(new Weibo_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 access_token 的授权信息
var tokenInfoEntity = Weibo.GetTokenInfo(new Weibo_GetTokenInfo_RequestEntity()
{
access_token = tokenEntity.access_token
});
//获取 users/show
_ = Weibo.UserShow(new Weibo_UserShow_RequestEntity()
{
access_token = tokenEntity.access_token,
uid = Convert.ToInt64(tokenInfoEntity.uid)
});
OpenId = tokenEntity.access_token;
}
break;
case LoginBase.LoginType.WeChat:
{
//获取 access_token
var tokenEntity = WeChat.AccessToken(new WeChat_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 user
_ = WeChat.Get_User_Info(new WeChat_OpenAPI_RequestEntity()
{
access_token = tokenEntity.access_token,
openid = tokenEntity.openid
});
//身份唯一标识
OpenId = tokenEntity.openid;
}
break;
case LoginBase.LoginType.GitHub:
{
//获取 access_token
var tokenEntity = GitHub.AccessToken(new GitHub_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 user
var userEntity = GitHub.User(new GitHub_User_RequestEntity()
{
access_token = tokenEntity.access_token
});
OpenId = userEntity.id.ToString();
}
break;
case LoginBase.LoginType.TaoBao:
{
//获取 access_token
var tokenEntity = TaoBao.AccessToken(new TaoBao_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
OpenId = tokenEntity.open_uid;
}
break;
case LoginBase.LoginType.MicroSoft:
{
//获取 access_token
var tokenEntity = MicroSoft.AccessToken(new MicroSoft_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 user
var userEntity = MicroSoft.User(new MicroSoft_User_RequestEntity()
{
access_token = tokenEntity.access_token
});
OpenId = userEntity.id.ToString();
}
break;
case LoginBase.LoginType.DingTalk:
{
//获取 user
var userEntity = DingTalk.User(new DingTalk_User_RequestEntity(), authorizeResult.code);
OpenId = userEntity?.openid;
}
break;
case LoginBase.LoginType.Gitee:
{
//获取 access_token
var tokenEntity = Gitee.AccessToken(new Gitee_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 user
var userEntity = Gitee.User(new Gitee_User_RequestEntity()
{
access_token = tokenEntity.access_token
});
OpenId = userEntity.id.ToString();
}
break;
case LoginBase.LoginType.Google:
{
//获取 access_token
var tokenEntity = Google.AccessToken(new Google_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 user
var userEntity = Google.User(new Google_User_RequestEntity()
{
access_token = tokenEntity.access_token
});
OpenId = userEntity.sub;
}
break;
case LoginBase.LoginType.AliPay:
{
//获取 access_token
var tokenEntity = AliPay.AccessToken(new AliPay_AccessToken_RequestEntity()
{
code = authorizeResult.auth_code
});
//实际上这一步已经获取到 OpenId,登录验证可以了,获取个人信息还需调用下面的接口
//tokenEntity.user_id
//获取 user
var userEntity = AliPay.User(new AliPay_User_RequestEntity()
{
auth_token = tokenEntity.access_token
});
OpenId = userEntity.user_id;
}
break;
case LoginBase.LoginType.StackOverflow:
{
//获取 access_token
var tokenEntity = StackOverflow.AccessToken(new StackOverflow_AccessToken_RequestEntity()
{
code = authorizeResult.code
});
//获取 user
var userEntity = StackOverflow.User(new StackOverflow_User_RequestEntity()
{
access_token = tokenEntity.access_token
});
OpenId = userEntity.user_id;
}
break;
}
//拿到登录标识
if (string.IsNullOrWhiteSpace(OpenId))
{
//TO DO
}
}
}
}
}
}
Source
第三方OAuth授权登录,QQ、微信(WeChat)、微博、GitHub、码云(Gitee)、淘宝(天猫)、微软(Microsoft )、钉钉、谷歌(Google)、支付宝(AliPay)、StackOverflow的更多相关文章
- 微信订阅号里实现oauth授权登录,并获取用户信息 (完整篇)
摘要 这段时间一直有人问我,订阅号实现的oauth授权登录的问题,之前写的比较简单,很多人不明白.众所周知,微信公众号分订阅号.服务号.企业号:每个号的用途不一样,接口开放程度也不一样.微信还有个扯淡 ...
- 基于Thinkphp3.2的qq第三方oauth认证登录扩展类
基于Thinkphp3.2的qq第三方oauth认证登录扩展类,由于腾讯oauth sdk写的太多,不能与thinkphp和好的结合,最终想法讲腾讯oauth sdk写成tp的扩展类先看代码,将代码保 ...
- [转] Android:微信授权登录与微信分享全解析
https://wohugb.gitbooks.io/wechat/content/qrconnent/refresh_token.html http://blog.csdn.net/xiong_it ...
- OAuth授权登录
一.写在前面 日常生活中,我们经常看到到一个网站时,需要登录的时候,都提供了第三方的登录,也就是说你可以使用你的微信,QQ,微博等账号进行授权登录.那么这个认证登录的东西到底是什么呢? 微信授权登录页 ...
- 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_5-7.授权登录获取微信用户个人信息实战
笔记 7.授权登录获取微信用户个人信息实战 简介:讲解使用授权码code获取用户个人信息接口 关键点:看微信文档,字段尽量用拷贝 1.通过code获取access_token ...
- php单点登录之模拟淘宝天猫同步登录
说到单点登录大家都很了解,一个站点登录其他域会自动登录. 单点登录SSO(Single Sign On)的方法有很多,比如:p3p.共享session.共享cookice.第三方OAuth认证. 这里 ...
- 带三方登录(qq,微信,微博)
实现QQ.微信.新浪微博和百度第三方登录(Android Studio) 前言: 对于大多数的APP都有第三方登录这个功能,自己也做过几次,最近又有一个新项目用到了第三方登录,所以特意总结了一下关于 ...
- 解决微信公众号授权登录和开放平台微信第三方应用授权登录获取到的用户Openid关联问题
开发背景: 最近一段时间一直在做关于微信方面的网站应用开发,这段时间也收获的不少关于微信开发方面的开发技能,接触的比较多的主要有微信公众号和微信网站app第三方登录授权,以及微信会员卡,优惠券和扫描二 ...
- AbpZero之企业微信---登录(拓展第三方auth授权登录)---第三步:需要注意事项
1.AbpZero的auth登录会在数据库中的AbpUserLogins表会根据你登录的ProviderKey和Provider来生成生成一条记录,ProviderKey在表中是唯一的: 2.要登录成 ...
随机推荐
- Flsk&pyecharts 动态数据可视化
1:数据源 Hollywood Movie Dataset: 好莱坞2006-2011数据集 实验目的: 实现 统计2006-2011的数据综合统计情况,进行数据可视化 gitee地址: https ...
- 力扣(LeetCode)按奇偶排序数组II 个人题解
给定一个非负整数数组 A, A 中一半整数是奇数,一半整数是偶数. 对数组进行排序,以便当 A[i] 为奇数时,i 也是奇数:当 A[i] 为偶数时, i 也是偶数. 你可以返回任何满足上述条件的数组 ...
- objc里的伪指针TaggedPointer
如果你看过我前面两篇objc函数枢纽msgSend和你印象中的NSString是这样吗,相信已经多次看过它的身影了,到底它是何物何作用,我今日就来揭开谜团.我之所为称呼它为伪指针,是因为它像幽灵一样, ...
- 微信公众号配置及微信jsAPI支付
公众号配置 一.基本配置 首先登陆微信公众平台,在开发--->配置--->公众号开发信息,获取到AppId,开发者秘钥是后台需要的,给到后台,IP白名单配置就是你服务器的IP地址写到里面就 ...
- 微信小程序使用 ECharts 实现数据可视化
微信小程序使用 ECharts 显示图表 首先创建微信小程序 这里就不再赘述 下载 GitHub 上的 ecomfe/echarts-for-weixin 下载后解压,打开文件夹,里面的 ec-can ...
- 2019-9-17:基础学习,windows server 2008 r2,搭建web服务器和FTP服务器
一.信息服务iis管理器安装 1,点击打开“服务器管理器”-->选择“角色”-->选择“添加角色”,打开“添加角色向导” 2,点击“下一步”-->勾选“web服务器(IIS)”--& ...
- Fabric1.4源码解析:Peer节点启动过程
看一下Peer节点的启动过程,通常在Fabric网络中,Peer节点的启动方式有两种,通过Docker容器启动,或者是通过执行命令直接启动. 一般情况下,我们都是执行docker-compose -f ...
- C#Windows Forms (Demo.SYS)--xdd
private void Show_background_picture()//随机更换背景 { ";//默认值 Random ran = new Random(); , );//返回一个1 ...
- DBEntry.Net 简介
[尊重作者:本文转自:http://www.cnblogs.com/lephone/] 这是我设计的一个轻量级的 .Net ORM (Object Relational Mapping) 数据访问 ...
- NLog日志框架使用探究-2
目录 前言 自定义参数 日志输出方式 文件 网络传输 数据库 科学使用 参考文档 前言 在一年前,我写过一篇关于NLog入门文章<NLog日志框架使用探究-1>,文章简单的介绍了Nlog的 ...