短信链接优化成短链接
短信链接现在的url比较长,需要优化成短链接。
只需要写一个短信短链接方法,然后在监听事件调用即可。
入参dto
创建一个ShortUrlDTO入参DTO,代码如下:
import lombok.Data;
@Data
public class ShortUrlDTO {
/**
* 签名
*/
private String signature;
/**
* 行为 固定shorturl
*/
private String action;
/**
* 原url
*/
private String url;
/**
* 格式 使用json
*/
private String format;
使用@Data注解,自动封装getset方法;@Data注解需要安装Lombok插件,导入lombok包。(在pom文件加入lombok依赖)
pom加入lombok依赖如下:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.16</version><!--版本号自己选一个就行-->
</dependency>
短信链接接口
创建一个ShortUrlClient接口,代码如下:
public interface ShortUrlClient {
String ShortUrl(ShortUrlDTO dto);
String ShortUrl(String url);
}
实现类写具体方法
接口和dto写好以后,最后创建实现类ShortUrlClientImpl,实现短信链接接口,在实现类中写具体业务。代码如下:
@Component
@Slf4j
public class ShortUrlClientImpl implements ShortUrlClient {
private static final String SHORT_URl = "urlxxx";
private static final String SUCCSS_CODE = "200";
//实现接口中的两个方法
@Override
public String ShortUrl(ShortUrlDTO dto){
String shortUrl = "";
Map<String,Object> params = new HashMap<>();
params.put("signature","05e2685fc7");
params.put("action","shorturl");
params.put("url",dto.getUrl());
params.put("format","json");
try {
log.info(String.format("生成短链接请求参数:%s",params.toString()));
String result = HttpUtil.post(SHORT_URl,params);
log.info(String.format("生成短链接响应返回 %s",result));
if (StrUtil.isNotBlank(result)){
JSONObject retJson = JSONObject.parseObject(result);
if (StrUtil.isNotBlank(retJson.getString("statusCode"))
&& SUCCSS_CODE.equals(retJson.getString("statusCode"))
&& StrUtil.isNotBlank(retJson.getString("shorturl"))){
shortUrl = (String)retJson.get("shorturl");
}
}
return shortUrl;
}catch (Exception e){
log.info("生成短链接请求异常");
return shortUrl;
}
}
@Override
public String ShortUrl(String url) {
ShortUrlDTO dto = new ShortUrlDTO();
dto.setUrl(url);
String shortUrl = ShortUrl(dto);
if(StrUtil.isNotBlank(shortUrl)){
return shortUrl;
}else {
return url;
}
}
声明
(一)log可以打印日志,为了避免每次都写private final Logger logger = LoggerFactory.getLogger(当前类名.class); 可以用注解@Slf4j;使用注解@Slf4j需要安装Lombok插件,在pom里加依赖。
(二)另外代码中的@component 注解是把普通pojo实例化到spring容器中。泛指各种组件,就是说当我们的类不属于各种归类的时候(不属于@Controller、@Services等的时候),我们就可以使用@Component来标注这个类。
在监听事件调用该方法
原代码:
String shortUrl=domainName+"/smscode/index.html?orderNo="+orderDO.getOrderNo();
shortUrl= URLEncoder.createDefault().encode(shortUrl, CharsetUtil.CHARSET_UTF_8);
try {
shortUrl=this.txShortUrlApi(shortUrl);
content.append(",").append(shortUrl);
SendMessageDTO sendMessageDTO=new SendMessageDTO();
sendMessageDTO.setMobilePhone(orderDO.getContactMobile());
sendMessageDTO.setTemplateId(SysConfigValueEnum.SMS_T_BUYSUCCESS.getCode());
sendMessageDTO.setContent(content.toString());
smsMessageSendRpcService.sendMessageByTemplate(sendMessageDTO);
}catch (Exception e){
e.printStackTrace();
log.error("发送短信失败",e);
}
修改后的代码:
String shortUrl=domainName+"/smscode/index.html?orderNo="+orderDO.getOrderNo();
String shortUrl2 = shortUrlClient.ShortUrl(shortUrl);
shortUrl2= URLEncoder.createDefault().encode(shortUrl2, CharsetUtil.CHARSET_UTF_8);
try {
shortUrl2=this.txShortUrlApi(shortUrl2);
content.append(",").append(shortUrl2);
SendMessageDTO sendMessageDTO=new SendMessageDTO();
sendMessageDTO.setMobilePhone(orderDO.getContactMobile());
sendMessageDTO.setTemplateId(SysConfigValueEnum.SMS_T_BUYSUCCESS.getCode());
sendMessageDTO.setContent(content.toString());
smsMessageSendRpcService.sendMessageByTemplate(sendMessageDTO);
}catch (Exception e){
e.printStackTrace();
log.error("发送短信失败",e);
}