优化登录体验。修复因为流地址导致的录像服务无法识别
This commit is contained in:
parent
792c93694d
commit
3578c1c040
@ -30,6 +30,9 @@ public class AnonymousAuthenticationEntryPoint implements AuthenticationEntryPoi
|
|||||||
JSONObject jsonObject = new JSONObject();
|
JSONObject jsonObject = new JSONObject();
|
||||||
jsonObject.put("code", "-1");
|
jsonObject.put("code", "-1");
|
||||||
jsonObject.put("msg", "请登录后重新请求");
|
jsonObject.put("msg", "请登录后重新请求");
|
||||||
|
if (request.getRequestURI().contains("api/user/login")){
|
||||||
|
jsonObject.put("msg", e.getMessage());
|
||||||
|
}
|
||||||
response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
|
response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
|
||||||
try {
|
try {
|
||||||
response.getWriter().print(jsonObject.toJSONString());
|
response.getWriter().print(jsonObject.toJSONString());
|
||||||
|
@ -376,7 +376,7 @@ public class ZLMHttpHookListener {
|
|||||||
String app = json.getString("app");
|
String app = json.getString("app");
|
||||||
String streamId = json.getString("stream");
|
String streamId = json.getString("stream");
|
||||||
if ("rtp".equals(app)) {
|
if ("rtp".equals(app)) {
|
||||||
String[] s = streamId.split("/");
|
String[] s = streamId.split("_");
|
||||||
if (s.length == 2) {
|
if (s.length == 2) {
|
||||||
String deviceId = s[0];
|
String deviceId = s[0];
|
||||||
String channelId = s[1];
|
String channelId = s[1];
|
||||||
@ -386,7 +386,7 @@ public class ZLMHttpHookListener {
|
|||||||
SSRCInfo ssrcInfo;
|
SSRCInfo ssrcInfo;
|
||||||
String streamId2 = null;
|
String streamId2 = null;
|
||||||
if (mediaInfo.isRtpEnable()) {
|
if (mediaInfo.isRtpEnable()) {
|
||||||
streamId2 = String.format("%s/%s", device.getDeviceId(), channelId);
|
streamId2 = String.format("%s_%s", device.getDeviceId(), channelId);
|
||||||
}
|
}
|
||||||
ssrcInfo = mediaServerService.openRTPServer(mediaInfo, streamId2);
|
ssrcInfo = mediaServerService.openRTPServer(mediaInfo, streamId2);
|
||||||
cmder.playStreamCmd(mediaInfo, ssrcInfo, device, channelId, (MediaServerItem mediaServerItemInuse, JSONObject response) -> {
|
cmder.playStreamCmd(mediaInfo, ssrcInfo, device, channelId, (MediaServerItem mediaServerItemInuse, JSONObject response) -> {
|
||||||
|
@ -122,7 +122,7 @@ public class MediaServerServiceImpl implements IMediaServerService, CommandLineR
|
|||||||
String mediaServerId = streamSession.getMediaServerId(device.getDeviceId(), channelId);
|
String mediaServerId = streamSession.getMediaServerId(device.getDeviceId(), channelId);
|
||||||
MediaServerItem mediaServerItem = this.getOne(mediaServerId);
|
MediaServerItem mediaServerItem = this.getOne(mediaServerId);
|
||||||
if (mediaServerItem != null) {
|
if (mediaServerItem != null) {
|
||||||
String streamId = String.format("%s/%s", device.getDeviceId(), channelId);
|
String streamId = String.format("%s_%s", device.getDeviceId(), channelId);
|
||||||
zlmrtpServerFactory.closeRTPServer(mediaServerItem, streamId);
|
zlmrtpServerFactory.closeRTPServer(mediaServerItem, streamId);
|
||||||
releaseSsrc(mediaServerItem, streamSession.getSSRC(device.getDeviceId(), channelId));
|
releaseSsrc(mediaServerItem, streamSession.getSSRC(device.getDeviceId(), channelId));
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ public class PlayServiceImpl implements IPlayService {
|
|||||||
SSRCInfo ssrcInfo;
|
SSRCInfo ssrcInfo;
|
||||||
String streamId = null;
|
String streamId = null;
|
||||||
if (mediaServerItem.isRtpEnable()) {
|
if (mediaServerItem.isRtpEnable()) {
|
||||||
streamId = String.format("%s/%s", device.getDeviceId(), channelId);
|
streamId = String.format("%s_%s", device.getDeviceId(), channelId);
|
||||||
}
|
}
|
||||||
|
|
||||||
ssrcInfo = mediaServerService.openRTPServer(mediaServerItem, streamId);
|
ssrcInfo = mediaServerService.openRTPServer(mediaServerItem, streamId);
|
||||||
@ -220,7 +220,7 @@ public class PlayServiceImpl implements IPlayService {
|
|||||||
SSRCInfo ssrcInfo;
|
SSRCInfo ssrcInfo;
|
||||||
String streamId2 = null;
|
String streamId2 = null;
|
||||||
if (mediaServerItem.isRtpEnable()) {
|
if (mediaServerItem.isRtpEnable()) {
|
||||||
streamId2 = String.format("%s/%s", device.getDeviceId(), channelId);
|
streamId2 = String.format("%s_%s", device.getDeviceId(), channelId);
|
||||||
}
|
}
|
||||||
ssrcInfo = mediaServerService.openRTPServer(mediaServerItem, streamId2);
|
ssrcInfo = mediaServerService.openRTPServer(mediaServerItem, streamId2);
|
||||||
|
|
||||||
|
@ -101,7 +101,7 @@ public class PlayController {
|
|||||||
@GetMapping("/stop/{deviceId}/{channelId}")
|
@GetMapping("/stop/{deviceId}/{channelId}")
|
||||||
public DeferredResult<ResponseEntity<String>> playStop(@PathVariable String deviceId, @PathVariable String channelId) {
|
public DeferredResult<ResponseEntity<String>> playStop(@PathVariable String deviceId, @PathVariable String channelId) {
|
||||||
|
|
||||||
logger.debug(String.format("设备预览/回放停止API调用,streamId:%s/%s", deviceId, channelId ));
|
logger.debug(String.format("设备预览/回放停止API调用,streamId:%s_%s", deviceId, channelId ));
|
||||||
|
|
||||||
UUID uuid = UUID.randomUUID();
|
UUID uuid = UUID.randomUUID();
|
||||||
DeferredResult<ResponseEntity<String>> result = new DeferredResult<ResponseEntity<String>>();
|
DeferredResult<ResponseEntity<String>> result = new DeferredResult<ResponseEntity<String>>();
|
||||||
@ -147,7 +147,7 @@ public class PlayController {
|
|||||||
|
|
||||||
// 超时处理
|
// 超时处理
|
||||||
result.onTimeout(()->{
|
result.onTimeout(()->{
|
||||||
logger.warn(String.format("设备预览/回放停止超时,deviceId/channelId:%s/%s ", deviceId, channelId));
|
logger.warn(String.format("设备预览/回放停止超时,deviceId/channelId:%s_%s ", deviceId, channelId));
|
||||||
RequestMessage msg = new RequestMessage();
|
RequestMessage msg = new RequestMessage();
|
||||||
msg.setId(DeferredResultHolder.CALLBACK_CMD_STOP + uuid);
|
msg.setId(DeferredResultHolder.CALLBACK_CMD_STOP + uuid);
|
||||||
msg.setData("Timeout");
|
msg.setData("Timeout");
|
||||||
|
@ -130,7 +130,7 @@ public class DownloadController {
|
|||||||
cmder.streamByeCmd(deviceId, channelId);
|
cmder.streamByeCmd(deviceId, channelId);
|
||||||
|
|
||||||
if (logger.isDebugEnabled()) {
|
if (logger.isDebugEnabled()) {
|
||||||
logger.debug(String.format("设备历史媒体下载停止 API调用,deviceId/channelId:%s/%s", deviceId, channelId));
|
logger.debug(String.format("设备历史媒体下载停止 API调用,deviceId/channelId:%s_%s", deviceId, channelId));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (deviceId != null && channelId != null) {
|
if (deviceId != null && channelId != null) {
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 6.7 KiB After Width: | Height: | Size: 66 KiB |
@ -22,7 +22,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="container-login100-form-btn">
|
<div class="container-login100-form-btn">
|
||||||
<div class="wrap-login100-form-btn">
|
<div class="wrap-login100-form-btn" :class="{'login-loading': isLoging}" v-loading="isLoging" element-loading-background="rgb(0 0 0 / 0%);" element-loading-custom-class="login-loading-class">
|
||||||
<div class="login100-form-bgbtn"></div>
|
<div class="login100-form-bgbtn"></div>
|
||||||
<button class="login100-form-btn" @click="login">登录</button>
|
<button class="login100-form-btn" @click="login">登录</button>
|
||||||
</div>
|
</div>
|
||||||
@ -41,6 +41,7 @@ export default {
|
|||||||
return {
|
return {
|
||||||
isLoging: false,
|
isLoging: false,
|
||||||
showPassword: false,
|
showPassword: false,
|
||||||
|
loginLoading: false,
|
||||||
username: '',
|
username: '',
|
||||||
password: ''
|
password: ''
|
||||||
}
|
}
|
||||||
|
@ -376,6 +376,31 @@
|
|||||||
.p-b-48 {padding-bottom: 48px;}
|
.p-b-48 {padding-bottom: 48px;}
|
||||||
.p-t-115 {padding-top: 115px;}
|
.p-t-115 {padding-top: 115px;}
|
||||||
|
|
||||||
|
@keyframes login {
|
||||||
|
from {width: 100%}
|
||||||
|
to {width: 50px}
|
||||||
|
}
|
||||||
|
|
||||||
|
.login-loading{
|
||||||
|
width: 50px;
|
||||||
|
animation-name: login;
|
||||||
|
animation-duration: 0.5s;
|
||||||
|
}
|
||||||
|
.login-loading > .login100-form-btn {
|
||||||
|
visibility: hidden !important;
|
||||||
|
}
|
||||||
|
.login-loading-class{
|
||||||
|
stroke: rgb(255, 255, 255) !important;
|
||||||
|
background-color: transparent !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.login-loading-class > .el-loading-spinner .path {
|
||||||
|
stroke: rgb(255, 255, 255) !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**font**/
|
/**font**/
|
||||||
/* .zmdi {
|
/* .zmdi {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
|
Loading…
Reference in New Issue
Block a user