wvp-GB28181-pro/src/main/java/com/genersoft/iot/vmp/conf/ProxyServletConfig.java

279 lines
11 KiB
Java
Raw Normal View History

2021-06-01 17:05:07 +08:00
package com.genersoft.iot.vmp.conf;
import com.genersoft.iot.vmp.media.zlm.dto.MediaServerItem;
2021-07-16 16:34:51 +08:00
import com.genersoft.iot.vmp.service.IMediaServerService;
import org.apache.http.HttpHost;
2021-06-01 17:05:07 +08:00
import org.apache.http.HttpRequest;
import org.apache.http.HttpResponse;
2023-02-22 18:01:30 +08:00
import org.junit.jupiter.api.Order;
2021-06-01 17:05:07 +08:00
import org.mitre.dsmiley.httpproxy.ProxyServlet;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
2021-07-16 16:34:51 +08:00
import org.springframework.beans.factory.annotation.Value;
2021-06-01 17:05:07 +08:00
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.util.ObjectUtils;
2021-06-01 17:05:07 +08:00
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
2021-06-01 17:05:07 +08:00
import java.io.IOException;
import java.net.ConnectException;
/**
* @author lin
*/
@SuppressWarnings(value = {"rawtypes", "unchecked"})
2021-06-01 17:05:07 +08:00
@Configuration
2023-02-22 18:01:30 +08:00
@Order(1)
2021-06-01 17:05:07 +08:00
public class ProxyServletConfig {
private final static Logger logger = LoggerFactory.getLogger(ProxyServletConfig.class);
@Autowired
2021-07-16 16:34:51 +08:00
private IMediaServerService mediaServerService;
@Value("${server.port}")
private int serverPort;
2021-06-01 17:05:07 +08:00
@Bean
public ServletRegistrationBean zlmServletRegistrationBean(){
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new ZlmProxyServlet(),"/zlm/*");
2021-06-01 17:05:07 +08:00
servletRegistrationBean.setName("zlm_Proxy");
2021-07-16 16:34:51 +08:00
servletRegistrationBean.addInitParameter("targetUri", "http://127.0.0.1:6080");
servletRegistrationBean.addUrlMappings();
2021-06-01 17:05:07 +08:00
if (logger.isDebugEnabled()) {
servletRegistrationBean.addInitParameter("log", "true");
}
return servletRegistrationBean;
}
class ZlmProxyServlet extends ProxyServlet{
@Override
protected String rewriteQueryStringFromRequest(HttpServletRequest servletRequest, String queryString) {
String queryStr = super.rewriteQueryStringFromRequest(servletRequest, queryString);
MediaServerItem mediaInfo = getMediaInfoByUri(servletRequest.getRequestURI());
2021-07-16 16:34:51 +08:00
if (mediaInfo != null) {
if (!ObjectUtils.isEmpty(queryStr)) {
2021-07-16 16:34:51 +08:00
queryStr += "&secret=" + mediaInfo.getSecret();
}else {
queryStr = "secret=" + mediaInfo.getSecret();
}
}
return queryStr;
}
2021-07-16 16:34:51 +08:00
/**
*
*/
2021-06-01 17:05:07 +08:00
@Override
protected void handleRequestException(HttpRequest proxyRequest, HttpResponse proxyResonse, Exception e){
try {
super.handleRequestException(proxyRequest, proxyResonse, e);
} catch (ServletException servletException) {
logger.error("zlm 代理失败: ", e);
} catch (IOException ioException) {
if (ioException instanceof ConnectException) {
logger.error("zlm 连接失败");
2023-02-06 17:34:47 +08:00
} else {
2021-06-01 17:05:07 +08:00
logger.error("zlm 代理失败: ", e);
}
} catch (RuntimeException exception){
logger.error("zlm 代理失败: ", e);
}
}
2021-07-16 16:34:51 +08:00
/**
* 404
*/
@Override
protected String getTargetUri(HttpServletRequest servletRequest) {
String requestURI = servletRequest.getRequestURI();
MediaServerItem mediaInfo = getMediaInfoByUri(requestURI);
2021-07-16 16:34:51 +08:00
String uri = null;
if (mediaInfo != null) {
// String realRequestURI = requestURI.substring(requestURI.indexOf(mediaInfo.getId())+ mediaInfo.getId().length());
uri = String.format("http://%s:%s", mediaInfo.getIp(), mediaInfo.getHttpPort());
}else {
uri = "http://127.0.0.1:" + serverPort +"/index/hook/null"; // 只是一个能返回404的请求而已 其他的也可以
}
return uri;
}
/**
*
*/
@Override
protected HttpHost getTargetHost(HttpServletRequest servletRequest) {
String requestURI = servletRequest.getRequestURI();
MediaServerItem mediaInfo = getMediaInfoByUri(requestURI);
2021-07-16 16:34:51 +08:00
HttpHost host;
if (mediaInfo != null) {
host = new HttpHost(mediaInfo.getIp(), mediaInfo.getHttpPort());
}else {
host = new HttpHost("127.0.0.1", serverPort);
}
return host;
}
/**
* uri
*/
MediaServerItem getMediaInfoByUri(String uri){
2021-07-16 16:34:51 +08:00
String[] split = uri.split("/");
String mediaServerId = split[2];
if ("default".equalsIgnoreCase(mediaServerId)) {
2021-12-02 17:37:29 +08:00
return mediaServerService.getDefaultMediaServer();
}else {
return mediaServerService.getOne(mediaServerId);
}
2021-07-16 16:34:51 +08:00
}
/**
* url
*/
@Override
protected String rewriteUrlFromRequest(HttpServletRequest servletRequest) {
String requestURI = servletRequest.getRequestURI();
MediaServerItem mediaInfo = getMediaInfoByUri(requestURI);
2021-07-16 16:34:51 +08:00
String url = super.rewriteUrlFromRequest(servletRequest);
if (mediaInfo == null) {
logger.error("[ZLM服务访问代理]错误处理url信息时未找到流媒体信息=>{}", requestURI);
2021-07-16 16:34:51 +08:00
return url;
}
if (!ObjectUtils.isEmpty(mediaInfo.getId())) {
url = url.replace(mediaInfo.getId() + "/", "");
}
return url.replace("default/", "");
2021-07-16 16:34:51 +08:00
}
2021-06-01 17:05:07 +08:00
}
2021-07-19 17:54:01 +08:00
@Bean
public ServletRegistrationBean recordServletRegistrationBean(){
2021-12-02 17:37:29 +08:00
ServletRegistrationBean servletRegistrationBean = new ServletRegistrationBean(new RecordProxyServlet(),"/record_proxy/*");
2021-07-19 17:54:01 +08:00
servletRegistrationBean.setName("record_proxy");
servletRegistrationBean.addInitParameter("targetUri", "http://127.0.0.1:18081");
servletRegistrationBean.addUrlMappings();
if (logger.isDebugEnabled()) {
servletRegistrationBean.addInitParameter("log", "true");
}
return servletRegistrationBean;
}
2021-12-02 17:37:29 +08:00
class RecordProxyServlet extends ProxyServlet{
2021-07-19 17:54:01 +08:00
2021-12-02 17:37:29 +08:00
@Override
protected String rewriteQueryStringFromRequest(HttpServletRequest servletRequest, String queryString) {
String queryStr = super.rewriteQueryStringFromRequest(servletRequest, queryString);
MediaServerItem mediaInfo = getMediaInfoByUri(servletRequest.getRequestURI());
if (mediaInfo == null) {
return null;
}
String remoteHost = String.format("http://%s:%s", mediaInfo.getStreamIp(), mediaInfo.getRecordAssistPort());
2023-03-23 20:52:05 +08:00
if (!ObjectUtils.isEmpty(queryStr)) {
queryStr += "&remoteHost=" + remoteHost;
}else {
queryStr = "remoteHost=" + remoteHost;
2021-12-02 17:37:29 +08:00
}
return queryStr;
}
2021-07-19 17:54:01 +08:00
/**
*
*/
@Override
2021-11-22 17:27:48 +08:00
protected void handleRequestException(HttpRequest proxyRequest, HttpResponse proxyResponse, Exception e){
2021-07-19 17:54:01 +08:00
try {
2021-11-22 17:27:48 +08:00
super.handleRequestException(proxyRequest, proxyResponse, e);
2021-07-19 17:54:01 +08:00
} catch (ServletException servletException) {
logger.error("录像服务 代理失败: ", e);
} catch (IOException ioException) {
if (ioException instanceof ConnectException) {
logger.error("录像服务 连接失败");
// }else if (ioException instanceof ClientAbortException) {
// /**
// * TODO 使用这个代理库实现代理在遇到代理视频文件时如果是206结果会遇到报错蛋市目前功能正常
// * TODO 暂时去除异常处理。后续使用其他代理框架修改测试
// */
2023-03-27 15:47:04 +08:00
2023-02-06 17:34:47 +08:00
}else {
2021-07-19 17:54:01 +08:00
logger.error("录像服务 代理失败: ", e);
}
} catch (RuntimeException exception){
logger.error("录像服务 代理失败: ", e);
}
}
/**
* 404
*/
@Override
protected String getTargetUri(HttpServletRequest servletRequest) {
String requestURI = servletRequest.getRequestURI();
MediaServerItem mediaInfo = getMediaInfoByUri(requestURI);
2021-07-19 17:54:01 +08:00
String uri = null;
if (mediaInfo != null) {
// String realRequestURI = requestURI.substring(requestURI.indexOf(mediaInfo.getId())+ mediaInfo.getId().length());
uri = String.format("http://%s:%s", mediaInfo.getIp(), mediaInfo.getRecordAssistPort());
}else {
uri = "http://127.0.0.1:" + serverPort +"/index/hook/null"; // 只是一个能返回404的请求而已 其他的也可以
}
return uri;
}
/**
*
*/
@Override
protected HttpHost getTargetHost(HttpServletRequest servletRequest) {
String requestURI = servletRequest.getRequestURI();
MediaServerItem mediaInfo = getMediaInfoByUri(requestURI);
2021-07-19 17:54:01 +08:00
HttpHost host;
if (mediaInfo != null) {
host = new HttpHost(mediaInfo.getIp(), mediaInfo.getRecordAssistPort());
}else {
host = new HttpHost("127.0.0.1", serverPort);
}
return host;
}
/**
* uri
*/
MediaServerItem getMediaInfoByUri(String uri){
2021-07-19 17:54:01 +08:00
String[] split = uri.split("/");
String mediaServerId = split[2];
if ("default".equalsIgnoreCase(mediaServerId)) {
2021-12-02 17:37:29 +08:00
return mediaServerService.getDefaultMediaServer();
}else {
return mediaServerService.getOne(mediaServerId);
}
2021-07-19 17:54:01 +08:00
}
/**
* url
*/
@Override
protected String rewriteUrlFromRequest(HttpServletRequest servletRequest) {
String requestURI = servletRequest.getRequestURI();
MediaServerItem mediaInfo = getMediaInfoByUri(requestURI);
2021-07-19 17:54:01 +08:00
String url = super.rewriteUrlFromRequest(servletRequest);
if (mediaInfo == null) {
logger.error("[录像服务访问代理]错误处理url信息时未找到流媒体信息=>{}", requestURI);
2021-07-19 17:54:01 +08:00
return url;
}
if (!ObjectUtils.isEmpty(mediaInfo.getId())) {
url = url.replace(mediaInfo.getId() + "/", "");
}
return url.replace("default/", "");
2021-07-19 17:54:01 +08:00
}
}
2021-06-01 17:05:07 +08:00
}