Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
My_csdo
JustAuth
提交
3933b3b7
J
JustAuth
项目概览
My_csdo
/
JustAuth
与 Fork 源项目一致
Fork自
justauth / JustAuth
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
JustAuth
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
3933b3b7
编写于
3月 19, 2021
作者:
智布道
👁
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
🥚
增加钉钉账号登录
上级
cd324cc7
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
149 addition
and
82 deletion
+149
-82
src/main/java/me/zhyd/oauth/config/AuthConfig.java
src/main/java/me/zhyd/oauth/config/AuthConfig.java
+1
-1
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
+20
-1
src/main/java/me/zhyd/oauth/request/AbstractAuthDingtalkRequest.java
...va/me/zhyd/oauth/request/AbstractAuthDingtalkRequest.java
+104
-0
src/main/java/me/zhyd/oauth/request/AuthDingTalkAccountRequest.java
...ava/me/zhyd/oauth/request/AuthDingTalkAccountRequest.java
+22
-0
src/main/java/me/zhyd/oauth/request/AuthDingTalkRequest.java
src/main/java/me/zhyd/oauth/request/AuthDingTalkRequest.java
+2
-80
未找到文件。
src/main/java/me/zhyd/oauth/config/AuthConfig.java
浏览文件 @
3933b3b7
...
...
@@ -135,7 +135,7 @@ public class AuthConfig {
/**
* 是否开启 PKCE 模式,该配置仅用于支持 PKCE 模式的平台,针对无服务应用,不推荐使用隐式授权,推荐使用 PKCE 模式
*
* @since 1.1
6.0
* @since 1.1
5.9
*/
private
boolean
pkce
;
}
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
浏览文件 @
3933b3b7
...
...
@@ -73,7 +73,7 @@ public enum AuthDefaultSource implements AuthSource {
}
},
/**
* 钉钉
* 钉钉
扫码登录
*/
DINGTALK
{
@Override
...
...
@@ -91,6 +91,25 @@ public enum AuthDefaultSource implements AuthSource {
return
"https://oapi.dingtalk.com/sns/getuserinfo_bycode"
;
}
},
/**
* 钉钉账号登录
*/
DINGTALK_ACCOUNT
{
@Override
public
String
authorize
()
{
return
"https://oapi.dingtalk.com/connect/oauth2/sns_authorize"
;
}
@Override
public
String
accessToken
()
{
return
DINGTALK
.
accessToken
();
}
@Override
public
String
userInfo
()
{
return
DINGTALK
.
userInfo
();
}
},
/**
* 百度
*/
...
...
src/main/java/me/zhyd/oauth/request/AbstractAuthDingtalkRequest.java
0 → 100644
浏览文件 @
3933b3b7
package
me.zhyd.oauth.request
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
me.zhyd.oauth.cache.AuthStateCache
;
import
me.zhyd.oauth.config.AuthConfig
;
import
me.zhyd.oauth.config.AuthSource
;
import
me.zhyd.oauth.enums.AuthUserGender
;
import
me.zhyd.oauth.exception.AuthException
;
import
me.zhyd.oauth.model.AuthCallback
;
import
me.zhyd.oauth.model.AuthToken
;
import
me.zhyd.oauth.model.AuthUser
;
import
me.zhyd.oauth.utils.GlobalAuthUtils
;
import
me.zhyd.oauth.utils.HttpUtils
;
import
me.zhyd.oauth.utils.UrlBuilder
;
/**
* <p>
* 钉钉登录抽象类,负责处理使用钉钉账号登录第三方网站和扫码登录第三方网站两种钉钉的登录方式
* </p>
*
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
* @since 1.16.0
*/
public
abstract
class
AbstractAuthDingtalkRequest
extends
AuthDefaultRequest
{
public
AbstractAuthDingtalkRequest
(
AuthConfig
config
,
AuthSource
source
)
{
super
(
config
,
source
);
}
public
AbstractAuthDingtalkRequest
(
AuthConfig
config
,
AuthSource
source
,
AuthStateCache
authStateCache
)
{
super
(
config
,
source
,
authStateCache
);
}
@Override
protected
AuthToken
getAccessToken
(
AuthCallback
authCallback
)
{
return
AuthToken
.
builder
().
accessCode
(
authCallback
.
getCode
()).
build
();
}
@Override
protected
AuthUser
getUserInfo
(
AuthToken
authToken
)
{
String
code
=
authToken
.
getAccessCode
();
JSONObject
param
=
new
JSONObject
();
param
.
put
(
"tmp_auth_code"
,
code
);
String
response
=
new
HttpUtils
(
config
.
getHttpConfig
()).
post
(
userInfoUrl
(
authToken
),
param
.
toJSONString
());
JSONObject
object
=
JSON
.
parseObject
(
response
);
if
(
object
.
getIntValue
(
"errcode"
)
!=
0
)
{
throw
new
AuthException
(
object
.
getString
(
"errmsg"
));
}
object
=
object
.
getJSONObject
(
"user_info"
);
AuthToken
token
=
AuthToken
.
builder
()
.
openId
(
object
.
getString
(
"openid"
))
.
unionId
(
object
.
getString
(
"unionid"
))
.
build
();
return
AuthUser
.
builder
()
.
rawUserInfo
(
object
)
.
uuid
(
object
.
getString
(
"unionid"
))
.
nickname
(
object
.
getString
(
"nick"
))
.
username
(
object
.
getString
(
"nick"
))
.
gender
(
AuthUserGender
.
UNKNOWN
)
.
source
(
source
.
toString
())
.
token
(
token
)
.
build
();
}
/**
* 返回带{@code state}参数的授权url,授权回调时会带上这个{@code state}
*
* @param state state 验证授权流程的参数,可以防止csrf
* @return 返回授权地址
* @since 1.9.3
*/
@Override
public
String
authorize
(
String
state
)
{
return
UrlBuilder
.
fromBaseUrl
(
source
.
authorize
())
.
queryParam
(
"response_type"
,
"code"
)
.
queryParam
(
"appid"
,
config
.
getClientId
())
.
queryParam
(
"scope"
,
"snsapi_login"
)
.
queryParam
(
"redirect_uri"
,
config
.
getRedirectUri
())
.
queryParam
(
"state"
,
getRealState
(
state
))
.
build
();
}
/**
* 返回获取userInfo的url
*
* @param authToken 用户授权后的token
* @return 返回获取userInfo的url
*/
@Override
protected
String
userInfoUrl
(
AuthToken
authToken
)
{
// 根据timestamp, appSecret计算签名值
String
timestamp
=
System
.
currentTimeMillis
()
+
""
;
String
urlEncodeSignature
=
GlobalAuthUtils
.
generateDingTalkSignature
(
config
.
getClientSecret
(),
timestamp
);
return
UrlBuilder
.
fromBaseUrl
(
source
.
userInfo
())
.
queryParam
(
"signature"
,
urlEncodeSignature
)
.
queryParam
(
"timestamp"
,
timestamp
)
.
queryParam
(
"accessKey"
,
config
.
getClientId
())
.
build
();
}
}
src/main/java/me/zhyd/oauth/request/AuthDingTalkAccountRequest.java
0 → 100644
浏览文件 @
3933b3b7
package
me.zhyd.oauth.request
;
import
me.zhyd.oauth.cache.AuthStateCache
;
import
me.zhyd.oauth.config.AuthConfig
;
import
me.zhyd.oauth.config.AuthDefaultSource
;
/**
* 钉钉账号登录
*
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
* @since 1.0.0
*/
public
class
AuthDingTalkAccountRequest
extends
AbstractAuthDingtalkRequest
{
public
AuthDingTalkAccountRequest
(
AuthConfig
config
)
{
super
(
config
,
AuthDefaultSource
.
DINGTALK_ACCOUNT
);
}
public
AuthDingTalkAccountRequest
(
AuthConfig
config
,
AuthStateCache
authStateCache
)
{
super
(
config
,
AuthDefaultSource
.
DINGTALK_ACCOUNT
,
authStateCache
);
}
}
src/main/java/me/zhyd/oauth/request/AuthDingTalkRequest.java
浏览文件 @
3933b3b7
package
me.zhyd.oauth.request
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
me.zhyd.oauth.utils.HttpUtils
;
import
me.zhyd.oauth.cache.AuthStateCache
;
import
me.zhyd.oauth.config.AuthConfig
;
import
me.zhyd.oauth.config.AuthDefaultSource
;
import
me.zhyd.oauth.enums.AuthUserGender
;
import
me.zhyd.oauth.exception.AuthException
;
import
me.zhyd.oauth.model.AuthCallback
;
import
me.zhyd.oauth.model.AuthToken
;
import
me.zhyd.oauth.model.AuthUser
;
import
me.zhyd.oauth.utils.GlobalAuthUtils
;
import
me.zhyd.oauth.utils.UrlBuilder
;
/**
* 钉钉登录
* 钉钉
二维码
登录
*
* @author yadong.zhang (yadong.zhang0415(a)gmail.com)
* @since 1.0.0
*/
public
class
AuthDingTalkRequest
extends
A
uthDefault
Request
{
public
class
AuthDingTalkRequest
extends
A
bstractAuthDingtalk
Request
{
public
AuthDingTalkRequest
(
AuthConfig
config
)
{
super
(
config
,
AuthDefaultSource
.
DINGTALK
);
...
...
@@ -29,72 +19,4 @@ public class AuthDingTalkRequest extends AuthDefaultRequest {
public
AuthDingTalkRequest
(
AuthConfig
config
,
AuthStateCache
authStateCache
)
{
super
(
config
,
AuthDefaultSource
.
DINGTALK
,
authStateCache
);
}
@Override
protected
AuthToken
getAccessToken
(
AuthCallback
authCallback
)
{
return
AuthToken
.
builder
().
accessCode
(
authCallback
.
getCode
()).
build
();
}
@Override
protected
AuthUser
getUserInfo
(
AuthToken
authToken
)
{
String
code
=
authToken
.
getAccessCode
();
JSONObject
param
=
new
JSONObject
();
param
.
put
(
"tmp_auth_code"
,
code
);
String
response
=
new
HttpUtils
(
config
.
getHttpConfig
()).
post
(
userInfoUrl
(
authToken
),
param
.
toJSONString
());
JSONObject
object
=
JSON
.
parseObject
(
response
);
if
(
object
.
getIntValue
(
"errcode"
)
!=
0
)
{
throw
new
AuthException
(
object
.
getString
(
"errmsg"
));
}
object
=
object
.
getJSONObject
(
"user_info"
);
AuthToken
token
=
AuthToken
.
builder
()
.
openId
(
object
.
getString
(
"openid"
))
.
unionId
(
object
.
getString
(
"unionid"
))
.
build
();
return
AuthUser
.
builder
()
.
rawUserInfo
(
object
)
.
uuid
(
object
.
getString
(
"unionid"
))
.
nickname
(
object
.
getString
(
"nick"
))
.
username
(
object
.
getString
(
"nick"
))
.
gender
(
AuthUserGender
.
UNKNOWN
)
.
source
(
source
.
toString
())
.
token
(
token
)
.
build
();
}
/**
* 返回带{@code state}参数的授权url,授权回调时会带上这个{@code state}
*
* @param state state 验证授权流程的参数,可以防止csrf
* @return 返回授权地址
* @since 1.9.3
*/
@Override
public
String
authorize
(
String
state
)
{
return
UrlBuilder
.
fromBaseUrl
(
source
.
authorize
())
.
queryParam
(
"response_type"
,
"code"
)
.
queryParam
(
"appid"
,
config
.
getClientId
())
.
queryParam
(
"scope"
,
"snsapi_login"
)
.
queryParam
(
"redirect_uri"
,
config
.
getRedirectUri
())
.
queryParam
(
"state"
,
getRealState
(
state
))
.
build
();
}
/**
* 返回获取userInfo的url
*
* @param authToken 用户授权后的token
* @return 返回获取userInfo的url
*/
@Override
protected
String
userInfoUrl
(
AuthToken
authToken
)
{
// 根据timestamp, appSecret计算签名值
String
timestamp
=
System
.
currentTimeMillis
()
+
""
;
String
urlEncodeSignature
=
GlobalAuthUtils
.
generateDingTalkSignature
(
config
.
getClientSecret
(),
timestamp
);
return
UrlBuilder
.
fromBaseUrl
(
source
.
userInfo
())
.
queryParam
(
"signature"
,
urlEncodeSignature
)
.
queryParam
(
"timestamp"
,
timestamp
)
.
queryParam
(
"accessKey"
,
config
.
getClientId
())
.
build
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录