parent
f97c675771
commit
081c2615be
@ -0,0 +1,27 @@
|
|||||||
|
package org.jeecg.config.sign.interceptor;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
|
||||||
|
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* online 拦截器配置
|
||||||
|
*/
|
||||||
|
@Configuration
|
||||||
|
public class SignAuthConfiguration implements WebMvcConfigurer {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public SignAuthInterceptor signAuthInterceptor() {
|
||||||
|
return new SignAuthInterceptor();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addInterceptors(InterceptorRegistry registry) {
|
||||||
|
String[] inculudes = new String[] {"/sys/dict/getDictItems/*", "/sys/dict/loadDict/*",
|
||||||
|
"/sys/dict/loadDictOrderByValue/*", "/sys/dict/loadDictItem/*", "/sys/dict/loadTreeData",
|
||||||
|
"/sys/api/queryTableDictItemsByCode", "/sys/api/queryFilterTableDictInfo", "/sys/api/queryTableDictByKeys",
|
||||||
|
"/sys/api/translateDictFromTable", "/sys/api/translateDictFromTableByKeys"};
|
||||||
|
registry.addInterceptor(signAuthInterceptor()).addPathPatterns(inculudes);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,107 @@
|
|||||||
|
package org.jeecg.config.sign.util;
|
||||||
|
|
||||||
|
import javax.servlet.ReadListener;
|
||||||
|
import javax.servlet.ServletInputStream;
|
||||||
|
import javax.servlet.ServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletRequestWrapper;
|
||||||
|
import java.io.*;
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 保存过滤器里面的流
|
||||||
|
*
|
||||||
|
* @author show
|
||||||
|
* @date 10:03 2019/5/30
|
||||||
|
*/
|
||||||
|
public class BodyReaderHttpServletRequestWrapper extends HttpServletRequestWrapper {
|
||||||
|
|
||||||
|
private final byte[] body;
|
||||||
|
|
||||||
|
public BodyReaderHttpServletRequestWrapper(HttpServletRequest request) {
|
||||||
|
|
||||||
|
super(request);
|
||||||
|
String sessionStream = getBodyString(request);
|
||||||
|
body = sessionStream.getBytes(Charset.forName("UTF-8"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取请求Body
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public String getBodyString(final ServletRequest request) {
|
||||||
|
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
try (InputStream inputStream = cloneInputStream(request.getInputStream());
|
||||||
|
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, Charset.forName("UTF-8")))) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
sb.append(line);
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return sb.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Description: 复制输入流</br>
|
||||||
|
*
|
||||||
|
* @param inputStream
|
||||||
|
* @return</br>
|
||||||
|
*/
|
||||||
|
public InputStream cloneInputStream(ServletInputStream inputStream) {
|
||||||
|
|
||||||
|
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
|
||||||
|
byte[] buffer = new byte[1024];
|
||||||
|
int len;
|
||||||
|
try {
|
||||||
|
while ((len = inputStream.read(buffer)) > -1) {
|
||||||
|
byteArrayOutputStream.write(buffer, 0, len);
|
||||||
|
}
|
||||||
|
byteArrayOutputStream.flush();
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return new ByteArrayInputStream(byteArrayOutputStream.toByteArray());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public BufferedReader getReader() {
|
||||||
|
|
||||||
|
return new BufferedReader(new InputStreamReader(getInputStream()));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ServletInputStream getInputStream() {
|
||||||
|
|
||||||
|
final ByteArrayInputStream bais = new ByteArrayInputStream(body);
|
||||||
|
return new ServletInputStream() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int read() {
|
||||||
|
|
||||||
|
return bais.read();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isFinished() {
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isReady() {
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setReadListener(ReadListener readListener) {
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,49 @@
|
|||||||
|
package org.jeecg.config.sign.util;
|
||||||
|
|
||||||
|
import com.alibaba.fastjson.JSONObject;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.util.DigestUtils;
|
||||||
|
import org.springframework.util.StringUtils;
|
||||||
|
|
||||||
|
import java.util.SortedMap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 签名工具类
|
||||||
|
*
|
||||||
|
* @author show
|
||||||
|
* @date 10:01 2019/5/30
|
||||||
|
*/
|
||||||
|
@Slf4j
|
||||||
|
public class SignUtil {
|
||||||
|
//签名密钥串(前后端要一致,正式发布请自行修改)
|
||||||
|
private static final String signatureSecret = "dd05f1c54d63749eda95f9fa6d49v442a";
|
||||||
|
public static final String xPathVariable = "x-path-variable";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param params
|
||||||
|
* 所有的请求参数都会在这里进行排序加密
|
||||||
|
* @return 验证签名结果
|
||||||
|
*/
|
||||||
|
public static boolean verifySign(SortedMap<String, String> params,String headerSign) {
|
||||||
|
if (params == null || StringUtils.isEmpty(headerSign)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// 把参数加密
|
||||||
|
String paramsSign = getParamsSign(params);
|
||||||
|
log.info("Param Sign : {}", paramsSign);
|
||||||
|
return !StringUtils.isEmpty(paramsSign) && headerSign.equals(paramsSign);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param params
|
||||||
|
* 所有的请求参数都会在这里进行排序加密
|
||||||
|
* @return 得到签名
|
||||||
|
*/
|
||||||
|
public static String getParamsSign(SortedMap<String, String> params) {
|
||||||
|
//去掉 Url 里的时间戳
|
||||||
|
params.remove("_t");
|
||||||
|
String paramsJsonStr = JSONObject.toJSONString(params);
|
||||||
|
log.info("Param paramsJsonStr : {}", paramsJsonStr);
|
||||||
|
return DigestUtils.md5DigestAsHex((paramsJsonStr+signatureSecret).getBytes()).toUpperCase();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue