拒绝包含./或/连续过多的接口请求

This commit is contained in:
zengqiao
2021-03-31 19:45:18 +08:00
parent 648af61116
commit 9e7450c012

View File

@@ -64,11 +64,13 @@ public class LoginServiceImpl implements LoginService {
@Override @Override
public boolean checkLogin(HttpServletRequest request, HttpServletResponse response) { public boolean checkLogin(HttpServletRequest request, HttpServletResponse response) {
String uri = request.getRequestURI().replace("//", "/"); String uri = request.getRequestURI();
if (uri.contains("/../") || uri.contains("/./")) { if (uri.contains("./") || uri.contains("///")) {
LOGGER.error("class=LoginServiceImpl||method=checkLogin||msg=uri illegal, contains /../ or /./||uri={}", uri); LOGGER.error("class=LoginServiceImpl||method=checkLogin||msg=uri illegal, contains ../ or ./ or ///||uri={}", uri);
singleSignOn.setRedirectToLoginPage(response);
return false; return false;
} }
uri = uri.replaceAll("//", "/");
if (uri.startsWith(ApiPrefix.API_V1_SSO_PREFIX) if (uri.startsWith(ApiPrefix.API_V1_SSO_PREFIX)
|| uri.startsWith(ApiPrefix.API_V1_THIRD_PART_PREFIX) || uri.startsWith(ApiPrefix.API_V1_THIRD_PART_PREFIX)