Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
yujianwangzivayy
MaxKey
提交
ff5d2dfd
MaxKey
项目概览
yujianwangzivayy
/
MaxKey
与 Fork 源项目一致
Fork自
MaxKey单点登录官方(MaxKeyTop) / MaxKey
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MaxKey
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ff5d2dfd
编写于
8月 08, 2020
作者:
MaxKey单点登录官方
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
CAS Parameters Support
上级
3bf2566f
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
40 addition
and
6 deletion
+40
-6
maxkey-core/src/main/java/org/maxkey/web/WebContext.java
maxkey-core/src/main/java/org/maxkey/web/WebContext.java
+10
-0
maxkey-protocols/maxkey-protocol-cas/src/main/java/org/maxkey/authz/cas/endpoint/CasAuthorizeEndpoint.java
...a/org/maxkey/authz/cas/endpoint/CasAuthorizeEndpoint.java
+28
-6
maxkey-protocols/maxkey-protocol-cas/src/main/java/org/maxkey/authz/cas/endpoint/ticket/CasConstants.java
...va/org/maxkey/authz/cas/endpoint/ticket/CasConstants.java
+2
-0
未找到文件。
maxkey-core/src/main/java/org/maxkey/web/WebContext.java
浏览文件 @
ff5d2dfd
...
...
@@ -323,6 +323,16 @@ public final class WebContext {
return
locale
;
}
public
static
Map
<
String
,
String
>
getRequestParameterMap
(
HttpServletRequest
request
)
{
Map
<
String
,
String
>
map
=
new
HashMap
<
String
,
String
>();
Map
<
String
,
String
[]>
parameters
=
request
.
getParameterMap
();
for
(
String
key
:
parameters
.
keySet
())
{
String
[]
values
=
parameters
.
get
(
key
);
map
.
put
(
key
,
values
!=
null
&&
values
.
length
>
0
?
values
[
0
]
:
null
);
}
return
map
;
}
/**
* 根据名字获取cookie.
*
...
...
maxkey-protocols/maxkey-protocol-cas/src/main/java/org/maxkey/authz/cas/endpoint/CasAuthorizeEndpoint.java
浏览文件 @
ff5d2dfd
...
...
@@ -21,6 +21,7 @@
package
org.maxkey.authz.cas.endpoint
;
import
java.util.List
;
import
java.util.Map
;
import
javax.servlet.http.HttpServletRequest
;
import
javax.servlet.http.HttpServletResponse
;
...
...
@@ -61,7 +62,7 @@ public class CasAuthorizeEndpoint extends CasBaseAuthorizeEndpoint{
casDetails
=(
casDetailsList
!=
null
&&
casDetailsList
.
size
()==
1
)?
casDetailsList
.
get
(
0
):
null
;
return
buildCasModelAndView
(
casDetails
);
return
buildCasModelAndView
(
request
,
response
,
casDetails
);
}
...
...
@@ -73,13 +74,20 @@ public class CasAuthorizeEndpoint extends CasBaseAuthorizeEndpoint{
AppsCasDetails
casDetails
=
casDetailsService
.
getAppDetails
(
id
);
return
buildCasModelAndView
(
casDetails
);
return
buildCasModelAndView
(
request
,
response
,
casDetails
);
}
private
ModelAndView
buildCasModelAndView
(
AppsCasDetails
casDetails
){
private
ModelAndView
buildCasModelAndView
(
HttpServletRequest
request
,
HttpServletResponse
response
,
AppsCasDetails
casDetails
){
_logger
.
debug
(
""
+
casDetails
);
WebContext
.
setAttribute
(
CasConstants
.
PARAMETER
.
PARAMETER_MAP
,
WebContext
.
getRequestParameterMap
(
request
)
);
WebContext
.
setAttribute
(
CasConstants
.
PARAMETER
.
ENDPOINT_CAS_DETAILS
,
casDetails
);
WebContext
.
setAttribute
(
WebConstants
.
SINGLE_SIGN_ON_APP_ID
,
casDetails
.
getId
());
WebContext
.
setAttribute
(
AuthorizeBaseEndpoint
.
class
.
getName
(),
casDetails
);
...
...
@@ -101,9 +109,23 @@ public class CasAuthorizeEndpoint extends CasBaseAuthorizeEndpoint{
callbackUrl
.
append
(
"?"
);
}
callbackUrl
.
append
(
CasConstants
.
PARAMETER
.
TICKET
).
append
(
"="
).
append
(
ticket
)
.
append
(
"&"
)
.
append
(
CasConstants
.
PARAMETER
.
SERVICE
).
append
(
"="
).
append
(
casDetails
.
getService
());
//append ticket
callbackUrl
.
append
(
CasConstants
.
PARAMETER
.
TICKET
).
append
(
"="
).
append
(
ticket
);
callbackUrl
.
append
(
"&"
);
//append service
callbackUrl
.
append
(
CasConstants
.
PARAMETER
.
SERVICE
).
append
(
"="
).
append
(
casDetails
.
getService
());
//增加可自定义的参数
if
(
WebContext
.
getAttribute
(
CasConstants
.
PARAMETER
.
PARAMETER_MAP
)!=
null
)
{
@SuppressWarnings
(
"unchecked"
)
Map
<
String
,
String
>
parameterMap
=
(
Map
<
String
,
String
>)
WebContext
.
getAttribute
(
CasConstants
.
PARAMETER
.
PARAMETER_MAP
);
parameterMap
.
remove
(
CasConstants
.
PARAMETER
.
TICKET
);
parameterMap
.
remove
(
CasConstants
.
PARAMETER
.
SERVICE
);
for
(
String
key
:
parameterMap
.
keySet
())
{
callbackUrl
.
append
(
"&"
).
append
(
key
).
append
(
parameterMap
.
get
(
key
));
}
}
_logger
.
debug
(
"redirect to CAS Client URL "
+
callbackUrl
);
...
...
maxkey-protocols/maxkey-protocol-cas/src/main/java/org/maxkey/authz/cas/endpoint/ticket/CasConstants.java
浏览文件 @
ff5d2dfd
...
...
@@ -23,6 +23,8 @@ public class CasConstants {
public
static
final
class
PARAMETER
{
public
final
static
String
ENDPOINT_CAS_DETAILS
=
"CAS_AUTHORIZE_ENDPOINT_CAS_DETAILS"
;
public
final
static
String
PARAMETER_MAP
=
"CAS_AUTHORIZE_ENDPOINT_PARAMETER_MAP"
;
/** Constant representing the ticket parameter in the request. */
public
final
static
String
TICKET
=
"ticket"
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录