Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
My_csdo
JustAuth
提交
7d6049da
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看板
提交
7d6049da
编写于
8月 11, 2021
作者:
Z
zheng-jx
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
企业微信第三方登录
接入链接
https://open.work.weixin.qq.com/api/doc/90001/90143/91123
上级
af8fda70
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
160 addition
and
1 deletion
+160
-1
src/main/java/me/zhyd/oauth/config/AuthConfig.java
src/main/java/me/zhyd/oauth/config/AuthConfig.java
+7
-0
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
+33
-0
src/main/java/me/zhyd/oauth/request/AuthDefaultRequest.java
src/main/java/me/zhyd/oauth/request/AuthDefaultRequest.java
+1
-1
src/main/java/me/zhyd/oauth/request/AuthWeChatEnterpriseThirdQrcodeRequest.java
...oauth/request/AuthWeChatEnterpriseThirdQrcodeRequest.java
+119
-0
未找到文件。
src/main/java/me/zhyd/oauth/config/AuthConfig.java
浏览文件 @
7d6049da
...
...
@@ -65,6 +65,13 @@ public class AuthConfig {
*/
private
String
agentId
;
/**
* 企业微信第三方授权用户类型,member|admin
*
* @since 1.10.0
*/
private
String
usertype
;
/**
* 域名前缀。
* <p>
...
...
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
浏览文件 @
7d6049da
...
...
@@ -600,7 +600,40 @@ public enum AuthDefaultSource implements AuthSource {
return
"https://qyapi.weixin.qq.com/cgi-bin/user/getuserinfo"
;
}
},
/**
* 企业微信二维码第三方登录
*/
WECHAT_ENTERPRISE_QRCODE_THIRD
{
/**
* 授权的api
*
* @return url
*/
@Override
public
String
authorize
()
{
return
"https://open.work.weixin.qq.com/wwopen/sso/3rd_qrConnect"
;
}
/**
* 获取accessToken的api
*
* @return url
*/
@Override
public
String
accessToken
()
{
return
"https://qyapi.weixin.qq.com/cgi-bin/service/get_provider_token"
;
}
/**
* 获取用户信息的api
*
* @return url
*/
@Override
public
String
userInfo
()
{
return
"https://qyapi.weixin.qq.com/cgi-bin/service/get_login_info"
;
}
},
/**
* 企业微信网页登录
*/
...
...
src/main/java/me/zhyd/oauth/request/AuthDefaultRequest.java
浏览文件 @
7d6049da
...
...
@@ -92,7 +92,7 @@ public abstract class AuthDefaultRequest implements AuthRequest {
* @param e 具体的异常
* @return AuthResponse
*/
private
AuthResponse
responseError
(
Exception
e
)
{
AuthResponse
responseError
(
Exception
e
)
{
int
errorCode
=
AuthResponseStatus
.
FAILURE
.
getCode
();
String
errorMsg
=
e
.
getMessage
();
if
(
e
instanceof
AuthException
)
{
...
...
src/main/java/me/zhyd/oauth/request/AuthWeChatEnterpriseThirdQrcodeRequest.java
0 → 100644
浏览文件 @
7d6049da
package
me.zhyd.oauth.request
;
import
com.alibaba.fastjson.JSONObject
;
import
me.zhyd.oauth.cache.AuthStateCache
;
import
me.zhyd.oauth.config.AuthConfig
;
import
me.zhyd.oauth.config.AuthDefaultSource
;
import
me.zhyd.oauth.enums.AuthResponseStatus
;
import
me.zhyd.oauth.exception.AuthException
;
import
me.zhyd.oauth.log.Log
;
import
me.zhyd.oauth.model.AuthCallback
;
import
me.zhyd.oauth.model.AuthResponse
;
import
me.zhyd.oauth.model.AuthToken
;
import
me.zhyd.oauth.model.AuthUser
;
import
me.zhyd.oauth.utils.*
;
/**
* <p>
* 企业微信第三方二维码登录
* </p>
*
* @author zhengjx
* @since 1.10.0
*/
public
class
AuthWeChatEnterpriseThirdQrcodeRequest
extends
AbstractAuthWeChatEnterpriseRequest
{
public
AuthWeChatEnterpriseThirdQrcodeRequest
(
AuthConfig
config
)
{
super
(
config
,
AuthDefaultSource
.
WECHAT_ENTERPRISE_QRCODE_THIRD
);
}
public
AuthWeChatEnterpriseThirdQrcodeRequest
(
AuthConfig
config
,
AuthStateCache
authStateCache
)
{
super
(
config
,
AuthDefaultSource
.
WECHAT_ENTERPRISE_QRCODE_THIRD
,
authStateCache
);
}
@Override
public
String
authorize
(
String
state
)
{
return
UrlBuilder
.
fromBaseUrl
(
source
.
authorize
())
.
queryParam
(
"appid"
,
config
.
getClientId
())
.
queryParam
(
"redirect_uri"
,
config
.
getRedirectUri
())
.
queryParam
(
"state"
,
getRealState
(
state
))
.
queryParam
(
"usertype"
,
config
.
getUsertype
())
.
build
();
}
@Override
public
AuthResponse
login
(
AuthCallback
authCallback
)
{
try
{
if
(!
config
.
isIgnoreCheckState
())
{
AuthChecker
.
checkState
(
authCallback
.
getState
(),
source
,
authStateCache
);
}
AuthToken
authToken
=
this
.
getAccessToken
(
authCallback
);
AuthUser
user
=
this
.
getUserInfo
(
authToken
);
return
AuthResponse
.
builder
().
code
(
AuthResponseStatus
.
SUCCESS
.
getCode
()).
data
(
user
).
build
();
}
catch
(
Exception
e
)
{
Log
.
error
(
"Failed to login with oauth authorization."
,
e
);
return
this
.
responseError
(
e
);
}
}
@Override
protected
AuthToken
getAccessToken
(
AuthCallback
authCallback
)
{
try
{
String
response
=
doGetAuthorizationCode
(
accessTokenUrl
());
JSONObject
object
=
this
.
checkResponse
(
response
);
AuthToken
authToken
=
AuthToken
.
builder
()
.
accessToken
(
object
.
getString
(
"provider_access_token"
))
.
expireIn
(
object
.
getIntValue
(
"expires_in"
))
.
build
();
return
authToken
;
}
catch
(
Exception
e
)
{
throw
new
AuthException
(
"企业微信获取token失败"
,
e
);
}
}
@Override
protected
String
doGetAuthorizationCode
(
String
code
)
{
JSONObject
data
=
new
JSONObject
();
data
.
put
(
"corpid"
,
config
.
getClientId
());
data
.
put
(
"provider_secret"
,
config
.
getClientSecret
());
return
new
HttpUtils
(
config
.
getHttpConfig
()).
post
(
accessTokenUrl
(
code
),
data
.
toJSONString
());
}
/**
* 获取token的URL
*
* @return
*/
protected
String
accessTokenUrl
()
{
return
UrlBuilder
.
fromBaseUrl
(
source
.
accessToken
())
.
build
();
}
@Override
protected
AuthUser
getUserInfo
(
AuthToken
authToken
)
{
JSONObject
response
=
this
.
checkResponse
(
doGetUserInfo
(
authToken
));
return
AuthUser
.
builder
()
.
rawUserInfo
(
response
)
.
build
();
}
protected
String
doGetUserInfo
(
AuthToken
authToken
)
{
JSONObject
data
=
new
JSONObject
();
data
.
put
(
"auth_code"
,
authToken
.
getCode
());
return
new
HttpUtils
(
config
.
getHttpConfig
())
.
post
(
userInfoUrl
(
authToken
),
data
.
toJSONString
());
}
protected
String
userInfoUrl
(
AuthToken
authToken
)
{
return
UrlBuilder
.
fromBaseUrl
(
source
.
userInfo
())
.
queryParam
(
"access_token"
,
authToken
.
getAccessToken
()).
build
();
}
private
JSONObject
checkResponse
(
String
response
)
{
JSONObject
object
=
JSONObject
.
parseObject
(
response
);
if
(
object
.
containsKey
(
"errcode"
)
&&
object
.
getIntValue
(
"errcode"
)
!=
0
)
{
throw
new
AuthException
(
object
.
getString
(
"errmsg"
),
source
);
}
return
object
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录