From 89a7399256f6ea63af45e825eb409193c4c85ceb Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期日, 29 九月 2024 22:58:54 +0800 Subject: [PATCH] 工单取图片优化 --- ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml | 2 +- ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java | 12 ++++++------ ycl-server/src/main/java/com/ycl/utils/http/HttpUtils.java | 1 - 3 files changed, 7 insertions(+), 8 deletions(-) diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java index 32536ae..5b5e8ce 100644 --- a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java +++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java @@ -752,19 +752,21 @@ @Override - public String getFrameImgByDevice(String deviceId, String channelId, String workOrderNo) { + public synchronized String getFrameImgByDevice(String deviceId, String channelId, String workOrderNo) { String url = String.format(this.rtspServer + "/api/play/start/%s/%s", deviceId, channelId); String result = HttpUtils.sendGet(url); WVPResult wvpResult = JSON.parseObject(result, WVPResult.class); String imgUrl = null; if (wvpResult.getCode() == 0) { JSONObject data = (JSONObject) wvpResult.getData(); - String rtspUrl = data.getString("fmp4"); // 鍙杕p4鍦板潃 + String rtspUrl = data.getString("mp4"); // 鍙杕p4鍦板潃 if (StringUtils.hasText(rtspUrl)) { System.out.println("鐩爣鍦板潃锛�" + rtspUrl); FFmpegFrameGrabber grabber = null; try { - grabber = FFmpegFrameGrabber.createDefault(rtspUrl); + grabber = new FFmpegFrameGrabber(rtspUrl); +// grabber.setOption("rtsp_transport", "tcp"); // 浣跨敤tcp鐨勬柟寮忥紝涓嶇劧浼氫涪鍖呭緢涓ラ噸 +// grabber.setVideoOption("probesize", "10000"); // 璁剧疆鎹曡幏鍒嗘瀽鐨勬渶澶у瓧鑺� //璁剧疆10s瓒呮椂 grabber.setTimeout(10000); grabber.start(); @@ -794,13 +796,11 @@ } catch (FrameGrabber.Exception e) { e.printStackTrace(); } - // 閫氬父涓嶉渶瑕佽皟鐢╮elease()锛屽洜涓簊top()浼氬鐞嗚祫婧愰噴鏀� - // grabber.release(); // 閲婃斁璧勬簮 } } } } else { - System.out.println("璇锋眰澶辫触锛岄敊璇爜锛�" + wvpResult.getCode()); + System.out.println("璇锋眰澶辫触锛岄敊璇爜锛�" + wvpResult.getCode() + "--" + wvpResult.getMsg()); } System.out.println("鍥剧墖URL锛�" + imgUrl); return imgUrl; diff --git a/ycl-server/src/main/java/com/ycl/utils/http/HttpUtils.java b/ycl-server/src/main/java/com/ycl/utils/http/HttpUtils.java index 676b7b3..e446221 100644 --- a/ycl-server/src/main/java/com/ycl/utils/http/HttpUtils.java +++ b/ycl-server/src/main/java/com/ycl/utils/http/HttpUtils.java @@ -64,7 +64,6 @@ log.info("sendGet - {}", urlNameString); URL realUrl = new URL(urlNameString); URLConnection connection = realUrl.openConnection(); - connection.setConnectTimeout(20000); // 20s瓒呮椂 connection.setRequestProperty("accept", "*/*"); connection.setRequestProperty("connection", "Keep-Alive"); connection.setRequestProperty("user-agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64)"); diff --git a/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml b/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml index b9d5398..2f7f2d2 100644 --- a/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml +++ b/ycl-server/src/main/resources/mapper/zgyw/WorkOrderMapper.xml @@ -63,7 +63,7 @@ AND wo.unit_id = #{query.unitId} </if> <if test="query.keyword != null and query.keyword != ''"> - AND (wo.work_order_no like concat('%', #{query.keyword}, '%') or tm.name like concat('%', #{query.keyword}, '%')) + AND (wo.work_order_no like concat('%', #{query.keyword}, '%') or tm.name like concat('%', #{query.keyword}, '%') or wo.serial_number like concat('%', #{query.keyword}, '%')) </if> <if test="query.status != null and query.status != ''"> AND wo.status = #{query.status} -- Gitblit v1.8.0