Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
O
order-group
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
order-group-application
order-group
Commits
70b9dc99
Commit
70b9dc99
authored
Aug 15, 2022
by
周晓航
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
支付接口合规改造
parent
e22e581a
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
13 deletions
+23
-13
order-application-service/src/main/java/cn/freemud/interceptor/FeignInterceptor.java
+23
-13
No files found.
order-application-service/src/main/java/cn/freemud/interceptor/FeignInterceptor.java
View file @
70b9dc99
...
@@ -4,50 +4,60 @@ import cn.freemud.utils.AppLogUtil;
...
@@ -4,50 +4,60 @@ import cn.freemud.utils.AppLogUtil;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSON
;
import
feign.RequestInterceptor
;
import
feign.RequestInterceptor
;
import
feign.RequestTemplate
;
import
feign.RequestTemplate
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.context.annotation.Configuration
;
import
org.springframework.web.context.request.RequestContextHolder
;
import
org.springframework.web.context.request.RequestContextHolder
;
import
org.springframework.web.context.request.ServletRequestAttributes
;
import
org.springframework.web.context.request.ServletRequestAttributes
;
import
javax.servlet.http.HttpServletRequest
;
import
javax.servlet.http.HttpServletRequest
;
import
java.util.Arrays
;
import
java.util.*
;
import
java.util.Enumeration
;
import
java.util.LinkedHashMap
;
import
java.util.Map
;
@Configuration
@Configuration
public
class
FeignInterceptor
implements
RequestInterceptor
{
public
class
FeignInterceptor
implements
RequestInterceptor
{
@Value
(
"${forward.feign.headers:x-forwarded-for, x-real-ip}"
)
private
Set
<
String
>
needHeaders
;
@Override
@Override
public
void
apply
(
RequestTemplate
requestTemplate
)
{
public
void
apply
(
RequestTemplate
requestTemplate
)
{
Map
<
String
,
String
>
headers
=
getHeaders
(
getHttpServletRequest
());
HttpServletRequest
httpServletRequest
=
this
.
getHttpServletRequest
();
for
(
String
headerName
:
headers
.
keySet
()){
if
(
Objects
.
nonNull
(
httpServletRequest
))
{
Map
<
String
,
String
>
headers
=
getHeaders
(
httpServletRequest
);
for
(
String
headerName
:
headers
.
keySet
())
{
requestTemplate
.
header
(
headerName
,
getHeaders
(
getHttpServletRequest
()).
get
(
headerName
));
requestTemplate
.
header
(
headerName
,
getHeaders
(
getHttpServletRequest
()).
get
(
headerName
));
}
}
}
}
}
private
HttpServletRequest
getHttpServletRequest
()
{
private
HttpServletRequest
getHttpServletRequest
()
{
try
{
try
{
return
((
ServletRequestAttributes
)
RequestContextHolder
.
getRequestAttributes
()).
getRequest
();
ServletRequestAttributes
requestAttributes
=
(
ServletRequestAttributes
)
RequestContextHolder
.
getRequestAttributes
();
if
(
Objects
.
isNull
(
requestAttributes
))
{
return
null
;
}
return
requestAttributes
.
getRequest
();
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
AppLogUtil
.
errorLog
(
"FeignInterceptor error {}"
,
""
,
""
,
e
);
AppLogUtil
.
errorLog
(
"FeignInterceptor error {}"
,
""
,
""
,
e
);
return
null
;
return
null
;
}
}
}
}
private
Map
<
String
,
String
>
getHeaders
(
HttpServletRequest
request
)
{
private
Map
<
String
,
String
>
getHeaders
(
HttpServletRequest
request
)
{
Map
<
String
,
String
>
map
=
new
LinkedHashMap
<>();
Map
<
String
,
String
>
map
=
new
LinkedHashMap
<>();
Enumeration
<
String
>
enumeration
=
request
.
getHeaderNames
();
Enumeration
<
String
>
enumeration
=
request
.
getHeaderNames
();
while
(
enumeration
.
hasMoreElements
())
{
while
(
enumeration
.
hasMoreElements
())
{
String
key
=
enumeration
.
nextElement
();
String
key
=
enumeration
.
nextElement
();
if
(
needThisHeader
(
key
))
{
if
(
needThisHeader
(
key
))
{
String
value
=
request
.
getHeader
(
key
);
String
value
=
request
.
getHeader
(
key
);
map
.
put
(
key
,
value
);
map
.
put
(
key
,
value
);
}
}
}
}
AppLogUtil
.
printLog
(
"clientIp for feign client info:"
+
JSON
.
toJSONString
(
map
),
""
,
""
);
AppLogUtil
.
printLog
(
"clientIp for feign client info:"
+
JSON
.
toJSONString
(
map
),
""
,
""
);
return
map
;
return
map
;
}
}
private
boolean
needThisHeader
(
String
headerName
){
private
boolean
needThisHeader
(
String
headerName
)
{
// TODO:过滤哪些header需要传递,千万不能把所有的header传下去
// TODO:过滤哪些header需要传递,千万不能把所有的header传下去
String
[]
needHeaders
=
{
"x-forwarded-for"
,
"x-real-ip"
};
return
needHeaders
.
contains
(
headerName
);
return
Arrays
.
asList
(
needHeaders
).
contains
(
headerName
);
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment