Merge branch 'dev/优化模糊查询中的特殊符号'

pull/1694/head
648540858 2024-11-14 14:08:28 +08:00
commit 36f79d798b
20 changed files with 81 additions and 25 deletions

View File

@ -18,16 +18,13 @@ import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
@Tag(name = "媒体流相关") @Tag(name = "媒体流相关")
@Controller @RestController
@Slf4j @Slf4j
@RequestMapping(value = "/api/media") @RequestMapping(value = "/api/media")
public class MediaController { public class MediaController {

View File

@ -119,6 +119,7 @@ public interface CommonGBChannelMapper {
", gb_block = #{gbBlock}" + ", gb_block = #{gbBlock}" +
", gb_address = #{gbAddress}" + ", gb_address = #{gbAddress}" +
", gb_parental = #{gbParental}" + ", gb_parental = #{gbParental}" +
", gb_parent_id = #{gbParentId}" +
", gb_safety_way = #{gbSafetyWay}" + ", gb_safety_way = #{gbSafetyWay}" +
", gb_register_way = #{gbRegisterWay}" + ", gb_register_way = #{gbRegisterWay}" +
", gb_cert_num = #{gbCertNum}" + ", gb_cert_num = #{gbCertNum}" +

View File

@ -330,7 +330,11 @@ public interface DeviceMapper {
" FROM wvp_device de" + " FROM wvp_device de" +
" where 1 = 1 "+ " where 1 = 1 "+
" <if test='status != null'> AND de.on_line=${status}</if>"+ " <if test='status != null'> AND de.on_line=${status}</if>"+
" <if test='query != null'> AND (coalesce(custom_name, name) LIKE '%${query}%' OR device_id LIKE '%${query}%' OR ip LIKE '%${query}%')</if> " + " <if test='query != null'> AND (" +
" coalesce(custom_name, name) LIKE concat('%',#{query},'%') escape '/' " +
" OR device_id LIKE concat('%',#{query},'%') escape '/' " +
" OR ip LIKE concat('%',#{query},'%') escape '/')" +
"</if> " +
" order by create_time desc "+ " order by create_time desc "+
" </script>") " </script>")
List<Device> getDeviceList(@Param("query") String query, @Param("status") Boolean status); List<Device> getDeviceList(@Param("query") String query, @Param("status") Boolean status);

View File

@ -71,7 +71,7 @@ public interface PlatformMapper {
" ) as channel_count" + " ) as channel_count" +
" FROM wvp_platform pp where 1=1 " + " FROM wvp_platform pp where 1=1 " +
" <if test='query != null'> " + " <if test='query != null'> " +
" AND (pp.name LIKE concat('%',#{query},'%') OR pp.server_gb_id LIKE concat('%',#{query},'%') )</if> " + " AND (pp.name LIKE concat('%',#{query},'%') escape '/' OR pp.server_gb_id LIKE concat('%',#{query},'%') escape '/' )</if> " +
" order by pp.id desc"+ " order by pp.id desc"+
" </script>") " </script>")
List<Platform> queryList(@Param("query") String query); List<Platform> queryList(@Param("query") String query);

View File

@ -26,7 +26,7 @@ public interface RegionMapper {
@Select(value = {" <script>" + @Select(value = {" <script>" +
"SELECT * from wvp_common_region WHERE 1=1 " + "SELECT * from wvp_common_region WHERE 1=1 " +
" <if test='query != null'> AND (device_id LIKE concat('%',#{query},'%') OR name LIKE concat('%',#{query},'%'))</if> " + " <if test='query != null'> AND (device_id LIKE concat('%',#{query},'%') escape '/' OR name LIKE concat('%',#{query},'%') escape '/')</if> " +
" <if test='parentId != null'> AND parent_device_id = #{parentId}</if> " + " <if test='parentId != null'> AND parent_device_id = #{parentId}</if> " +
"ORDER BY id " + "ORDER BY id " +
" </script>"}) " </script>"})
@ -79,7 +79,7 @@ public interface RegionMapper {
" where " + " where " +
" <if test='parentId != null'> parent_id = #{parentId} </if> " + " <if test='parentId != null'> parent_id = #{parentId} </if> " +
" <if test='parentId == null'> parent_id is null </if> " + " <if test='parentId == null'> parent_id is null </if> " +
" <if test='query != null'> AND (device_id LIKE concat('%',#{query},'%') OR name LIKE concat('%',#{query},'%'))</if> " + " <if test='query != null'> AND (device_id LIKE concat('%',#{query},'%') escape '/' OR name LIKE concat('%',#{query},'%') escape '/')</if> " +
" </script>") " </script>")
List<RegionTree> queryForTree(@Param("query") String query, @Param("parentId") Integer parentId); List<RegionTree> queryForTree(@Param("query") String query, @Param("parentId") Integer parentId);

View File

@ -122,8 +122,8 @@ public class ChannelProvider {
sqlBuild.append(BASE_SQL); sqlBuild.append(BASE_SQL);
sqlBuild.append(" where channel_type = 0 "); sqlBuild.append(" where channel_type = 0 ");
if (params.get("query") != null) { if (params.get("query") != null) {
sqlBuild.append(" AND (coalesce(gb_device_id, device_id) LIKE concat('%',#{query},'%')" + sqlBuild.append(" AND (coalesce(gb_device_id, device_id) LIKE concat('%',#{query},'%') escape '/'" +
" OR coalesce(gb_name, name) LIKE concat('%',#{query},'%') )") " OR coalesce(gb_name, name) LIKE concat('%',#{query},'%') escape '/' )")
; ;
} }
if (params.get("online") != null && (Boolean)params.get("online")) { if (params.get("online") != null && (Boolean)params.get("online")) {
@ -154,8 +154,8 @@ public class ChannelProvider {
sqlBuild.append(BASE_SQL); sqlBuild.append(BASE_SQL);
sqlBuild.append(" where channel_type = 0 "); sqlBuild.append(" where channel_type = 0 ");
if (params.get("query") != null) { if (params.get("query") != null) {
sqlBuild.append(" AND (coalesce(gb_device_id, device_id) LIKE concat('%',#{query},'%')" + sqlBuild.append(" AND (coalesce(gb_device_id, device_id) LIKE concat('%',#{query},'%') escape '/'" +
" OR coalesce(gb_name, name) LIKE concat('%',#{query},'%') )") " OR coalesce(gb_name, name) LIKE concat('%',#{query},'%') escape '/' )")
; ;
} }
if (params.get("online") != null && (Boolean)params.get("online")) { if (params.get("online") != null && (Boolean)params.get("online")) {

View File

@ -71,8 +71,8 @@ public class DeviceChannelProvider {
"OR (LENGTH(coalesce(dc.gb_device_id, dc.device_id))=LENGTH(#{civilCode}) + 2) AND coalesce(dc.gb_device_id, dc.device_id) LIKE concat(#{civilCode},'%'))"); "OR (LENGTH(coalesce(dc.gb_device_id, dc.device_id))=LENGTH(#{civilCode}) + 2) AND coalesce(dc.gb_device_id, dc.device_id) LIKE concat(#{civilCode},'%'))");
} }
if (params.get("query") != null && !ObjectUtils.isEmpty(params.get("query"))) { if (params.get("query") != null && !ObjectUtils.isEmpty(params.get("query"))) {
sqlBuild.append(" AND (coalesce(dc.gb_device_id, dc.device_id) LIKE concat('%',#{query},'%')" + sqlBuild.append(" AND (coalesce(dc.gb_device_id, dc.device_id) LIKE concat('%',#{query},'%') escape '/'" +
" OR coalesce(dc.gb_name, dc.name) LIKE concat('%',#{query},'%'))") " OR coalesce(dc.gb_name, dc.name) LIKE concat('%',#{query},'%') escape '/')")
; ;
} }
if (params.get("online") != null && (Boolean)params.get("online")) { if (params.get("online") != null && (Boolean)params.get("online")) {

View File

@ -609,6 +609,11 @@ public class DeviceChannelServiceImpl implements IDeviceChannelService {
parentId = channelId; parentId = channelId;
} }
} }
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<DeviceChannel> all = channelMapper.queryChannels(deviceDbId, civilCode, businessGroupId, parentId, query, channelType, online,null); List<DeviceChannel> all = channelMapper.queryChannels(deviceDbId, civilCode, businessGroupId, parentId, query, channelType, online,null);
return new PageInfo<>(all); return new PageInfo<>(all);
} }
@ -624,7 +629,11 @@ public class DeviceChannelServiceImpl implements IDeviceChannelService {
if (device == null) { if (device == null) {
throw new ControllerException(ErrorCode.ERROR100.getCode(), "未找到设备:" + deviceId); throw new ControllerException(ErrorCode.ERROR100.getCode(), "未找到设备:" + deviceId);
} }
// 获取到所有正在播放的流 if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
List<DeviceChannel> all = channelMapper.queryChannels(device.getId(), null,null, null, query, hasSubChannel, online,null); List<DeviceChannel> all = channelMapper.queryChannels(device.getId(), null,null, null, query, hasSubChannel, online,null);
return new PageInfo<>(all); return new PageInfo<>(all);

View File

@ -519,6 +519,11 @@ public class DeviceServiceImpl implements IDeviceService {
@Override @Override
public PageInfo<Device> getAll(int page, int count, String query, Boolean status) { public PageInfo<Device> getAll(int page, int count, String query, Boolean status) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<Device> all = deviceMapper.getDeviceList(query, status); List<Device> all = deviceMapper.getDeviceList(query, status);
return new PageInfo<>(all); return new PageInfo<>(all);
} }

View File

@ -390,6 +390,11 @@ public class GbChannelServiceImpl implements IGbChannelService {
@Override @Override
public PageInfo<CommonGBChannel> queryListByCivilCode(int page, int count, String query, Boolean online, Integer channelType, String civilCode) { public PageInfo<CommonGBChannel> queryListByCivilCode(int page, int count, String query, Boolean online, Integer channelType, String civilCode) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<CommonGBChannel> all = commonGBChannelMapper.queryListByCivilCode(query, online, channelType, civilCode); List<CommonGBChannel> all = commonGBChannelMapper.queryListByCivilCode(query, online, channelType, civilCode);
return new PageInfo<>(all); return new PageInfo<>(all);
} }
@ -397,6 +402,11 @@ public class GbChannelServiceImpl implements IGbChannelService {
@Override @Override
public PageInfo<CommonGBChannel> queryListByParentId(int page, int count, String query, Boolean online, Integer channelType, String groupDeviceId) { public PageInfo<CommonGBChannel> queryListByParentId(int page, int count, String query, Boolean online, Integer channelType, String groupDeviceId) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<CommonGBChannel> all = commonGBChannelMapper.queryListByParentId(query, online, channelType, groupDeviceId); List<CommonGBChannel> all = commonGBChannelMapper.queryListByParentId(query, online, channelType, groupDeviceId);
return new PageInfo<>(all); return new PageInfo<>(all);
} }

View File

@ -159,6 +159,11 @@ public class PlatformServiceImpl implements IPlatformService {
@Override @Override
public PageInfo<Platform> queryPlatformList(int page, int count, String query) { public PageInfo<Platform> queryPlatformList(int page, int count, String query) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<Platform> all = platformMapper.queryList(query); List<Platform> all = platformMapper.queryList(query);
return new PageInfo<>(all); return new PageInfo<>(all);
} }

View File

@ -97,6 +97,11 @@ public class RegionServiceImpl implements IRegionService {
@Override @Override
public PageInfo<Region> query(String query, int page, int count) { public PageInfo<Region> query(String query, int page, int count) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<Region> regionList = regionMapper.query(query, null); List<Region> regionList = regionMapper.query(query, null);
return new PageInfo<>(regionList); return new PageInfo<>(regionList);
} }
@ -140,6 +145,11 @@ public class RegionServiceImpl implements IRegionService {
@Override @Override
public List<RegionTree> queryForTree(String query, Integer parent, Boolean hasChannel) { public List<RegionTree> queryForTree(String query, Integer parent, Boolean hasChannel) {
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<RegionTree> regionList = regionMapper.queryForTree(query, parent); List<RegionTree> regionList = regionMapper.queryForTree(query, parent);
if (parent != null && hasChannel != null && hasChannel) { if (parent != null && hasChannel != null && hasChannel) {
Region parentRegion = regionMapper.queryOne(parent); Region parentRegion = regionMapper.queryOne(parent);

View File

@ -71,6 +71,11 @@ public class CloudRecordServiceImpl implements ICloudRecordService {
} }
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<CloudRecordItem> all = cloudRecordServiceMapper.getList(query, app, stream, startTimeStamp, endTimeStamp, List<CloudRecordItem> all = cloudRecordServiceMapper.getList(query, app, stream, startTimeStamp, endTimeStamp,
callId, mediaServerItems, null); callId, mediaServerItems, null);
return new PageInfo<>(all); return new PageInfo<>(all);

View File

@ -41,7 +41,7 @@ public interface CloudRecordServiceMapper {
"select * " + "select * " +
" from wvp_cloud_record " + " from wvp_cloud_record " +
" where 0 = 0" + " where 0 = 0" +
" <if test='query != null'> AND (app LIKE concat('%',#{query},'%') OR stream LIKE concat('%',#{query},'%') )</if> " + " <if test='query != null'> AND (app LIKE concat('%',#{query},'%') escape '/' OR stream LIKE concat('%',#{query},'%') escape '/' )</if> " +
" <if test= 'app != null '> and app=#{app}</if>" + " <if test= 'app != null '> and app=#{app}</if>" +
" <if test= 'stream != null '> and stream=#{stream}</if>" + " <if test= 'stream != null '> and stream=#{stream}</if>" +
" <if test= 'startTimeStamp != null '> and end_time &gt;= #{startTimeStamp}</if>" + " <if test= 'startTimeStamp != null '> and end_time &gt;= #{startTimeStamp}</if>" +

View File

@ -30,7 +30,7 @@ import java.util.Map;
* *
*/ */
@Tag(name = "拉流代理", description = "") @Tag(name = "拉流代理", description = "")
@Controller @RestController
@Slf4j @Slf4j
@RequestMapping(value = "/api/proxy") @RequestMapping(value = "/api/proxy")
public class StreamProxyController { public class StreamProxyController {

View File

@ -36,13 +36,13 @@ public class StreamProxyProvider {
if (params.get("query") != null) { if (params.get("query") != null) {
sqlBuild.append(" AND ") sqlBuild.append(" AND ")
.append(" (") .append(" (")
.append(" st.app LIKE ").append("'%").append(params.get("query")).append("%'") .append(" st.app LIKE ").append("'%").append(params.get("query")).append("%' escape '/'")
.append(" OR") .append(" OR")
.append(" st.stream LIKE ").append("'%").append(params.get("query")).append("%'") .append(" st.stream LIKE ").append("'%").append(params.get("query")).append("%' escape '/'")
.append(" OR") .append(" OR")
.append(" wdc.gb_device_id LIKE ").append("'%").append(params.get("query")).append("%'") .append(" wdc.gb_device_id LIKE ").append("'%").append(params.get("query")).append("%' escape '/'")
.append(" OR") .append(" OR")
.append(" wdc.gb_name LIKE ").append("'%").append(params.get("query")).append("%'") .append(" wdc.gb_name LIKE ").append("'%").append(params.get("query")).append("%' escape '/'")
.append(" )") .append(" )")
; ;
} }

View File

@ -246,6 +246,11 @@ public class StreamProxyServiceImpl implements IStreamProxyService {
@Override @Override
public PageInfo<StreamProxy> getAll(Integer page, Integer count, String query, Boolean pulling, String mediaServerId) { public PageInfo<StreamProxy> getAll(Integer page, Integer count, String query, Boolean pulling, String mediaServerId) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<StreamProxy> all = streamProxyMapper.selectAll(query, pulling, mediaServerId); List<StreamProxy> all = streamProxyMapper.selectAll(query, pulling, mediaServerId);
return new PageInfo<>(all); return new PageInfo<>(all);
} }

View File

@ -43,7 +43,7 @@ import java.util.Map;
import java.util.UUID; import java.util.UUID;
@Tag(name = "推流信息管理") @Tag(name = "推流信息管理")
@Controller @RestController
@Slf4j @Slf4j
@RequestMapping(value = "/api/push") @RequestMapping(value = "/api/push")
public class StreamPushController { public class StreamPushController {

View File

@ -48,8 +48,8 @@ public interface StreamPushMapper {
" on st.id = wdc.stream_push_id " + " on st.id = wdc.stream_push_id " +
" WHERE " + " WHERE " +
" 1=1 " + " 1=1 " +
" <if test='query != null'> AND (st.app LIKE concat('%',#{query},'%') OR st.stream LIKE concat('%',#{query},'%') " + " <if test='query != null'> AND (st.app LIKE concat('%',#{query},'%') escape '/' OR st.stream LIKE concat('%',#{query},'%') escape '/' " +
" OR wdc.gb_device_id LIKE concat('%',#{query},'%') OR wdc.gb_name LIKE concat('%',#{query},'%'))</if> " + " OR wdc.gb_device_id LIKE concat('%',#{query},'%') escape '/' OR wdc.gb_name LIKE concat('%',#{query},'%') escape '/')</if> " +
" <if test='pushing == true' > AND st.pushing=1</if>" + " <if test='pushing == true' > AND st.pushing=1</if>" +
" <if test='pushing == false' > AND st.pushing=0 </if>" + " <if test='pushing == false' > AND st.pushing=0 </if>" +
" <if test='mediaServerId != null' > AND st.media_server_id=#{mediaServerId} </if>" + " <if test='mediaServerId != null' > AND st.media_server_id=#{mediaServerId} </if>" +

View File

@ -175,6 +175,11 @@ public class StreamPushServiceImpl implements IStreamPushService {
@Override @Override
public PageInfo<StreamPush> getPushList(Integer page, Integer count, String query, Boolean pushing, String mediaServerId) { public PageInfo<StreamPush> getPushList(Integer page, Integer count, String query, Boolean pushing, String mediaServerId) {
PageHelper.startPage(page, count); PageHelper.startPage(page, count);
if (query != null) {
query = query.replaceAll("/", "//")
.replaceAll("%", "/%")
.replaceAll("_", "/_");
}
List<StreamPush> all = streamPushMapper.selectAll(query, pushing, mediaServerId); List<StreamPush> all = streamPushMapper.selectAll(query, pushing, mediaServerId);
return new PageInfo<>(all); return new PageInfo<>(all);
} }