Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
My_csdo
JustAuth
提交
d9952968
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看板
提交
d9952968
编写于
9月 10, 2019
作者:
H
harrylee
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
📝
集成京东
上级
80f2dbda
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
125 addition
and
0 deletion
+125
-0
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
+25
-0
src/main/java/me/zhyd/oauth/request/AuthJdRequest.java
src/main/java/me/zhyd/oauth/request/AuthJdRequest.java
+100
-0
未找到文件。
src/main/java/me/zhyd/oauth/config/AuthDefaultSource.java
浏览文件 @
d9952968
...
...
@@ -672,6 +672,31 @@ public enum AuthDefaultSource implements AuthSource {
public
String
refresh
()
{
return
"https://open-api.shop.ele.me/token"
;
}
},
/**
* 京东
* @since
*/
JD
{
@Override
public
String
authorize
()
{
return
"https://open-oauth.jd.com/oauth2/to_login"
;
}
@Override
public
String
accessToken
()
{
return
"https://open-oauth.jd.com/oauth2/access_token"
;
}
@Override
public
String
userInfo
()
{
return
null
;
}
@Override
public
String
refresh
()
{
return
"https://open-oauth.jd.com/oauth2/refresh_token"
;
}
}
}
src/main/java/me/zhyd/oauth/request/AuthJdRequest.java
0 → 100644
浏览文件 @
d9952968
package
me.zhyd.oauth.request
;
import
cn.hutool.http.HttpRequest
;
import
cn.hutool.http.HttpResponse
;
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.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.UrlBuilder
;
/**
* 京东登录
*
* @author harry.lee (harryleexyz@qq.com)
* @since
*/
public
class
AuthJdRequest
extends
AuthDefaultRequest
{
public
AuthJdRequest
(
AuthConfig
config
)
{
super
(
config
,
AuthDefaultSource
.
JD
);
}
public
AuthJdRequest
(
AuthConfig
config
,
AuthStateCache
authStateCache
)
{
super
(
config
,
AuthDefaultSource
.
JD
,
authStateCache
);
}
@Override
protected
AuthToken
getAccessToken
(
AuthCallback
authCallback
)
{
HttpResponse
response
=
HttpRequest
.
post
(
source
.
accessToken
())
.
form
(
"app_key"
,
config
.
getClientId
())
.
form
(
"app_secret"
,
config
.
getClientSecret
())
.
form
(
"grant_type"
,
"authorization_code"
)
.
form
(
"code"
,
authCallback
.
getCode
())
.
execute
();
JSONObject
object
=
JSONObject
.
parseObject
(
response
.
body
());
this
.
checkResponse
(
object
);
return
AuthToken
.
builder
()
.
accessToken
(
object
.
getString
(
"access_token"
))
.
expireIn
(
object
.
getIntValue
(
"expires_in"
))
.
refreshToken
(
object
.
getString
(
"refresh_token"
))
.
scope
(
object
.
getString
(
"scope"
))
.
openId
(
object
.
getString
(
"open_id"
))
.
build
();
}
@Override
protected
AuthUser
getUserInfo
(
AuthToken
authToken
)
{
return
null
;
}
@Override
public
AuthResponse
refresh
(
AuthToken
oldToken
)
{
HttpResponse
response
=
HttpRequest
.
post
(
source
.
refresh
())
.
form
(
"app_key"
,
config
.
getClientId
())
.
form
(
"app_secret"
,
config
.
getClientSecret
())
.
form
(
"grant_type"
,
"refresh_token"
)
.
form
(
"refresh_token"
,
oldToken
.
getRefreshToken
())
.
execute
();
JSONObject
object
=
JSONObject
.
parseObject
(
response
.
body
());
this
.
checkResponse
(
object
);
return
AuthResponse
.
builder
()
.
code
(
AuthResponseStatus
.
SUCCESS
.
getCode
())
.
data
(
AuthToken
.
builder
()
.
accessToken
(
object
.
getString
(
"access_token"
))
.
expireIn
(
object
.
getIntValue
(
"expires_in"
))
.
refreshToken
(
object
.
getString
(
"refresh_token"
))
.
scope
(
object
.
getString
(
"scope"
))
.
openId
(
object
.
getString
(
"open_id"
))
.
build
())
.
build
();
}
private
void
checkResponse
(
JSONObject
object
)
{
if
(
object
.
containsKey
(
"msg"
))
{
throw
new
AuthException
(
object
.
getString
(
"msg"
));
}
}
@Override
public
String
authorize
(
String
state
)
{
return
UrlBuilder
.
fromBaseUrl
(
source
.
authorize
())
.
queryParam
(
"app_key"
,
config
.
getClientId
())
.
queryParam
(
"response_type"
,
"code"
)
.
queryParam
(
"redirect_uri"
,
config
.
getRedirectUri
())
.
queryParam
(
"scope"
,
"snsapi_base"
)
.
queryParam
(
"state"
,
getRealState
(
state
))
.
build
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录