Merge pull request #1137 from xiaoQQya/develop

bugfix: 修复推流鉴权、报警推送等问题
pull/1209/head
648540858 2023-12-11 10:22:26 +08:00 committed by GitHub
commit e73d00060e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 569 additions and 570 deletions

674
pom.xml
View File

@ -1,368 +1,382 @@
<?xml version="1.0"?> <?xml version="1.0"?>
<project <project
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<parent> <parent>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId> <artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.2</version> <version>2.7.17</version>
</parent> </parent>
<groupId>com.genersoft</groupId> <groupId>com.genersoft</groupId>
<artifactId>wvp-pro</artifactId> <artifactId>wvp-pro</artifactId>
<version>2.6.9</version> <version>2.6.9</version>
<name>web video platform</name> <name>web video platform</name>
<description>国标28181视频平台</description> <description>国标28181视频平台</description>
<packaging>${project.packaging}</packaging> <packaging>${project.packaging}</packaging>
<repositories> <repositories>
<repository> <repository>
<id>nexus-aliyun</id> <id>nexus-aliyun</id>
<name>Nexus aliyun</name> <name>Nexus aliyun</name>
<url>https://maven.aliyun.com/repository/public</url> <url>https://maven.aliyun.com/repository/public</url>
<layout>default</layout> <layout>default</layout>
<snapshots> <snapshots>
<enabled>false</enabled> <enabled>false</enabled>
</snapshots> </snapshots>
<releases> <releases>
<enabled>true</enabled> <enabled>true</enabled>
</releases> </releases>
</repository> </repository>
</repositories> </repositories>
<pluginRepositories>
<pluginRepository>
<id>nexus-aliyun</id>
<name>Nexus aliyun</name>
<url>https://maven.aliyun.com/repository/public</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</pluginRepository>
</pluginRepositories>
<properties> <pluginRepositories>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <pluginRepository>
<maven.build.timestamp.format>MMddHHmm</maven.build.timestamp.format> <id>nexus-aliyun</id>
<maven-jar-plugin.version>3.1.1</maven-jar-plugin.version> <name>Nexus aliyun</name>
<url>https://maven.aliyun.com/repository/public</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</pluginRepository>
</pluginRepositories>
<!-- 依赖版本 --> <properties>
<snippetsDirectory>${project.build.directory}/generated-snippets</snippetsDirectory> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<asciidoctor.input.directory>${project.basedir}/docs/asciidoc</asciidoctor.input.directory> <maven.build.timestamp.format>MMddHHmm</maven.build.timestamp.format>
<generated.asciidoc.directory>${project.build.directory}/asciidoc</generated.asciidoc.directory> <maven-jar-plugin.version>3.1.1</maven-jar-plugin.version>
<asciidoctor.html.output.directory>${project.build.directory}/asciidoc/html</asciidoctor.html.output.directory>
<asciidoctor.pdf.output.directory>${project.build.directory}/asciidoc/pdf</asciidoctor.pdf.output.directory>
</properties>
<profiles> <!-- 依赖版本 -->
<profile> <snippetsDirectory>${project.build.directory}/generated-snippets</snippetsDirectory>
<id>jar</id> <asciidoctor.input.directory>${project.basedir}/docs/asciidoc</asciidoctor.input.directory>
<activation> <generated.asciidoc.directory>${project.build.directory}/asciidoc</generated.asciidoc.directory>
<activeByDefault>true</activeByDefault> <asciidoctor.html.output.directory>${project.build.directory}/asciidoc/html</asciidoctor.html.output.directory>
</activation> <asciidoctor.pdf.output.directory>${project.build.directory}/asciidoc/pdf</asciidoctor.pdf.output.directory>
<properties> </properties>
<project.packaging>jar</project.packaging>
</properties>
</profile>
<profile>
<id>war</id>
<properties>
<project.packaging>war</project.packaging>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</profile>
</profiles>
<dependencies> <profiles>
<dependency> <profile>
<groupId>org.springframework.boot</groupId> <id>jar</id>
<artifactId>spring-boot-starter-data-redis</artifactId> <activation>
</dependency> <activeByDefault>true</activeByDefault>
<dependency> </activation>
<groupId>org.springframework.boot</groupId> <properties>
<artifactId>spring-boot-starter-web</artifactId> <project.packaging>jar</project.packaging>
</dependency> </properties>
<dependency> </profile>
<groupId>org.springframework.boot</groupId> <profile>
<artifactId>spring-boot-configuration-processor</artifactId> <id>war</id>
<optional>true</optional> <properties>
</dependency> <project.packaging>war</project.packaging>
<dependency> </properties>
<groupId>org.mybatis.spring.boot</groupId> <dependencies>
<artifactId>mybatis-spring-boot-starter</artifactId> <dependency>
<version>2.2.2</version> <groupId>org.springframework.boot</groupId>
<exclusions> <artifactId>spring-boot-starter-web</artifactId>
<exclusion> <exclusions>
<groupId>com.zaxxer</groupId> <exclusion>
<artifactId>HikariCP</artifactId> <groupId>org.springframework.boot</groupId>
</exclusion> <artifactId>spring-boot-starter-jetty</artifactId>
</exclusions> </exclusion>
</dependency> </exclusions>
<dependency> </dependency>
<groupId>org.springframework.boot</groupId> <dependency>
<artifactId>spring-boot-starter-security</artifactId> <groupId>javax.servlet</groupId>
</dependency> <artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</profile>
</profiles>
<dependency> <dependencies>
<groupId>org.springframework.boot</groupId> <dependency>
<artifactId>spring-boot-starter-jdbc</artifactId> <groupId>org.springframework.boot</groupId>
</dependency> <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.2.2</version>
<exclusions>
<exclusion>
<groupId>com.zaxxer</groupId>
<artifactId>HikariCP</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<!-- mysql数据库 --> <dependency>
<dependency> <groupId>org.springframework.boot</groupId>
<groupId>mysql</groupId> <artifactId>spring-boot-starter-jdbc</artifactId>
<artifactId>mysql-connector-java</artifactId> </dependency>
<version>8.0.30</version>
</dependency>
<!--postgresql--> <!-- mysql数据库 -->
<dependency> <dependency>
<groupId>org.postgresql</groupId> <groupId>com.mysql</groupId>
<artifactId>postgresql</artifactId> <artifactId>mysql-connector-j</artifactId>
<version>42.5.1</version> <version>8.2.0</version>
</dependency> </dependency>
<!-- kingbase人大金仓 --> <!--postgresql-->
<!-- 手动下载驱动后安装 --> <dependency>
<!-- mvn install:install-file -Dfile=/home/lin/soft/kingbase/jdbc-aarch/kingbase8-8.6.0.jar -DgroupId=com.kingbase -DartifactId=kingbase8 -Dversion=8.6.0 -Dpackaging=jar <groupId>org.postgresql</groupId>
--> <artifactId>postgresql</artifactId>
<dependency> <version>42.5.1</version>
<groupId>com.kingbase</groupId> </dependency>
<artifactId>kingbase8</artifactId>
<version>8.6.0</version>
<scope>system</scope>
<systemPath>${basedir}/libs/jdbc-aarch/kingbase8-8.6.0.jar</systemPath>
</dependency>
<!--Mybatis分页插件 --> <!-- kingbase人大金仓 -->
<dependency> <!-- 手动下载驱动后安装 -->
<groupId>com.github.pagehelper</groupId> <!-- mvn install:install-file -Dfile=/home/lin/soft/kingbase/jdbc-aarch/kingbase8-8.6.0.jar -DgroupId=com.kingbase -DartifactId=kingbase8
<artifactId>pagehelper-spring-boot-starter</artifactId> -Dversion=8.6.0 -Dpackaging=jar -->
<version>1.4.6</version> <dependency>
</dependency> <groupId>com.kingbase</groupId>
<artifactId>kingbase8</artifactId>
<version>8.6.0</version>
<scope>system</scope>
<systemPath>${basedir}/libs/jdbc-aarch/kingbase8-8.6.0.jar</systemPath>
</dependency>
<!--在线文档 --> <!--Mybatis分页插件 -->
<dependency> <dependency>
<groupId>org.springdoc</groupId> <groupId>com.github.pagehelper</groupId>
<artifactId>springdoc-openapi-ui</artifactId> <artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.6.10</version> <version>1.4.6</version>
</dependency> </dependency>
<dependency> <!--在线文档 -->
<groupId>com.github.xiaoymin</groupId> <dependency>
<artifactId>knife4j-springdoc-ui</artifactId> <groupId>org.springdoc</groupId>
<version>3.0.3</version> <artifactId>springdoc-openapi-ui</artifactId>
</dependency> <version>1.7.0</version>
<exclusions>
<exclusion>
<groupId>org.yaml</groupId>
<artifactId>snakeyaml</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.yaml</groupId>
<artifactId>snakeyaml</artifactId>
<version>2.2</version>
</dependency>
<!--参数校验 --> <dependency>
<dependency> <groupId>com.github.xiaoymin</groupId>
<groupId>javax.validation</groupId> <artifactId>knife4j-springdoc-ui</artifactId>
<artifactId>validation-api</artifactId> <version>3.0.3</version>
</dependency> </dependency>
<!-- 日志相关 --> <!--参数校验 -->
<dependency> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>javax.validation</groupId>
<artifactId>spring-boot-starter-aop</artifactId> <artifactId>validation-api</artifactId>
</dependency> </dependency>
<!-- sip协议栈 --> <!-- 日志相关 -->
<dependency> <dependency>
<groupId>javax.sip</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>jain-sip-ri</artifactId> <artifactId>spring-boot-starter-aop</artifactId>
<version>1.3.0-91</version> </dependency>
</dependency>
<!-- 取代log4j --> <!-- sip协议栈 -->
<dependency> <dependency>
<groupId>org.slf4j</groupId> <groupId>javax.sip</groupId>
<artifactId>log4j-over-slf4j</artifactId> <artifactId>jain-sip-ri</artifactId>
<version>1.7.36</version> <version>1.3.0-91</version>
</dependency> </dependency>
<!-- xml解析库 --> <!-- 取代log4j -->
<dependency> <dependency>
<groupId>org.dom4j</groupId> <groupId>org.slf4j</groupId>
<artifactId>dom4j</artifactId> <artifactId>log4j-over-slf4j</artifactId>
<version>2.1.3</version> <version>1.7.36</version>
</dependency> </dependency>
<dependency> <!-- xml解析库 -->
<groupId>com.google.guava</groupId> <dependency>
<artifactId>guava</artifactId> <groupId>org.dom4j</groupId>
<version>20.0</version> <artifactId>dom4j</artifactId>
</dependency> <version>2.1.3</version>
</dependency>
<!-- json解析库fastjson2 --> <!-- json解析库fastjson2 -->
<dependency> <dependency>
<groupId>com.alibaba.fastjson2</groupId> <groupId>com.alibaba.fastjson2</groupId>
<artifactId>fastjson2</artifactId> <artifactId>fastjson2</artifactId>
<version>2.0.17</version> <version>2.0.17</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.alibaba.fastjson2</groupId> <groupId>com.alibaba.fastjson2</groupId>
<artifactId>fastjson2-extension</artifactId> <artifactId>fastjson2-extension</artifactId>
<version>2.0.17</version> <version>2.0.17</version>
</dependency> </dependency>
<!-- okhttp --> <!-- okhttp -->
<dependency> <dependency>
<groupId>com.squareup.okhttp3</groupId> <groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId> <artifactId>okhttp</artifactId>
<version>4.10.0</version> <version>4.10.0</version>
</dependency> </dependency>
<!-- okhttp 调试日志 --> <!-- okhttp 调试日志 -->
<dependency> <dependency>
<groupId>com.squareup.okhttp3</groupId> <groupId>com.squareup.okhttp3</groupId>
<artifactId>logging-interceptor</artifactId> <artifactId>logging-interceptor</artifactId>
<version>4.10.0</version> <version>4.10.0</version>
</dependency> </dependency>
<!-- okhttp-digest --> <!-- okhttp-digest -->
<dependency> <dependency>
<groupId>io.github.rburgst</groupId> <groupId>io.github.rburgst</groupId>
<artifactId>okhttp-digest</artifactId> <artifactId>okhttp-digest</artifactId>
<version>2.7</version> <version>2.7</version>
</dependency> </dependency>
<!-- https://mvnrepository.com/artifact/net.sf.kxml/kxml2 --> <!-- https://mvnrepository.com/artifact/net.sf.kxml/kxml2 -->
<!-- <dependency>--> <!-- <dependency>-->
<!-- <groupId>net.sf.kxml</groupId>--> <!-- <groupId>net.sf.kxml</groupId>-->
<!-- <artifactId>kxml2</artifactId>--> <!-- <artifactId>kxml2</artifactId>-->
<!-- <version>2.3.0</version>--> <!-- <version>2.3.0</version>-->
<!-- </dependency>--> <!-- </dependency>-->
<!-- jwt实现 --> <!-- jwt实现 -->
<dependency> <dependency>
<groupId>org.bitbucket.b_c</groupId> <groupId>org.bitbucket.b_c</groupId>
<artifactId>jose4j</artifactId> <artifactId>jose4j</artifactId>
<version>0.9.3</version> <version>0.9.3</version>
</dependency> </dependency>
<!--反向代理--> <!--反向代理-->
<dependency> <dependency>
<groupId>org.mitre.dsmiley.httpproxy</groupId> <groupId>org.mitre.dsmiley.httpproxy</groupId>
<artifactId>smiley-http-proxy-servlet</artifactId> <artifactId>smiley-http-proxy-servlet</artifactId>
<version>1.12.1</version> <version>1.12.1</version>
</dependency> </dependency>
<!--excel解析库--> <!--excel解析库-->
<dependency> <dependency>
<groupId>com.alibaba</groupId> <groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId> <artifactId>easyexcel</artifactId>
<version>3.1.1</version> <version>3.3.2</version>
</dependency> <exclusions>
<exclusion>
<groupId>org.apache.commons</groupId>
<artifactId>commons-compress</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-compress</artifactId>
<version>1.24.0</version>
</dependency>
<!-- 获取系统信息 --> <!-- 获取系统信息 -->
<dependency> <dependency>
<groupId>com.github.oshi</groupId> <groupId>com.github.oshi</groupId>
<artifactId>oshi-core</artifactId> <artifactId>oshi-core</artifactId>
<version>6.2.2</version> <version>6.2.2</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.springframework.session</groupId> <groupId>org.springframework.session</groupId>
<artifactId>spring-session-core</artifactId> <artifactId>spring-session-core</artifactId>
</dependency> </dependency>
<!-- &lt;!&ndash; 检测文件编码 &ndash;&gt;--> <!-- 检测文件编码 -->
<!-- &lt;!&ndash; https://mvnrepository.com/artifact/cpdetector/cpdetector &ndash;&gt;--> <!-- https://mvnrepository.com/artifact/cpdetector/cpdetector -->
<!-- <dependency>--> <!--<dependency>-->
<!-- <groupId>cpdetector</groupId>--> <!-- <groupId>cpdetector</groupId>-->
<!-- <artifactId>cpdetector</artifactId>--> <!-- <artifactId>cpdetector</artifactId>-->
<!-- <version>1.0.8</version>--> <!-- <version>1.0.8</version>-->
<!-- </dependency>--> <!--</dependency>-->
<!-- https://mvnrepository.com/artifact/com.google.guava/guava --> <!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
<dependency> <dependency>
<groupId>com.google.guava</groupId> <groupId>com.google.guava</groupId>
<artifactId>guava</artifactId> <artifactId>guava</artifactId>
<version>31.1-jre</version> <version>32.1.3-jre</version>
</dependency> </dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependency> <build>
<groupId>org.springframework.boot</groupId> <finalName>${project.artifactId}-${project.version}-${maven.build.timestamp}</finalName>
<artifactId>spring-boot-starter-test</artifactId> <plugins>
<!-- <scope>test</scope>--> <plugin>
</dependency> <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.7.2</version>
<configuration>
<includeSystemScope>true</includeSystemScope>
</configuration>
</plugin>
</dependencies> <plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>pl.project13.maven</groupId>
<artifactId>git-commit-id-plugin</artifactId>
<version>3.0.1</version>
<configuration>
<offline>true</offline>
<failOnNoGitDirectory>false</failOnNoGitDirectory>
<dateFormat>yyyyMMdd</dateFormat>
</configuration>
</plugin>
<build> <plugin>
<finalName>${project.artifactId}-${project.version}-${maven.build.timestamp}</finalName> <groupId>org.apache.maven.plugins</groupId>
<plugins> <artifactId>maven-surefire-plugin</artifactId>
<plugin> <version>2.22.2</version>
<groupId>org.springframework.boot</groupId> <configuration>
<artifactId>spring-boot-maven-plugin</artifactId> <skipTests>true</skipTests>
<version>2.7.2</version> </configuration>
<configuration> </plugin>
<includeSystemScope>true</includeSystemScope> </plugins>
</configuration> <resources>
</plugin> <resource>
<plugin> <directory>src/main/resources</directory>
<groupId>org.apache.maven.plugins</groupId> </resource>
<artifactId>maven-compiler-plugin</artifactId> <resource>
<version>3.8.1</version> <directory>src/main/java</directory>
<configuration> <includes>
<source>1.8</source> <include>**/*.xml</include>
<target>1.8</target> </includes>
</configuration> </resource>
</plugin> </resources>
</build>
<plugin>
<groupId>pl.project13.maven</groupId>
<artifactId>git-commit-id-plugin</artifactId>
<version>3.0.1</version>
<configuration>
<offline>true</offline>
<failOnNoGitDirectory>false</failOnNoGitDirectory>
<dateFormat>yyyyMMdd</dateFormat>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.2</version>
<configuration>
<skipTests>true</skipTests>
</configuration>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/resources</directory>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.xml</include>
</includes>
</resource>
</resources>
</build>
</project> </project>

View File

@ -1,12 +1,12 @@
package com.genersoft.iot.vmp.conf.security; package com.genersoft.iot.vmp.conf.security;
import com.genersoft.iot.vmp.conf.UserSetting; import com.genersoft.iot.vmp.conf.UserSetting;
import org.springframework.core.annotation.Order;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.core.annotation.Order;
import org.springframework.security.authentication.AuthenticationManager; import org.springframework.security.authentication.AuthenticationManager;
import org.springframework.security.authentication.dao.DaoAuthenticationProvider; import org.springframework.security.authentication.dao.DaoAuthenticationProvider;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
@ -28,6 +28,7 @@ import java.util.Arrays;
/** /**
* Spring Security * Spring Security
*
* @author lin * @author lin
*/ */
@Configuration @Configuration
@ -75,6 +76,7 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
matchers.add("/js/**"); matchers.add("/js/**");
matchers.add("/api/device/query/snap/**"); matchers.add("/api/device/query/snap/**");
matchers.add("/record_proxy/*/**"); matchers.add("/record_proxy/*/**");
matchers.add("/api/emit");
matchers.addAll(userSetting.getInterfaceAuthenticationExcludes()); matchers.addAll(userSetting.getInterfaceAuthenticationExcludes());
// 可以直接访问的静态数据 // 可以直接访问的静态数据
web.ignoring().antMatchers(matchers.toArray(new String[0])); web.ignoring().antMatchers(matchers.toArray(new String[0]));
@ -83,6 +85,7 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
/** /**
* *
*
* @param auth * @param auth
* @throws Exception * @throws Exception
*/ */
@ -111,7 +114,7 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
.authorizeRequests() .authorizeRequests()
.requestMatchers(CorsUtils::isPreFlightRequest).permitAll() .requestMatchers(CorsUtils::isPreFlightRequest).permitAll()
.antMatchers(userSetting.getInterfaceAuthenticationExcludes().toArray(new String[0])).permitAll() .antMatchers(userSetting.getInterfaceAuthenticationExcludes().toArray(new String[0])).permitAll()
.antMatchers("/api/user/login","/index/hook/**","/zlm_Proxy/FhTuMYqB2HeCuNOb/record/t/1/2023-03-25/16:35:07-16:35:16-9353.mp4").permitAll() .antMatchers("/api/user/login", "/index/hook/**").permitAll()
.anyRequest().authenticated() .anyRequest().authenticated()
// 异常处理器 // 异常处理器
.and() .and()
@ -124,7 +127,7 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
} }
CorsConfigurationSource configurationSource(){ CorsConfigurationSource configurationSource() {
// 配置跨域 // 配置跨域
CorsConfiguration corsConfiguration = new CorsConfiguration(); CorsConfiguration corsConfiguration = new CorsConfiguration();
corsConfiguration.setAllowedHeaders(Arrays.asList("*")); corsConfiguration.setAllowedHeaders(Arrays.asList("*"));
@ -135,7 +138,7 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
corsConfiguration.setExposedHeaders(Arrays.asList(JwtUtils.getHeader())); corsConfiguration.setExposedHeaders(Arrays.asList(JwtUtils.getHeader()));
UrlBasedCorsConfigurationSource url = new UrlBasedCorsConfigurationSource(); UrlBasedCorsConfigurationSource url = new UrlBasedCorsConfigurationSource();
url.registerCorsConfiguration("/**",corsConfiguration); url.registerCorsConfiguration("/**", corsConfiguration);
return url; return url;
} }

View File

@ -1,55 +1,68 @@
package com.genersoft.iot.vmp.gb28181.event.alarm; package com.genersoft.iot.vmp.gb28181.event.alarm;
import org.springframework.context.ApplicationListener; import org.jetbrains.annotations.NotNull;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
import java.io.IOException;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.Map;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationListener;
import org.springframework.stereotype.Component;
import java.io.PrintWriter;
import java.util.Iterator;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
/** /**
* @description: * .
* @author: lawrencehj *
* @data: 2021-01-20 * @author lawrencehj
* @author <a href="mailto:xiaoQQya@126.com">xiaoQQya</a>
* @since 2021/01/20
*/ */
@Component @Component
public class AlarmEventListener implements ApplicationListener<AlarmEvent> { public class AlarmEventListener implements ApplicationListener<AlarmEvent> {
private final static Logger logger = LoggerFactory.getLogger(AlarmEventListener.class); private static final Logger logger = LoggerFactory.getLogger(AlarmEventListener.class);
private static Map<String, SseEmitter> sseEmitters = new Hashtable<>(); private static final Map<String, PrintWriter> SSE_CACHE = new ConcurrentHashMap<>();
public void addSseEmitters(String browserId, SseEmitter sseEmitter) { public void addSseEmitter(String browserId, PrintWriter writer) {
sseEmitters.put(browserId, sseEmitter); SSE_CACHE.put(browserId, writer);
logger.info("SSE 在线数量: {}", SSE_CACHE.size());
}
public void removeSseEmitter(String browserId, PrintWriter writer) {
SSE_CACHE.remove(browserId, writer);
logger.info("SSE 在线数量: {}", SSE_CACHE.size());
} }
@Override @Override
public void onApplicationEvent(AlarmEvent event) { public void onApplicationEvent(@NotNull AlarmEvent event) {
if (logger.isDebugEnabled()) { if (logger.isDebugEnabled()) {
logger.debug("设备报警事件触发deviceId" + event.getAlarmInfo().getDeviceId() + ", " logger.debug("设备报警事件触发, deviceId: {}, {}", event.getAlarmInfo().getDeviceId(), event.getAlarmInfo().getAlarmDescription());
+ event.getAlarmInfo().getAlarmDescription());
} }
String msg = "<strong>设备编码:</strong> <i>" + event.getAlarmInfo().getDeviceId() + "</i>"
+ "<br><strong>报警描述:</strong> <i>" + event.getAlarmInfo().getAlarmDescription() + "</i>"
+ "<br><strong>报警时间:</strong> <i>" + event.getAlarmInfo().getAlarmTime() + "</i>"
+ "<br><strong>报警位置:</strong> <i>" + event.getAlarmInfo().getLongitude() + "</i>"
+ ", <i>" + event.getAlarmInfo().getLatitude() + "</i>";
for (Iterator<Map.Entry<String, SseEmitter>> it = sseEmitters.entrySet().iterator(); it.hasNext();) { String msg = "<strong>设备编号:</strong> <i>" + event.getAlarmInfo().getDeviceId() + "</i>"
Map.Entry<String, SseEmitter> emitter = it.next(); + "<br><strong>通道编号:</strong> <i>" + event.getAlarmInfo().getChannelId() + "</i>"
logger.info("推送到SSE连接浏览器ID: " + emitter.getKey()); + "<br><strong>报警描述:</strong> <i>" + event.getAlarmInfo().getAlarmDescription() + "</i>"
+ "<br><strong>报警时间:</strong> <i>" + event.getAlarmInfo().getAlarmTime() + "</i>";
for (Iterator<Map.Entry<String, PrintWriter>> it = SSE_CACHE.entrySet().iterator(); it.hasNext(); ) {
Map.Entry<String, PrintWriter> response = it.next();
logger.info("推送到 SSE 连接, 浏览器 ID: {}", response.getKey());
try { try {
emitter.getValue().send(msg); PrintWriter writer = response.getValue();
} catch (IOException | IllegalStateException e) {
if (logger.isDebugEnabled()) { if (writer.checkError()) {
logger.debug("SSE连接已关闭"); it.remove();
continue;
} }
// 移除已关闭的连接
String sseMsg = "event:message\n" +
"data:" + msg + "\n" +
"\n";
writer.write(sseMsg);
writer.flush();
} catch (Exception e) {
it.remove(); it.remove();
} }
} }

View File

@ -244,7 +244,6 @@ public class ZLMHttpHookListener {
HookResultForOnPublish result = HookResultForOnPublish.SUCCESS(); HookResultForOnPublish result = HookResultForOnPublish.SUCCESS();
result.setEnable_audio(true);
taskExecutor.execute(() -> { taskExecutor.execute(() -> {
ZlmHttpHookSubscribe.Event subscribe = this.subscribe.sendNotify(HookType.on_publish, json); ZlmHttpHookSubscribe.Event subscribe = this.subscribe.sendNotify(HookType.on_publish, json);
if (subscribe != null) { if (subscribe != null) {
@ -262,29 +261,36 @@ public class ZLMHttpHookListener {
} else { } else {
result.setEnable_mp4(userSetting.isRecordPushLive()); result.setEnable_mp4(userSetting.isRecordPushLive());
} }
// 替换流地址
if ("rtp".equals(param.getApp()) && !mediaInfo.isRtpEnable()) { // 国标流
String ssrc = String.format("%010d", Long.parseLong(param.getStream(), 16));; if ("rtp".equals(param.getApp())) {
String ssrc = String.format("%010d", Long.parseLong(param.getStream(), 16));
InviteInfo inviteInfo = inviteStreamService.getInviteInfoBySSRC(ssrc); InviteInfo inviteInfo = inviteStreamService.getInviteInfoBySSRC(ssrc);
if (inviteInfo != null) {
// 单端口模式下修改流 ID
if (!mediaInfo.isRtpEnable() && inviteInfo != null) {
result.setStream_replace(inviteInfo.getStream()); result.setStream_replace(inviteInfo.getStream());
logger.info("[ZLM HOOK]推流鉴权 stream: {} 替换为 {}", param.getStream(), inviteInfo.getStream()); logger.info("[ZLM HOOK]推流鉴权 stream: {} 替换为 {}", param.getStream(), inviteInfo.getStream());
} }
}
List<SsrcTransaction> ssrcTransactionForAll = sessionManager.getSsrcTransactionForAll(null, null, null, param.getStream()); // 设置音频信息及录制信息
if (ssrcTransactionForAll != null && ssrcTransactionForAll.size() == 1) { List<SsrcTransaction> ssrcTransactionForAll = (inviteInfo == null ? null :
String deviceId = ssrcTransactionForAll.get(0).getDeviceId(); sessionManager.getSsrcTransactionForAll(inviteInfo.getDeviceId(), inviteInfo.getChannelId(), null, null));
String channelId = ssrcTransactionForAll.get(0).getChannelId(); if (ssrcTransactionForAll != null && ssrcTransactionForAll.size() == 1) {
DeviceChannel deviceChannel = storager.queryChannel(deviceId, channelId); String deviceId = ssrcTransactionForAll.get(0).getDeviceId();
if (deviceChannel != null) { String channelId = ssrcTransactionForAll.get(0).getChannelId();
result.setEnable_audio(deviceChannel.isHasAudio()); DeviceChannel deviceChannel = storager.queryChannel(deviceId, channelId);
} if (deviceChannel != null) {
// 如果是录像下载就设置视频间隔十秒 result.setEnable_audio(deviceChannel.isHasAudio());
if (ssrcTransactionForAll.get(0).getType() == InviteSessionType.DOWNLOAD) { }
result.setMp4_max_second(10); // 如果是录像下载就设置视频间隔十秒
result.setEnable_mp4(true); if (ssrcTransactionForAll.get(0).getType() == InviteSessionType.DOWNLOAD) {
result.setMp4_max_second(10);
result.setEnable_mp4(true);
}
} }
} }
if (mediaInfo.getRecordAssistPort() > 0 && userSetting.getRecordPath() == null) { if (mediaInfo.getRecordAssistPort() > 0 && userSetting.getRecordPath() == null) {
logger.info("推流时发现尚未设置录像路径从assist服务中读取"); logger.info("推流时发现尚未设置录像路径从assist服务中读取");
JSONObject info = assistRESTfulUtils.getInfo(mediaInfo, null); JSONObject info = assistRESTfulUtils.getInfo(mediaInfo, null);

View File

@ -569,7 +569,7 @@ public class MediaServerServiceImpl implements IMediaServerService {
Map<String, Object> param = new HashMap<>(); Map<String, Object> param = new HashMap<>();
param.put("api.secret",mediaServerItem.getSecret()); // -profile:v Baseline param.put("api.secret",mediaServerItem.getSecret()); // -profile:v Baseline
if (mediaServerItem.getRtspPort() != 0) { if (mediaServerItem.getRtspPort() != 0) {
param.put("ffmpeg.snap", "%s -rtsp_transport tcp -i %s -y -f mjpeg -t 0.001 %s"); param.put("ffmpeg.snap", "%s -rtsp_transport tcp -i %s -y -f mjpeg -frames:v 1 %s");
} }
param.put("hook.enable","1"); param.put("hook.enable","1");
param.put("hook.on_flow_report",""); param.put("hook.on_flow_report","");

View File

@ -1,37 +0,0 @@
package com.genersoft.iot.vmp.vmanager.gb28181.SseController;
import com.genersoft.iot.vmp.gb28181.event.alarm.AlarmEventListener;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.mvc.method.annotation.SseEmitter;
/**
* @description: SSE
* @author: lawrencehj
* @data: 2021-01-20
*/
@Tag(name = "SSE推送")
@Controller
@RequestMapping("/api")
public class SseController {
@Autowired
AlarmEventListener alarmEventListener;
@GetMapping("/emit")
public SseEmitter emit(@RequestParam String browserId) {
final SseEmitter sseEmitter = new SseEmitter(0L);
try {
alarmEventListener.addSseEmitters(browserId, sseEmitter);
}catch (Exception e){
sseEmitter.completeWithError(e);
}
return sseEmitter;
}
}

View File

@ -0,0 +1,55 @@
package com.genersoft.iot.vmp.vmanager.gb28181.sse;
import com.genersoft.iot.vmp.gb28181.event.alarm.AlarmEventListener;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
/**
* SSE .
*
* @author lawrencehj
* @author <a href="mailto:xiaoQQya@126.com">xiaoQQya</a>
* @since 2021/01/20
*/
@Tag(name = "SSE 推送")
@RestController
@RequestMapping("/api")
public class SseController {
@Resource
private AlarmEventListener alarmEventListener;
/**
* SSE .
*
* @param response
* @param browserId ID
* @throws IOException IOEXCEPTION
* @author <a href="mailto:xiaoQQya@126.com">xiaoQQya</a>
* @since 2023/11/06
*/
@GetMapping("/emit")
public void emit(HttpServletResponse response, @RequestParam String browserId) throws IOException, InterruptedException {
response.setContentType("text/event-stream");
response.setCharacterEncoding("utf-8");
PrintWriter writer = response.getWriter();
alarmEventListener.addSseEmitter(browserId, writer);
while (!writer.checkError()) {
Thread.sleep(1000);
writer.write(":keep alive\n\n");
writer.flush();
}
alarmEventListener.removeSseEmitter(browserId, writer);
}
}

View File

@ -1,6 +1,6 @@
<template> <template>
<div ref="container" @dblclick="fullscreenSwich" <div ref="container" @dblclick="fullscreenSwich"
style="width:100%;height:100%;background-color: #000000;margin:0 auto;"> style="width:100%;height:100%;background-color: #000000;margin:0 auto;position: relative;">
<div class="buttons-box" id="buttonsBox"> <div class="buttons-box" id="buttonsBox">
<div class="buttons-box-left"> <div class="buttons-box-left">
<i v-if="!playing" class="iconfont icon-play jessibuca-btn" @click="playBtnClick"></i> <i v-if="!playing" class="iconfont icon-play jessibuca-btn" @click="playBtnClick"></i>
@ -47,10 +47,6 @@ export default {
}, },
props: ['videoUrl', 'error', 'hasAudio', 'height'], props: ['videoUrl', 'error', 'hasAudio', 'height'],
mounted() { mounted() {
window.onerror = (msg) => {
// console.error(msg)
};
console.log(this._uid)
let paramUrl = decodeURIComponent(this.$route.params.url) let paramUrl = decodeURIComponent(this.$route.params.url)
this.$nextTick(() => { this.$nextTick(() => {
this.updatePlayerDomSize() this.updatePlayerDomSize()
@ -61,15 +57,17 @@ export default {
this.videoUrl = paramUrl; this.videoUrl = paramUrl;
} }
this.btnDom = document.getElementById("buttonsBox"); this.btnDom = document.getElementById("buttonsBox");
console.log("初始化时的地址为: " + this.videoUrl)
this.play(this.videoUrl)
}) })
}, },
watch: { watch: {
videoUrl(newData, oldData) { videoUrl: {
this.play(newData) handler(val, _) {
}, this.$nextTick(() => {
immediate: true this.play(val);
})
},
immediate: true
}
}, },
methods: { methods: {
updatePlayerDomSize() { updatePlayerDomSize() {
@ -87,70 +85,54 @@ export default {
dom.style.height = height + "px"; dom.style.height = height + "px";
}, },
create() { create() {
let options = {}; let options = {
console.log("hasAudio " + this.hasAudio) container: this.$refs.container,
autoWasm: true,
jessibucaPlayer[this._uid] = new window.Jessibuca(Object.assign( background: "",
{ controlAutoHide: false,
container: this.$refs.container, debug: false,
autoWasm: true, decoder: "static/js/jessibuca/decoder.js",
background: "", forceNoOffscreen: false,
controlAutoHide: false, hasAudio: typeof (this.hasAudio) == "undefined" ? true : this.hasAudio,
debug: false, heartTimeout: 5,
decoder: "static/js/jessibuca/decoder.js", heartTimeoutReplay: true,
forceNoOffscreen: true, heartTimeoutReplayTimes: 3,
hasAudio: typeof (this.hasAudio) == "undefined" ? true : this.hasAudio, hiddenAutoPause: false,
hasVideo: true, hotKey: true,
heartTimeout: 5, isFlv: false,
heartTimeoutReplay: true, isFullResize: false,
heartTimeoutReplayTimes: 3, isNotMute: this.isNotMute,
hiddenAutoPause: false, isResize: false,
hotKey: false, keepScreenOn: true,
isFlv: false, loadingText: "请稍等, 视频加载中......",
isFullResize: false, loadingTimeout: 10,
isNotMute: this.isNotMute, loadingTimeoutReplay: true,
isResize: false, loadingTimeoutReplayTimes: 3,
keepScreenOn: false, openWebglAlignment: false,
loadingText: "请稍等, 视频加载中......", operateBtns: {
loadingTimeout: 10, fullscreen: false,
loadingTimeoutReplay: true, screenshot: false,
loadingTimeoutReplayTimes: 3, play: false,
openWebglAlignment: false, audio: false,
operateBtns: { record: false
fullscreen: false,
screenshot: false,
play: false,
audio: false,
record: false
},
recordType: "webm",
rotate: 0,
showBandwidth: false,
supportDblclickFullscreen: false,
timeout: 10,
useMSE: location.hostname !== "localhost" && location.protocol !== "https:",
useOffscreen: false,
useWCS: location.hostname === "localhost" || location.protocol === "https",
useWebFullScreen: false,
videoBuffer: 0,
wasmDecodeAudioSyncVideo: true,
wasmDecodeErrorReplay: true,
wcsUseVideoRender: true
}, },
options recordType: "mp4",
)); rotate: 0,
showBandwidth: false,
supportDblclickFullscreen: false,
timeout: 10,
useMSE: true,
useWCS: location.hostname === "localhost" || location.protocol === "https:",
useWebFullScreen: true,
videoBuffer: 0.1,
wasmDecodeErrorReplay: true,
wcsUseVideoRender: true
};
console.log("Jessibuca -> options: ", options);
jessibucaPlayer[this._uid] = new window.Jessibuca({...options});
let jessibuca = jessibucaPlayer[this._uid]; let jessibuca = jessibucaPlayer[this._uid];
let _this = this; let _this = this;
jessibuca.on("load", function () {
console.log("on load init");
});
jessibuca.on("log", function (msg) {
console.log("on log", msg);
});
jessibuca.on("record", function (msg) {
console.log("on record:", msg);
});
jessibuca.on("pause", function () { jessibuca.on("pause", function () {
_this.playing = false; _this.playing = false;
}); });
@ -158,44 +140,11 @@ export default {
_this.playing = true; _this.playing = true;
}); });
jessibuca.on("fullscreen", function (msg) { jessibuca.on("fullscreen", function (msg) {
console.log("on fullscreen", msg);
_this.fullscreen = msg _this.fullscreen = msg
}); });
jessibuca.on("mute", function (msg) { jessibuca.on("mute", function (msg) {
console.log("on mute", msg);
_this.isNotMute = !msg; _this.isNotMute = !msg;
}); });
jessibuca.on("audioInfo", function (msg) {
console.log("audioInfo", msg);
});
jessibuca.on("bps", function (bps) {
// console.log('bps', bps);
});
let _ts = 0;
jessibuca.on("timeUpdate", function (ts) {
// console.log('timeUpdate,old,new,timestamp', _ts, ts, ts - _ts);
_ts = ts;
});
jessibuca.on("videoInfo", function (info) {
console.log("videoInfo", info);
});
jessibuca.on("error", function (error) {
console.log("error", error);
});
jessibuca.on("timeout", function () {
console.log("timeout");
});
jessibuca.on('start', function () {
console.log('start');
})
jessibuca.on("performance", function (performance) { jessibuca.on("performance", function (performance) {
let show = "卡顿"; let show = "卡顿";
if (performance === 2) { if (performance === 2) {
@ -205,33 +154,36 @@ export default {
} }
_this.performance = show; _this.performance = show;
}); });
jessibuca.on('buffer', function (buffer) {
// console.log('buffer', buffer);
})
jessibuca.on('stats', function (stats) {
// console.log('stats', stats);
})
jessibuca.on('kBps', function (kBps) { jessibuca.on('kBps', function (kBps) {
_this.kBps = Math.round(kBps); _this.kBps = Math.round(kBps);
}); });
jessibuca.on("videoInfo", function (msg) {
// PTS console.log("Jessibuca -> videoInfo: ", msg);
jessibuca.on('videoFrame', function () { });
jessibuca.on("audioInfo", function (msg) {
}) console.log("Jessibuca -> audioInfo: ", msg);
});
// jessibuca.on("error", function (msg) {
jessibuca.on('metadata', function () { console.log("Jessibuca -> error: ", msg);
});
jessibuca.on("timeout", function (msg) {
console.log("Jessibuca -> timeout: ", msg);
});
jessibuca.on("loadingTimeout", function (msg) {
console.log("Jessibuca -> timeout: ", msg);
});
jessibuca.on("delayTimeout", function (msg) {
console.log("Jessibuca -> timeout: ", msg);
});
jessibuca.on("playToRenderTimes", function (msg) {
console.log("Jessibuca -> playToRenderTimes: ", msg);
}); });
}, },
playBtnClick: function (event) { playBtnClick: function (event) {
this.play(this.videoUrl) this.play(this.videoUrl)
}, },
play: function (url) { play: function (url) {
console.log(url) console.log("Jessibuca -> url: ", url);
if (jessibucaPlayer[this._uid]) { if (jessibucaPlayer[this._uid]) {
this.destroy(); this.destroy();
} }
@ -245,7 +197,6 @@ export default {
jessibucaPlayer[this._uid].play(url); jessibucaPlayer[this._uid].play(url);
} else { } else {
jessibucaPlayer[this._uid].on("load", () => { jessibucaPlayer[this._uid].on("load", () => {
console.log("load 播放")
jessibucaPlayer[this._uid].play(url); jessibucaPlayer[this._uid].play(url);
}); });
} }
@ -286,11 +237,6 @@ export default {
this.performance = ""; this.performance = "";
}, },
eventcallbacK: function (type, message) {
// console.log("player ")
// console.log(type)
// console.log(message)
},
fullscreenSwich: function () { fullscreenSwich: function () {
let isFull = this.isFullscreen() let isFull = this.isFullscreen()
jessibucaPlayer[this._uid].setFullscreen(!isFull) jessibucaPlayer[this._uid].setFullscreen(!isFull)

View File

@ -1,7 +1,7 @@
<template> <template>
<div id="devicePlayer" v-loading="isLoging"> <div id="devicePlayer" v-loading="isLoging">
<el-dialog title="视频播放" top="0" :close-on-click-modal="false" :visible.sync="showVideoDialog" @close="close()"> <el-dialog title="视频播放" top="0" :close-on-click-modal="false" :visible.sync="showVideoDialog" @close="close()" v-if="showVideoDialog">
<div style="width: 100%; height: 100%"> <div style="width: 100%; height: 100%">
<el-tabs type="card" :stretch="true" v-model="activePlayer" @tab-click="changePlayer" v-if="Object.keys(this.player).length > 1"> <el-tabs type="card" :stretch="true" v-model="activePlayer" @tab-click="changePlayer" v-if="Object.keys(this.player).length > 1">
<!-- <el-tab-pane label="LivePlayer" name="livePlayer">--> <!-- <el-tab-pane label="LivePlayer" name="livePlayer">-->

View File

@ -37,7 +37,6 @@
</template> </template>
<script> <script>
import changePasswordDialog from '../components/dialog/changePassword.vue' import changePasswordDialog from '../components/dialog/changePassword.vue'
import userService from '../components/service/UserService' import userService from '../components/service/UserService'
import {Notification} from 'element-ui'; import {Notification} from 'element-ui';
@ -55,18 +54,19 @@ export default {
}; };
}, },
created() { created() {
console.log(4444)
console.log(JSON.stringify(userService.getUser())) console.log(JSON.stringify(userService.getUser()))
if (this.$route.path.startsWith("/channelList")) { if (this.$route.path.startsWith("/channelList")) {
this.activeIndex = "/deviceList" this.activeIndex = "/deviceList"
} }
}, },
mounted() { mounted() {
window.addEventListener('beforeunload', e => this.beforeunloadHandler(e)) window.addEventListener('beforeunload', e => this.beforeunloadHandler(e))
// window.addEventListener('unload', e => this.unloadHandler(e))
this.alarmNotify = this.getAlarmSwitchStatus() === "true"; this.alarmNotify = this.getAlarmSwitchStatus() === "true";
this.sseControl();
// TODO: sse, sse browserId ,
setTimeout(() => {
this.sseControl()
}, 3000);
}, },
methods: { methods: {
loginout() { loginout() {
@ -107,10 +107,12 @@ export default {
this.sseSource = new EventSource('/api/emit?browserId=' + this.$browserId); this.sseSource = new EventSource('/api/emit?browserId=' + this.$browserId);
this.sseSource.addEventListener('message', function (evt) { this.sseSource.addEventListener('message', function (evt) {
that.$notify({ that.$notify({
title: '收到报警信息', title: '报警信息',
dangerouslyUseHTMLString: true, dangerouslyUseHTMLString: true,
message: evt.data, message: evt.data,
type: 'warning' type: 'warning',
position: 'bottom-right',
duration: 3000
}); });
console.log("收到信息:" + evt.data); console.log("收到信息:" + evt.data);
}); });

View File

@ -1,22 +1,20 @@
import Vue from 'vue'; import Vue from 'vue';
import App from './App.vue'; import App from './App.vue';
import ElementUI, {Notification} from 'element-ui';
Vue.config.productionTip = false;
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css'; import 'element-ui/lib/theme-chalk/index.css';
import router from './router/index.js'; import router from './router/index.js';
import axios from 'axios'; import axios from 'axios';
import VueCookies from 'vue-cookies'; import VueCookies from 'vue-cookies';
import echarts from 'echarts';
import VCharts from 'v-charts'; import VCharts from 'v-charts';
import VueClipboard from 'vue-clipboard2'; import VueClipboard from 'vue-clipboard2';
import {Notification} from 'element-ui';
import Fingerprint2 from 'fingerprintjs2'; import Fingerprint2 from 'fingerprintjs2';
import VueClipboards from 'vue-clipboards'; import VueClipboards from 'vue-clipboards';
import Contextmenu from "vue-contextmenujs" import Contextmenu from "vue-contextmenujs"
import userService from "./components/service/UserService" import userService from "./components/service/UserService"
Vue.config.productionTip = false;
// 生成唯一ID // 生成唯一ID
Fingerprint2.get(function (components) { Fingerprint2.get(function (components) {
@ -29,10 +27,9 @@ Fingerprint2.get(function (components) {
//console.log(values) //使用的浏览器信息npm //console.log(values) //使用的浏览器信息npm
// 生成最终id // 生成最终id
let port = window.location.port; let port = window.location.port;
console.log(port);
const fingerPrint = Fingerprint2.x64hash128(values.join(port), 31) const fingerPrint = Fingerprint2.x64hash128(values.join(port), 31)
Vue.prototype.$browserId = fingerPrint; Vue.prototype.$browserId = fingerPrint;
console.log("唯一标识码:" + fingerPrint); console.log("浏览器 ID: " + fingerPrint);
}); });
Vue.use(VueClipboard); Vue.use(VueClipboard);
@ -75,7 +72,7 @@ axios.interceptors.request.use(
); );
Vue.prototype.$axios = axios; Vue.prototype.$axios = axios;
Vue.prototype.$cookies.config(60*30); Vue.prototype.$cookies.config(60 * 30);
new Vue({ new Vue({
router: router, router: router,

View File

@ -561,9 +561,9 @@ declare class Jessibuca {
buf: number; buf: number;
/** 当前视频帧率 */ /** 当前视频帧率 */
fps: number; fps: number;
/** 当前音频码率单位bit */ /** 当前音频码率单位byte */
abps: number; abps: number;
/** 当前视频码率单位bit */ /** 当前视频码率单位byte */
vbps: number; vbps: number;
/** 当前视频帧pts单位毫秒 */ /** 当前视频帧pts单位毫秒 */
ts: number; ts: number;

File diff suppressed because one or more lines are too long