Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yanxuan-qc-change-system
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
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
胡园园
yanxuan-qc-change-system
Commits
6d6a725e
Commit
6d6a725e
authored
Dec 16, 2022
by
穆龙飞
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
modify:修改邮件发送逻辑
parent
1c11b477
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
602 additions
and
7 deletions
+602
-7
application.properties
...y/src/main/resources/config/online/application.properties
+2
-0
application.properties
...bly/src/main/resources/config/test/application.properties
+2
-0
Checker.java
...tease/mail/yanxuan/change/integration/client/Checker.java
+11
-0
HttpClientTemplate.java
...yanxuan/change/integration/client/HttpClientTemplate.java
+0
-0
LabelLevel.java
...se/mail/yanxuan/change/integration/client/LabelLevel.java
+36
-0
RpcListResult.java
...mail/yanxuan/change/integration/client/RpcListResult.java
+27
-0
RpcObjectData.java
...mail/yanxuan/change/integration/client/RpcObjectData.java
+27
-0
RpcObjectDataMsg.java
...l/yanxuan/change/integration/client/RpcObjectDataMsg.java
+29
-0
RpcObjectResult.java
...il/yanxuan/change/integration/client/RpcObjectResult.java
+27
-0
RpcTemplate.java
...e/mail/yanxuan/change/integration/client/RpcTemplate.java
+342
-0
SinoInfoRpcObjectData.java
...xuan/change/integration/client/SinoInfoRpcObjectData.java
+26
-0
SinoRpcObjectData.java
.../yanxuan/change/integration/client/SinoRpcObjectData.java
+21
-0
TrustAnyStrategy.java
...l/yanxuan/change/integration/client/TrustAnyStrategy.java
+28
-0
UasClientServiceImpl.java
.../integration/email/service/impl/UasClientServiceImpl.java
+24
-7
No files found.
yanxuan-qc-change-system-assembly/src/main/resources/config/online/application.properties
View file @
6d6a725e
env
=
online
dschedule.enable
=
true
dschedule.env
=
online
dschedule.app-id
=
yanxuan-sc-ehc
...
...
yanxuan-qc-change-system-assembly/src/main/resources/config/test/application.properties
View file @
6d6a725e
env
=
test
dschedule.enable
=
true
dschedule.env
=
test
dschedule.app-id
=
yanxuan-qc-change-system
...
...
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/Checker.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
public
interface
Checker
{
/**
* 校验结果是否成功
*
* @return
*/
boolean
check
();
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/HttpClientTemplate.java
0 → 100644
View file @
6d6a725e
This diff is collapsed.
Click to expand it.
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/LabelLevel.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
public
class
LabelLevel
{
/**
* 分类信息,100:色情,110:性感,200:广告,210:二维码,300:暴恐,400:违禁,500:涉政
*/
private
int
label
;
/**
* 分类级别,0:正常,1:不确定,2:确定
*/
private
int
level
;
public
LabelLevel
()
{}
public
LabelLevel
(
int
label
,
int
level
)
{
this
.
label
=
label
;
this
.
level
=
level
;
}
public
int
getLabel
()
{
return
label
;
}
public
void
setLabel
(
int
label
)
{
this
.
label
=
label
;
}
public
int
getLevel
()
{
return
level
;
}
public
void
setLevel
(
int
level
)
{
this
.
level
=
level
;
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/RpcListResult.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.netease.mail.yanxuan.change.integration.rpc.RpcResultException
;
import
java.io.IOException
;
import
java.util.List
;
public
class
RpcListResult
<
T
>
implements
RpcTemplate
.
CallHandler
<
List
<
T
>>
{
private
final
Class
<
T
>
tClass
;
public
RpcListResult
(
Class
<
T
>
tClass
)
{
this
.
tClass
=
tClass
;
}
@Override
public
List
<
T
>
handle
(
String
resp
)
throws
IOException
{
JSONObject
rpcResult
=
JSON
.
parseObject
(
resp
);
int
code
=
rpcResult
.
getIntValue
(
"code"
);
if
(
code
==
200
)
{
return
JSON
.
parseArray
(
rpcResult
.
getString
(
"result"
),
tClass
);
}
throw
new
RpcResultException
(
"response error, code = "
+
code
);
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/RpcObjectData.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.netease.mail.yanxuan.change.integration.rpc.RpcResultException
;
import
java.io.IOException
;
public
class
RpcObjectData
<
T
>
implements
RpcTemplate
.
CallHandler
<
T
>
{
private
Class
<
T
>
tClass
;
public
RpcObjectData
(
Class
<
T
>
tClass
)
{
this
.
tClass
=
tClass
;
}
@Override
public
T
handle
(
String
resp
)
throws
IOException
{
JSONObject
rpcResult
=
JSON
.
parseObject
(
resp
);
int
code
=
rpcResult
.
getIntValue
(
"code"
);
if
(
code
==
200
)
{
return
JSON
.
parseObject
(
rpcResult
.
getString
(
"data"
),
tClass
);
}
throw
new
RpcResultException
(
"response error, code = "
+
code
);
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/RpcObjectDataMsg.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.netease.mail.yanxuan.change.integration.rpc.RpcResultException
;
import
lombok.SneakyThrows
;
import
java.io.IOException
;
public
class
RpcObjectDataMsg
<
T
>
implements
RpcTemplate
.
CallHandler
<
T
>
{
private
Class
<
T
>
tClass
;
public
RpcObjectDataMsg
(
Class
<
T
>
tClass
)
{
this
.
tClass
=
tClass
;
}
@SneakyThrows
@Override
public
T
handle
(
String
resp
)
throws
IOException
{
JSONObject
rpcResult
=
JSON
.
parseObject
(
resp
);
int
code
=
rpcResult
.
getIntValue
(
"code"
);
if
(
code
==
200
)
{
return
JSON
.
parseObject
(
rpcResult
.
getString
(
"data"
),
tClass
);
}
throw
new
RpcResultException
(
rpcResult
.
getString
(
"msg"
));
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/RpcObjectResult.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.netease.mail.yanxuan.change.integration.rpc.RpcResultException
;
import
java.io.IOException
;
public
class
RpcObjectResult
<
T
>
implements
RpcTemplate
.
CallHandler
<
T
>
{
private
Class
<
T
>
tClass
;
public
RpcObjectResult
(
Class
<
T
>
tClass
)
{
this
.
tClass
=
tClass
;
}
@Override
public
T
handle
(
String
resp
)
throws
IOException
{
JSONObject
rpcResult
=
JSON
.
parseObject
(
resp
);
int
code
=
rpcResult
.
getIntValue
(
"code"
);
if
(
code
==
200
)
{
return
JSON
.
parseObject
(
rpcResult
.
getString
(
"result"
),
tClass
);
}
throw
new
RpcResultException
(
"response error, code = "
+
code
);
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/RpcTemplate.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.parser.ParserConfig
;
import
com.netease.mail.yanxuan.change.integration.email.exception.RpcException
;
import
com.netease.mail.yanxuan.change.integration.email.exception.RpcTimeoutException
;
import
com.netease.mail.yanxuan.change.integration.email.util.EncodeUtil
;
import
com.netease.mail.yanxuan.change.integration.email.util.HttpClientUtil
;
import
com.netease.yanxuan.missa.pressure.TracerClient
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.stereotype.Component
;
import
org.springframework.util.CollectionUtils
;
import
org.springframework.util.StringUtils
;
import
java.io.IOException
;
import
java.util.List
;
import
java.util.Map
;
@Component
public
class
RpcTemplate
{
private
static
final
Logger
LOG
=
LoggerFactory
.
getLogger
(
RpcTemplate
.
class
);
@Value
(
"${act.rpc.get.retry:1}"
)
private
int
rpcGetRetry
;
@Value
(
"${act.rpc.post.retry:0}"
)
private
int
rpcPostRetry
;
@Value
(
"${act.rpc.collect:false}"
)
private
boolean
rpcCollect
;
public
RpcTemplate
()
{
ParserConfig
.
getGlobalInstance
().
setAutoTypeSupport
(
true
);
}
/**
* Get请求
*
* @param url
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
get
(
String
url
,
CallHandler
<
T
>
handler
)
{
return
get
(
url
,
null
,
null
,
-
1
,
handler
);
}
/**
* Get请求
*
* @param url
* @param params
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
get
(
String
url
,
Map
<
String
,
Object
>
params
,
CallHandler
<
T
>
handler
)
{
return
get
(
url
,
params
,
null
,
-
1
,
handler
);
}
/**
* Get请求
*
* @param url
* @param params
* @param header
* @param timeout
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
get
(
String
url
,
Map
<
String
,
Object
>
params
,
Map
<
String
,
String
>
header
,
int
timeout
,
CallHandler
<
T
>
handler
)
{
CallTemplate
template
=
()
->
HttpClientUtil
.
get
(
url
,
params
,
header
,
timeout
);
return
this
.
execute
(
url
,
params
,
handler
,
template
,
rpcGetRetry
,
Method
.
GET
);
}
/**
* Post请求
*
* @param url
* @param params
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
post
(
String
url
,
Map
<
String
,
Object
>
params
,
CallHandler
<
T
>
handler
)
{
return
post
(
url
,
params
,
-
1
,
handler
);
}
/**
* Post请求
*
* @param url
* @param params
* @param timeout
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
post
(
String
url
,
Map
<
String
,
Object
>
params
,
int
timeout
,
CallHandler
<
T
>
handler
)
{
CallTemplate
template
=
()
->
HttpClientUtil
.
post
(
url
,
params
,
timeout
);
return
this
.
execute
(
url
,
params
,
handler
,
template
,
rpcPostRetry
,
Method
.
POST
);
}
/**
* Post Json请求
*
* @param url
* @param params
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
postJson
(
String
url
,
String
params
,
CallHandler
<
T
>
handler
)
{
return
postJson
(
url
,
params
,
-
1
,
handler
);
}
/**
* Post Json请求
*
* @param url
* @param params
* @param timeout
* @param handler
* @param <T>
* @return
*/
public
<
T
>
T
postJson
(
String
url
,
String
params
,
int
timeout
,
CallHandler
<
T
>
handler
)
{
CallTemplate
template
=
()
->
HttpClientUtil
.
postJson
(
url
,
params
,
timeout
);
return
this
.
execute
(
url
,
params
,
handler
,
template
,
rpcPostRetry
,
Method
.
BODY
);
}
/**
* 执行模板调用
*
* @param url
* 请求地址
* @param params
* 请求报文
* @param handler
* 返回解析
* @param callTemplate
* 模板调用
* @param retryTime
* 最多重复次数,0默认(3次)
*/
private
<
T
>
T
execute
(
String
url
,
Object
params
,
CallHandler
<
T
>
handler
,
CallTemplate
callTemplate
,
int
retryTime
,
Method
method
)
{
int
tryTimes
=
0
;
RpcException
rpcException
=
null
;
String
respBody
=
null
;
RpcStatus
status
=
RpcStatus
.
SUCCESS
;
while
(
tryTimes
<=
retryTime
)
{
long
startTime
=
System
.
currentTimeMillis
();
try
{
respBody
=
callTemplate
.
executeCall
();
if
(
StringUtils
.
isEmpty
(
respBody
))
{
throw
new
RpcException
(
"response empty"
);
}
T
t
=
handler
.
handle
(
respBody
);
status
=
checkResp
(
handler
,
t
);
return
t
;
}
catch
(
RpcTimeoutException
e
)
{
rpcException
=
e
;
status
=
RpcStatus
.
TIMEOUT
;
}
catch
(
RpcException
e
)
{
rpcException
=
e
;
status
=
RpcStatus
.
EXCEPTION
;
}
catch
(
Exception
e
)
{
rpcException
=
new
RpcException
(
e
);
status
=
RpcStatus
.
EXCEPTION
;
}
finally
{
try
{
if
(
LOG
.
isDebugEnabled
()
||
rpcCollect
)
{
long
costTime
=
System
.
currentTimeMillis
()
-
startTime
;
String
reqParam
=
convertParam
(
params
);
// 根据需要开启rpc日志
if
(
LOG
.
isDebugEnabled
())
{
LOG
.
debug
(
"process request, yx-tracer-flowType={}, url={}, method={}, params={}, response={}, cost={}ms"
,
TracerClient
.
getFlowType
(),
url
,
method
.
name
(),
reqParam
,
respBody
,
costTime
);
}
}
}
catch
(
Exception
e
)
{
LOG
.
error
(
"collect error, msg={}"
,
e
.
getMessage
());
}
}
tryTimes
++;
}
LOG
.
error
(
"request error, url={}, params={}, respBody={}"
,
url
,
params
instanceof
String
?
params
:
JSON
.
toJSONString
(
params
),
respBody
,
rpcException
);
if
(
rpcException
==
null
)
{
rpcException
=
new
RpcException
(
"服务异常"
);
}
throw
rpcException
;
}
/**
* 校验resp
*
* @param t
* @param <T>
* @return
*/
private
<
T
>
RpcStatus
checkResp
(
CallHandler
<
T
>
handler
,
T
t
)
{
RpcStatus
status
=
RpcStatus
.
SUCCESS
;
try
{
// 为空,或handlerCheck为false直接判断FAIL
if
(
t
==
null
||
!
handler
.
check
(
t
))
{
return
RpcStatus
.
WARNING
;
}
if
(
t
instanceof
Checker
)
{
status
=
((
Checker
)
t
).
check
()
?
RpcStatus
.
SUCCESS
:
RpcStatus
.
WARNING
;
}
else
if
(
t
instanceof
List
)
{
// 为空认为不是理想结果
if
(
CollectionUtils
.
isEmpty
((
List
)
t
))
{
status
=
RpcStatus
.
WARNING
;
}
else
{
// 列表数据简单检测第一个元素
Object
obj
=
((
List
)
t
).
get
(
0
);
if
(
obj
instanceof
Checker
)
{
status
=
((
Checker
)
obj
).
check
()
?
RpcStatus
.
SUCCESS
:
RpcStatus
.
WARNING
;
}
}
}
}
catch
(
Exception
e
)
{
LOG
.
error
(
"collect error, msg={}"
,
e
.
getMessage
());
}
return
status
;
}
private
String
convertParam
(
Object
param
)
{
if
(
param
instanceof
String
)
{
return
(
String
)
param
;
}
String
reqParam
=
""
;
if
(
param
instanceof
Map
)
{
reqParam
=
EncodeUtil
.
encodeMap
((
Map
)
param
);
}
else
if
(
param
!=
null
)
{
reqParam
=
JSON
.
toJSONString
(
param
);
}
return
reqParam
;
}
enum
RpcStatus
{
/**
* 成功
*/
SUCCESS
(
1
),
/**
* 告警(请求成功,但非理想值)
*/
WARNING
(
2
),
/**
* 异常
*/
EXCEPTION
(
3
),
/**
* 超时
*/
TIMEOUT
(
4
);
private
final
int
value
;
RpcStatus
(
int
value
)
{
this
.
value
=
value
;
}
public
int
getValue
()
{
return
value
;
}
}
enum
Method
{
/**
* Get请求
*/
GET
,
/**
* Post表单请求
*/
POST
,
/**
* 数据体(一般是post json)
*/
BODY
}
/**
* 模板调用
*/
@FunctionalInterface
public
interface
CallTemplate
{
/**
* 模板调用类
*/
String
executeCall
();
}
/**
* 报文解析
*/
@FunctionalInterface
public
interface
CallHandler
<
T
>
{
/**
* 报文解析
*
* @param resp
* response body
*/
T
handle
(
String
resp
)
throws
IOException
;
/**
* 校验数据体
*
* @param t
* @return
*/
default
boolean
check
(
T
t
)
{
return
true
;
}
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/SinoInfoRpcObjectData.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.netease.mail.yanxuan.change.integration.rpc.RpcResultException
;
import
java.io.IOException
;
public
class
SinoInfoRpcObjectData
<
T
>
implements
RpcTemplate
.
CallHandler
<
T
>
{
private
final
Class
<
T
>
tClass
;
public
SinoInfoRpcObjectData
(
Class
<
T
>
tClass
)
{
this
.
tClass
=
tClass
;
}
@Override
public
T
handle
(
String
resp
)
throws
IOException
{
JSONObject
rpcResult
=
JSON
.
parseObject
(
resp
);
int
code
=
rpcResult
.
getIntValue
(
"code"
);
if
(
code
==
200
)
{
return
JSON
.
parseObject
(
rpcResult
.
getString
(
"shareInfo"
),
tClass
);
}
throw
new
RpcResultException
(
"response error, code = "
+
code
);
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/SinoRpcObjectData.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
java.io.IOException
;
public
class
SinoRpcObjectData
<
T
>
implements
RpcTemplate
.
CallHandler
<
T
>
{
private
final
Class
<
T
>
tClass
;
public
SinoRpcObjectData
(
Class
<
T
>
tClass
)
{
this
.
tClass
=
tClass
;
}
@Override
public
T
handle
(
String
resp
)
throws
IOException
{
JSONObject
rpcResult
=
JSON
.
parseObject
(
resp
);
return
JSON
.
parseObject
(
JSON
.
toJSONString
(
rpcResult
),
tClass
);
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/client/TrustAnyStrategy.java
0 → 100644
View file @
6d6a725e
package
com
.
netease
.
mail
.
yanxuan
.
change
.
integration
.
client
;
import
org.apache.http.conn.ssl.TrustStrategy
;
import
java.security.cert.CertificateException
;
import
java.security.cert.X509Certificate
;
/**
* 不校验,统统认为是可信的
*
* Created by leikun on 2017/5/7.
*/
public
class
TrustAnyStrategy
implements
TrustStrategy
{
private
static
final
TrustAnyStrategy
INSTANCE
=
new
TrustAnyStrategy
();
public
static
TrustAnyStrategy
get
()
{
return
INSTANCE
;
}
private
TrustAnyStrategy
()
{}
@Override
public
boolean
isTrusted
(
X509Certificate
[]
chain
,
String
authType
)
throws
CertificateException
{
return
true
;
}
}
yanxuan-qc-change-system-integration/src/main/java/com/netease/mail/yanxuan/change/integration/email/service/impl/UasClientServiceImpl.java
View file @
6d6a725e
...
...
@@ -2,12 +2,15 @@ package com.netease.mail.yanxuan.change.integration.email.service.impl;
import
com.alibaba.fastjson.JSON
;
import
com.alibaba.fastjson.JSONObject
;
import
com.netease.mail.yanxuan.change.integration.client.RpcObjectData
;
import
com.netease.mail.yanxuan.change.integration.client.RpcTemplate
;
import
com.netease.mail.yanxuan.change.integration.email.service.UasClientService
;
import
com.netease.mail.yanxuan.change.integration.flow.email.EmailRpcService
;
import
org.apache.commons.lang.StringUtils
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.beans.factory.annotation.Value
;
import
org.springframework.stereotype.Service
;
import
org.springframework.util.CollectionUtils
;
...
...
@@ -26,23 +29,37 @@ public class UasClientServiceImpl implements UasClientService {
Logger
logger
=
LoggerFactory
.
getLogger
(
UasClientServiceImpl
.
class
);
private
static
final
String
TEST_URL
=
"http://127.0.0.1:8550/proxy/test.logistics-uas.service.mailsaas/push/email/qc"
;
private
static
final
String
ONLINE_URL
=
"http://127.0.0.1:8550/proxy/online.logistics-uas.service.mailsaas/push/email/qc"
;
@Autowired
private
EmailRpcService
service
;
@Value
(
"${env:online}"
)
private
String
env
;
@Autowired
private
RpcTemplate
rpcTemplate
;
@Override
public
void
sendEmail
(
String
subject
,
String
content
,
Collection
<
String
>
toList
,
Collection
<
String
>
ccList
,
List
<
File
>
fileList
)
{
if
(!
CollectionUtils
.
isEmpty
(
toList
))
{
Map
<
String
,
String
>
params
=
new
HashMap
();
String
url
=
ONLINE_URL
;
if
(
"test"
.
equals
(
env
))
{
url
=
TEST_URL
;
}
Map
<
String
,
Object
>
params
=
new
HashMap
();
params
.
put
(
"subject"
,
subject
);
params
.
put
(
"content"
,
content
);
params
.
put
(
"to"
,
StringUtils
.
join
(
toList
,
","
));
params
.
put
(
"topic"
,
"qc"
);
if
(!
CollectionUtils
.
isEmpty
(
ccList
))
{
params
.
put
(
"cc"
,
StringUtils
.
join
(
ccList
,
","
));
}
logger
.
info
(
JSONObject
.
toJSONString
(
"邮箱接口入参 subject={},content={},toList={},ccList={}"
),
subject
,
content
,
StringUtils
.
join
(
toList
,
","
),
params
.
get
(
"cc"
));
String
res
=
service
.
sendEmail
(
subject
,
content
,
StringUtils
.
join
(
toList
,
","
),
params
.
get
(
"cc"
));
this
.
logger
.
info
(
"[op:sendEmail] res={} "
,
res
);
JSONObject
jsonObject
=
JSON
.
parseObject
(
res
);
if
(
jsonObject
.
getInteger
(
"code"
)
!=
200
)
{
this
.
logger
.
error
(
"SendEmail"
,
null
,
"send email failed, subject={},toList={},ccList={}"
,
new
Object
[]{
subject
,
JSON
.
toJSONString
(
toList
),
JSON
.
toJSONString
(
ccList
)});
}
rpcTemplate
.
post
(
url
,
params
,
new
RpcObjectData
<>(
String
.
class
));
//String res = service.sendEmail(subject, content, StringUtils.join(toList, ","), params.get("cc"));
}
}
...
...
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