Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
My_csdo
JustAuth
提交
8d1f700e
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看板
提交
8d1f700e
编写于
7月 17, 2019
作者:
H
Hongwei Peng
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
integrate Renren
上级
d977e05a
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
167 addition
and
1 deletion
+167
-1
src/main/java/me/zhyd/oauth/config/AuthSource.java
src/main/java/me/zhyd/oauth/config/AuthSource.java
+26
-1
src/main/java/me/zhyd/oauth/request/AuthRenrenRequest.java
src/main/java/me/zhyd/oauth/request/AuthRenrenRequest.java
+92
-0
src/main/java/me/zhyd/oauth/url/AuthRenrenUrlBuilder.java
src/main/java/me/zhyd/oauth/url/AuthRenrenUrlBuilder.java
+49
-0
未找到文件。
src/main/java/me/zhyd/oauth/config/AuthSource.java
浏览文件 @
8d1f700e
...
...
@@ -444,6 +444,31 @@ public enum AuthSource {
public
String
userInfo
()
{
return
"https://api.teambition.com/users/me"
;
}
},
/**
* 人人网
*/
RENREN
{
@Override
public
String
authorize
()
{
return
"https://graph.renren.com/oauth/authorize"
;
}
@Override
public
String
accessToken
()
{
return
"https://graph.renren.com/oauth/token"
;
}
@Override
public
String
refresh
()
{
return
"https://graph.renren.com/oauth/token"
;
}
@Override
public
String
userInfo
()
{
return
"https://api.renren.com/v2/user/get"
;
}
};
/**
...
...
@@ -485,4 +510,4 @@ public enum AuthSource {
throw
new
AuthException
(
AuthResponseStatus
.
UNSUPPORTED
);
}
}
\ No newline at end of file
}
src/main/java/me/zhyd/oauth/request/AuthRenrenRequest.java
0 → 100644
浏览文件 @
8d1f700e
package
me.zhyd.oauth.request
;
import
cn.hutool.http.HttpRequest
;
import
cn.hutool.http.HttpResponse
;
import
com.alibaba.fastjson.JSONArray
;
import
com.alibaba.fastjson.JSONObject
;
import
me.zhyd.oauth.config.AuthConfig
;
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.model.AuthUserGender
;
import
me.zhyd.oauth.url.AuthRenrenUrlBuilder
;
import
me.zhyd.oauth.url.entity.AuthUserInfoEntity
;
import
java.util.Objects
;
import
static
me
.
zhyd
.
oauth
.
config
.
AuthSource
.
RENREN
;
/**
* 人人登录
*
* @author hongwei.peng (pengisgood(at)gmail(dot)com)
* @version 1.8.1
* @since 1.8.1
*/
public
class
AuthRenrenRequest
extends
AuthDefaultRequest
{
public
AuthRenrenRequest
(
AuthConfig
config
)
{
super
(
config
,
RENREN
,
new
AuthRenrenUrlBuilder
());
}
@Override
protected
AuthToken
getAccessToken
(
AuthCallback
authCallback
)
{
String
accessTokenUrl
=
this
.
urlBuilder
.
getAccessTokenUrl
(
authCallback
.
getCode
());
HttpResponse
response
=
HttpRequest
.
post
(
accessTokenUrl
).
execute
();
JSONObject
accessTokenObject
=
JSONObject
.
parseObject
(
response
.
body
());
if
(!
response
.
isOk
())
{
throw
new
AuthException
(
"Unable to get token from renren using code ["
+
authCallback
.
getCode
()
+
"]: "
+
accessTokenObject
);
}
return
AuthToken
.
builder
()
.
accessToken
(
accessTokenObject
.
getString
(
"access_token"
))
.
refreshToken
(
accessTokenObject
.
getString
(
"refresh_token"
))
.
openId
(
accessTokenObject
.
getJSONObject
(
"user"
).
getString
(
"id"
))
.
build
();
}
@Override
protected
AuthUser
getUserInfo
(
AuthToken
authToken
)
{
String
accessToken
=
authToken
.
getAccessToken
();
HttpResponse
response
=
HttpRequest
.
get
(
this
.
urlBuilder
.
getUserInfoUrl
(
AuthUserInfoEntity
.
builder
()
.
openId
(
authToken
.
getOpenId
())
.
accessToken
(
accessToken
)
.
build
())).
execute
();
JSONObject
userObj
=
JSONObject
.
parseObject
(
response
.
body
()).
getJSONObject
(
"response"
);
return
AuthUser
.
builder
()
.
uuid
(
userObj
.
getString
(
"id"
))
.
avatar
(
getAvatarUrl
(
userObj
))
.
nickname
(
userObj
.
getString
(
"name"
))
.
company
(
getCompany
(
userObj
))
.
gender
(
getGender
(
userObj
))
.
token
(
authToken
)
.
source
(
RENREN
)
.
build
();
}
private
String
getAvatarUrl
(
JSONObject
userObj
)
{
JSONArray
jsonArray
=
userObj
.
getJSONArray
(
"avatar"
);
if
(
Objects
.
isNull
(
jsonArray
)
||
jsonArray
.
isEmpty
())
{
return
null
;
}
return
jsonArray
.
getJSONObject
(
0
).
getString
(
"url"
);
}
private
AuthUserGender
getGender
(
JSONObject
userObj
)
{
JSONObject
basicInformation
=
userObj
.
getJSONObject
(
"basicInformation"
);
if
(
Objects
.
isNull
(
basicInformation
))
{
return
AuthUserGender
.
UNKNOW
;
}
return
AuthUserGender
.
getRealGender
(
basicInformation
.
getString
(
"sex"
));
}
private
String
getCompany
(
JSONObject
userObj
)
{
JSONArray
jsonArray
=
userObj
.
getJSONArray
(
"work"
);
if
(
Objects
.
isNull
(
jsonArray
)
||
jsonArray
.
isEmpty
())
{
return
null
;
}
return
jsonArray
.
getJSONObject
(
0
).
getString
(
"name"
);
}
}
src/main/java/me/zhyd/oauth/url/AuthRenrenUrlBuilder.java
0 → 100644
浏览文件 @
8d1f700e
package
me.zhyd.oauth.url
;
import
me.zhyd.oauth.exception.AuthException
;
import
me.zhyd.oauth.model.AuthResponseStatus
;
import
me.zhyd.oauth.url.entity.AuthUserInfoEntity
;
import
java.text.MessageFormat
;
import
static
me
.
zhyd
.
oauth
.
config
.
AuthSource
.
RENREN
;
/**
* 人人网相关的URL构建类
*
* @author hongwei.peng (pengisgood(at)gmail(dot)com)
* @version 1.8.1
* @since 1.8.1
*/
public
class
AuthRenrenUrlBuilder
extends
AuthDefaultUrlBuilder
{
private
static
final
String
RENREN_ACCESS_TOKEN_PATTERN
=
"{0}?client_id={1}&client_secret={2}&grant_type=authorization_code&code={3}&redirect_uri={4}"
;
private
static
final
String
RENREN_USER_INFO_PATTERN
=
"{0}?access_token={1}&userId={2}"
;
private
static
final
String
RENREN_AUTHORIZE_PATTERN
=
"{0}?client_id={1}&response_type=code&redirect_uri={2}&state={3}"
;
private
static
final
String
RENREN_REFRESH_PATTERN
=
"{0}?refresh_token={1}&client_id={2}&client_secret={3}&grant_type=refresh_token"
;
@Override
public
String
getAccessTokenUrl
(
String
code
)
{
return
MessageFormat
.
format
(
RENREN_ACCESS_TOKEN_PATTERN
,
RENREN
.
accessToken
(),
config
.
getClientId
(),
config
.
getClientSecret
(),
code
,
config
.
getRedirectUri
());
}
@Override
public
String
getUserInfoUrl
(
AuthUserInfoEntity
userInfoEntity
)
{
return
MessageFormat
.
format
(
RENREN_USER_INFO_PATTERN
,
RENREN
.
userInfo
(),
userInfoEntity
.
getAccessToken
(),
userInfoEntity
.
getOpenId
());
}
@Override
public
String
getAuthorizeUrl
()
{
return
MessageFormat
.
format
(
RENREN_AUTHORIZE_PATTERN
,
RENREN
.
authorize
(),
config
.
getClientId
(),
config
.
getRedirectUri
(),
this
.
getRealState
(
config
.
getState
()));
}
@Override
public
String
getRefreshUrl
(
String
refreshToken
)
{
return
MessageFormat
.
format
(
RENREN_REFRESH_PATTERN
,
RENREN
.
refresh
(),
refreshToken
,
config
.
getClientId
(),
config
.
getClientSecret
());
}
@Override
public
String
getRevokeUrl
(
String
accessToken
)
{
throw
new
AuthException
(
AuthResponseStatus
.
UNSUPPORTED
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录