pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V1/parse/global/GlCreate.java
@@ -52,6 +52,17 @@ bsNoTail[ProtocolConstantV206V1.dataLenIndex] = (byte)len ; } public static void createLen4PUg(byte[] bytes) throws Exception { int len = bytes.length - 4; byte[] bs = ByteUtil.int2BCD_LE(len) ; if(bs != null && bs.length == 1){ bytes[1] = bs[0] ; }else if(bs != null && bs.length > 1){ bytes[1] = bs[0] ; bytes[2] = bs[1] ; } } /** * 生成IC卡编码 pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/.gitattributes
New file @@ -0,0 +1,2 @@ /mvnw text eol=lf *.cmd text eol=crlf pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/.gitignore
New file @@ -0,0 +1,34 @@ HELP.md target/ /pipIrr-mw-simulate-rtu.iml !.mvn/wrapper/maven-wrapper.jar !**/src/main/**/target/ !**/src/test/**/target/ ### STS ### .apt_generated .classpath .factorypath .project .settings .springBeans .sts4-cache ### IntelliJ IDEA ### .idea *.iws *.iml *.ipr ### NetBeans ### /nbproject/private/ /nbbuild/ /dist/ /nbdist/ /.nb-gradle/ build/ !**/src/main/**/build/ !**/src/test/**/build/ ### VS Code ### .vscode/ pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/.mvn/wrapper/maven-wrapper.properties
New file @@ -0,0 +1,19 @@ # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. wrapperVersion=3.3.2 distributionType=only-script distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.9/apache-maven-3.9.9-bin.zip pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/mvnw
New file @@ -0,0 +1,259 @@ #!/bin/sh # ---------------------------------------------------------------------------- # Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you under the Apache License, Version 2.0 (the # "License"); you may not use this file except in compliance # with the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, # software distributed under the License is distributed on an # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY # KIND, either express or implied. See the License for the # specific language governing permissions and limitations # under the License. # ---------------------------------------------------------------------------- # ---------------------------------------------------------------------------- # Apache Maven Wrapper startup batch script, version 3.3.2 # # Optional ENV vars # ----------------- # JAVA_HOME - location of a JDK home dir, required when download maven via java source # MVNW_REPOURL - repo url base for downloading maven distribution # MVNW_USERNAME/MVNW_PASSWORD - user and password for downloading maven # MVNW_VERBOSE - true: enable verbose log; debug: trace the mvnw script; others: silence the output # ---------------------------------------------------------------------------- set -euf [ "${MVNW_VERBOSE-}" != debug ] || set -x # OS specific support. native_path() { printf %s\\n "$1"; } case "$(uname)" in CYGWIN* | MINGW*) [ -z "${JAVA_HOME-}" ] || JAVA_HOME="$(cygpath --unix "$JAVA_HOME")" native_path() { cygpath --path --windows "$1"; } ;; esac # set JAVACMD and JAVACCMD set_java_home() { # For Cygwin and MinGW, ensure paths are in Unix format before anything is touched if [ -n "${JAVA_HOME-}" ]; then if [ -x "$JAVA_HOME/jre/sh/java" ]; then # IBM's JDK on AIX uses strange locations for the executables JAVACMD="$JAVA_HOME/jre/sh/java" JAVACCMD="$JAVA_HOME/jre/sh/javac" else JAVACMD="$JAVA_HOME/bin/java" JAVACCMD="$JAVA_HOME/bin/javac" if [ ! -x "$JAVACMD" ] || [ ! -x "$JAVACCMD" ]; then echo "The JAVA_HOME environment variable is not defined correctly, so mvnw cannot run." >&2 echo "JAVA_HOME is set to \"$JAVA_HOME\", but \"\$JAVA_HOME/bin/java\" or \"\$JAVA_HOME/bin/javac\" does not exist." >&2 return 1 fi fi else JAVACMD="$( 'set' +e 'unset' -f command 2>/dev/null 'command' -v java )" || : JAVACCMD="$( 'set' +e 'unset' -f command 2>/dev/null 'command' -v javac )" || : if [ ! -x "${JAVACMD-}" ] || [ ! -x "${JAVACCMD-}" ]; then echo "The java/javac command does not exist in PATH nor is JAVA_HOME set, so mvnw cannot run." >&2 return 1 fi fi } # hash string like Java String::hashCode hash_string() { str="${1:-}" h=0 while [ -n "$str" ]; do char="${str%"${str#?}"}" h=$(((h * 31 + $(LC_CTYPE=C printf %d "'$char")) % 4294967296)) str="${str#?}" done printf %x\\n $h } verbose() { :; } [ "${MVNW_VERBOSE-}" != true ] || verbose() { printf %s\\n "${1-}"; } die() { printf %s\\n "$1" >&2 exit 1 } trim() { # MWRAPPER-139: # Trims trailing and leading whitespace, carriage returns, tabs, and linefeeds. # Needed for removing poorly interpreted newline sequences when running in more # exotic environments such as mingw bash on Windows. printf "%s" "${1}" | tr -d '[:space:]' } # parse distributionUrl and optional distributionSha256Sum, requires .mvn/wrapper/maven-wrapper.properties while IFS="=" read -r key value; do case "${key-}" in distributionUrl) distributionUrl=$(trim "${value-}") ;; distributionSha256Sum) distributionSha256Sum=$(trim "${value-}") ;; esac done <"${0%/*}/.mvn/wrapper/maven-wrapper.properties" [ -n "${distributionUrl-}" ] || die "cannot read distributionUrl property in ${0%/*}/.mvn/wrapper/maven-wrapper.properties" case "${distributionUrl##*/}" in maven-mvnd-*bin.*) MVN_CMD=mvnd.sh _MVNW_REPO_PATTERN=/maven/mvnd/ case "${PROCESSOR_ARCHITECTURE-}${PROCESSOR_ARCHITEW6432-}:$(uname -a)" in *AMD64:CYGWIN* | *AMD64:MINGW*) distributionPlatform=windows-amd64 ;; :Darwin*x86_64) distributionPlatform=darwin-amd64 ;; :Darwin*arm64) distributionPlatform=darwin-aarch64 ;; :Linux*x86_64*) distributionPlatform=linux-amd64 ;; *) echo "Cannot detect native platform for mvnd on $(uname)-$(uname -m), use pure java version" >&2 distributionPlatform=linux-amd64 ;; esac distributionUrl="${distributionUrl%-bin.*}-$distributionPlatform.zip" ;; maven-mvnd-*) MVN_CMD=mvnd.sh _MVNW_REPO_PATTERN=/maven/mvnd/ ;; *) MVN_CMD="mvn${0##*/mvnw}" _MVNW_REPO_PATTERN=/org/apache/maven/ ;; esac # apply MVNW_REPOURL and calculate MAVEN_HOME # maven home pattern: ~/.m2/wrapper/dists/{apache-maven-<version>,maven-mvnd-<version>-<platform>}/<hash> [ -z "${MVNW_REPOURL-}" ] || distributionUrl="$MVNW_REPOURL$_MVNW_REPO_PATTERN${distributionUrl#*"$_MVNW_REPO_PATTERN"}" distributionUrlName="${distributionUrl##*/}" distributionUrlNameMain="${distributionUrlName%.*}" distributionUrlNameMain="${distributionUrlNameMain%-bin}" MAVEN_USER_HOME="${MAVEN_USER_HOME:-${HOME}/.m2}" MAVEN_HOME="${MAVEN_USER_HOME}/wrapper/dists/${distributionUrlNameMain-}/$(hash_string "$distributionUrl")" exec_maven() { unset MVNW_VERBOSE MVNW_USERNAME MVNW_PASSWORD MVNW_REPOURL || : exec "$MAVEN_HOME/bin/$MVN_CMD" "$@" || die "cannot exec $MAVEN_HOME/bin/$MVN_CMD" } if [ -d "$MAVEN_HOME" ]; then verbose "found existing MAVEN_HOME at $MAVEN_HOME" exec_maven "$@" fi case "${distributionUrl-}" in *?-bin.zip | *?maven-mvnd-?*-?*.zip) ;; *) die "distributionUrl is not valid, must match *-bin.zip or maven-mvnd-*.zip, but found '${distributionUrl-}'" ;; esac # prepare tmp dir if TMP_DOWNLOAD_DIR="$(mktemp -d)" && [ -d "$TMP_DOWNLOAD_DIR" ]; then clean() { rm -rf -- "$TMP_DOWNLOAD_DIR"; } trap clean HUP INT TERM EXIT else die "cannot create temp dir" fi mkdir -p -- "${MAVEN_HOME%/*}" # Download and Install Apache Maven verbose "Couldn't find MAVEN_HOME, downloading and installing it ..." verbose "Downloading from: $distributionUrl" verbose "Downloading to: $TMP_DOWNLOAD_DIR/$distributionUrlName" # select .zip or .tar.gz if ! command -v unzip >/dev/null; then distributionUrl="${distributionUrl%.zip}.tar.gz" distributionUrlName="${distributionUrl##*/}" fi # verbose opt __MVNW_QUIET_WGET=--quiet __MVNW_QUIET_CURL=--silent __MVNW_QUIET_UNZIP=-q __MVNW_QUIET_TAR='' [ "${MVNW_VERBOSE-}" != true ] || __MVNW_QUIET_WGET='' __MVNW_QUIET_CURL='' __MVNW_QUIET_UNZIP='' __MVNW_QUIET_TAR=v # normalize http auth case "${MVNW_PASSWORD:+has-password}" in '') MVNW_USERNAME='' MVNW_PASSWORD='' ;; has-password) [ -n "${MVNW_USERNAME-}" ] || MVNW_USERNAME='' MVNW_PASSWORD='' ;; esac if [ -z "${MVNW_USERNAME-}" ] && command -v wget >/dev/null; then verbose "Found wget ... using wget" wget ${__MVNW_QUIET_WGET:+"$__MVNW_QUIET_WGET"} "$distributionUrl" -O "$TMP_DOWNLOAD_DIR/$distributionUrlName" || die "wget: Failed to fetch $distributionUrl" elif [ -z "${MVNW_USERNAME-}" ] && command -v curl >/dev/null; then verbose "Found curl ... using curl" curl ${__MVNW_QUIET_CURL:+"$__MVNW_QUIET_CURL"} -f -L -o "$TMP_DOWNLOAD_DIR/$distributionUrlName" "$distributionUrl" || die "curl: Failed to fetch $distributionUrl" elif set_java_home; then verbose "Falling back to use Java to download" javaSource="$TMP_DOWNLOAD_DIR/Downloader.java" targetZip="$TMP_DOWNLOAD_DIR/$distributionUrlName" cat >"$javaSource" <<-END public class Downloader extends java.net.Authenticator { protected java.net.PasswordAuthentication getPasswordAuthentication() { return new java.net.PasswordAuthentication( System.getenv( "MVNW_USERNAME" ), System.getenv( "MVNW_PASSWORD" ).toCharArray() ); } public static void main( String[] args ) throws Exception { setDefault( new Downloader() ); java.nio.file.Files.copy( java.net.URI.create( args[0] ).toURL().openStream(), java.nio.file.Paths.get( args[1] ).toAbsolutePath().normalize() ); } } END # For Cygwin/MinGW, switch paths to Windows format before running javac and java verbose " - Compiling Downloader.java ..." "$(native_path "$JAVACCMD")" "$(native_path "$javaSource")" || die "Failed to compile Downloader.java" verbose " - Running Downloader.java ..." "$(native_path "$JAVACMD")" -cp "$(native_path "$TMP_DOWNLOAD_DIR")" Downloader "$distributionUrl" "$(native_path "$targetZip")" fi # If specified, validate the SHA-256 sum of the Maven distribution zip file if [ -n "${distributionSha256Sum-}" ]; then distributionSha256Result=false if [ "$MVN_CMD" = mvnd.sh ]; then echo "Checksum validation is not supported for maven-mvnd." >&2 echo "Please disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." >&2 exit 1 elif command -v sha256sum >/dev/null; then if echo "$distributionSha256Sum $TMP_DOWNLOAD_DIR/$distributionUrlName" | sha256sum -c >/dev/null 2>&1; then distributionSha256Result=true fi elif command -v shasum >/dev/null; then if echo "$distributionSha256Sum $TMP_DOWNLOAD_DIR/$distributionUrlName" | shasum -a 256 -c >/dev/null 2>&1; then distributionSha256Result=true fi else echo "Checksum validation was requested but neither 'sha256sum' or 'shasum' are available." >&2 echo "Please install either command, or disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." >&2 exit 1 fi if [ $distributionSha256Result = false ]; then echo "Error: Failed to validate Maven distribution SHA-256, your Maven distribution might be compromised." >&2 echo "If you updated your Maven version, you need to update the specified distributionSha256Sum property." >&2 exit 1 fi fi # unzip and move if command -v unzip >/dev/null; then unzip ${__MVNW_QUIET_UNZIP:+"$__MVNW_QUIET_UNZIP"} "$TMP_DOWNLOAD_DIR/$distributionUrlName" -d "$TMP_DOWNLOAD_DIR" || die "failed to unzip" else tar xzf${__MVNW_QUIET_TAR:+"$__MVNW_QUIET_TAR"} "$TMP_DOWNLOAD_DIR/$distributionUrlName" -C "$TMP_DOWNLOAD_DIR" || die "failed to untar" fi printf %s\\n "$distributionUrl" >"$TMP_DOWNLOAD_DIR/$distributionUrlNameMain/mvnw.url" mv -- "$TMP_DOWNLOAD_DIR/$distributionUrlNameMain" "$MAVEN_HOME" || [ -d "$MAVEN_HOME" ] || die "fail to move MAVEN_HOME" clean || : exec_maven "$@" pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/mvnw.cmd
New file @@ -0,0 +1,149 @@ <# : batch portion @REM ---------------------------------------------------------------------------- @REM Licensed to the Apache Software Foundation (ASF) under one @REM or more contributor license agreements. See the NOTICE file @REM distributed with this work for additional information @REM regarding copyright ownership. The ASF licenses this file @REM to you under the Apache License, Version 2.0 (the @REM "License"); you may not use this file except in compliance @REM with the License. You may obtain a copy of the License at @REM @REM http://www.apache.org/licenses/LICENSE-2.0 @REM @REM Unless required by applicable law or agreed to in writing, @REM software distributed under the License is distributed on an @REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY @REM KIND, either express or implied. See the License for the @REM specific language governing permissions and limitations @REM under the License. @REM ---------------------------------------------------------------------------- @REM ---------------------------------------------------------------------------- @REM Apache Maven Wrapper startup batch script, version 3.3.2 @REM @REM Optional ENV vars @REM MVNW_REPOURL - repo url base for downloading maven distribution @REM MVNW_USERNAME/MVNW_PASSWORD - user and password for downloading maven @REM MVNW_VERBOSE - true: enable verbose log; others: silence the output @REM ---------------------------------------------------------------------------- @IF "%__MVNW_ARG0_NAME__%"=="" (SET __MVNW_ARG0_NAME__=%~nx0) @SET __MVNW_CMD__= @SET __MVNW_ERROR__= @SET __MVNW_PSMODULEP_SAVE=%PSModulePath% @SET PSModulePath= @FOR /F "usebackq tokens=1* delims==" %%A IN (`powershell -noprofile "& {$scriptDir='%~dp0'; $script='%__MVNW_ARG0_NAME__%'; icm -ScriptBlock ([Scriptblock]::Create((Get-Content -Raw '%~f0'))) -NoNewScope}"`) DO @( IF "%%A"=="MVN_CMD" (set __MVNW_CMD__=%%B) ELSE IF "%%B"=="" (echo %%A) ELSE (echo %%A=%%B) ) @SET PSModulePath=%__MVNW_PSMODULEP_SAVE% @SET __MVNW_PSMODULEP_SAVE= @SET __MVNW_ARG0_NAME__= @SET MVNW_USERNAME= @SET MVNW_PASSWORD= @IF NOT "%__MVNW_CMD__%"=="" (%__MVNW_CMD__% %*) @echo Cannot start maven from wrapper >&2 && exit /b 1 @GOTO :EOF : end batch / begin powershell #> $ErrorActionPreference = "Stop" if ($env:MVNW_VERBOSE -eq "true") { $VerbosePreference = "Continue" } # calculate distributionUrl, requires .mvn/wrapper/maven-wrapper.properties $distributionUrl = (Get-Content -Raw "$scriptDir/.mvn/wrapper/maven-wrapper.properties" | ConvertFrom-StringData).distributionUrl if (!$distributionUrl) { Write-Error "cannot read distributionUrl property in $scriptDir/.mvn/wrapper/maven-wrapper.properties" } switch -wildcard -casesensitive ( $($distributionUrl -replace '^.*/','') ) { "maven-mvnd-*" { $USE_MVND = $true $distributionUrl = $distributionUrl -replace '-bin\.[^.]*$',"-windows-amd64.zip" $MVN_CMD = "mvnd.cmd" break } default { $USE_MVND = $false $MVN_CMD = $script -replace '^mvnw','mvn' break } } # apply MVNW_REPOURL and calculate MAVEN_HOME # maven home pattern: ~/.m2/wrapper/dists/{apache-maven-<version>,maven-mvnd-<version>-<platform>}/<hash> if ($env:MVNW_REPOURL) { $MVNW_REPO_PATTERN = if ($USE_MVND) { "/org/apache/maven/" } else { "/maven/mvnd/" } $distributionUrl = "$env:MVNW_REPOURL$MVNW_REPO_PATTERN$($distributionUrl -replace '^.*'+$MVNW_REPO_PATTERN,'')" } $distributionUrlName = $distributionUrl -replace '^.*/','' $distributionUrlNameMain = $distributionUrlName -replace '\.[^.]*$','' -replace '-bin$','' $MAVEN_HOME_PARENT = "$HOME/.m2/wrapper/dists/$distributionUrlNameMain" if ($env:MAVEN_USER_HOME) { $MAVEN_HOME_PARENT = "$env:MAVEN_USER_HOME/wrapper/dists/$distributionUrlNameMain" } $MAVEN_HOME_NAME = ([System.Security.Cryptography.MD5]::Create().ComputeHash([byte[]][char[]]$distributionUrl) | ForEach-Object {$_.ToString("x2")}) -join '' $MAVEN_HOME = "$MAVEN_HOME_PARENT/$MAVEN_HOME_NAME" if (Test-Path -Path "$MAVEN_HOME" -PathType Container) { Write-Verbose "found existing MAVEN_HOME at $MAVEN_HOME" Write-Output "MVN_CMD=$MAVEN_HOME/bin/$MVN_CMD" exit $? } if (! $distributionUrlNameMain -or ($distributionUrlName -eq $distributionUrlNameMain)) { Write-Error "distributionUrl is not valid, must end with *-bin.zip, but found $distributionUrl" } # prepare tmp dir $TMP_DOWNLOAD_DIR_HOLDER = New-TemporaryFile $TMP_DOWNLOAD_DIR = New-Item -Itemtype Directory -Path "$TMP_DOWNLOAD_DIR_HOLDER.dir" $TMP_DOWNLOAD_DIR_HOLDER.Delete() | Out-Null trap { if ($TMP_DOWNLOAD_DIR.Exists) { try { Remove-Item $TMP_DOWNLOAD_DIR -Recurse -Force | Out-Null } catch { Write-Warning "Cannot remove $TMP_DOWNLOAD_DIR" } } } New-Item -Itemtype Directory -Path "$MAVEN_HOME_PARENT" -Force | Out-Null # Download and Install Apache Maven Write-Verbose "Couldn't find MAVEN_HOME, downloading and installing it ..." Write-Verbose "Downloading from: $distributionUrl" Write-Verbose "Downloading to: $TMP_DOWNLOAD_DIR/$distributionUrlName" $webclient = New-Object System.Net.WebClient if ($env:MVNW_USERNAME -and $env:MVNW_PASSWORD) { $webclient.Credentials = New-Object System.Net.NetworkCredential($env:MVNW_USERNAME, $env:MVNW_PASSWORD) } [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 $webclient.DownloadFile($distributionUrl, "$TMP_DOWNLOAD_DIR/$distributionUrlName") | Out-Null # If specified, validate the SHA-256 sum of the Maven distribution zip file $distributionSha256Sum = (Get-Content -Raw "$scriptDir/.mvn/wrapper/maven-wrapper.properties" | ConvertFrom-StringData).distributionSha256Sum if ($distributionSha256Sum) { if ($USE_MVND) { Write-Error "Checksum validation is not supported for maven-mvnd. `nPlease disable validation by removing 'distributionSha256Sum' from your maven-wrapper.properties." } Import-Module $PSHOME\Modules\Microsoft.PowerShell.Utility -Function Get-FileHash if ((Get-FileHash "$TMP_DOWNLOAD_DIR/$distributionUrlName" -Algorithm SHA256).Hash.ToLower() -ne $distributionSha256Sum) { Write-Error "Error: Failed to validate Maven distribution SHA-256, your Maven distribution might be compromised. If you updated your Maven version, you need to update the specified distributionSha256Sum property." } } # unzip and move Expand-Archive "$TMP_DOWNLOAD_DIR/$distributionUrlName" -DestinationPath "$TMP_DOWNLOAD_DIR" | Out-Null Rename-Item -Path "$TMP_DOWNLOAD_DIR/$distributionUrlNameMain" -NewName $MAVEN_HOME_NAME | Out-Null try { Move-Item -Path "$TMP_DOWNLOAD_DIR/$MAVEN_HOME_NAME" -Destination $MAVEN_HOME_PARENT | Out-Null } catch { if (! (Test-Path -Path "$MAVEN_HOME" -PathType Container)) { Write-Error "fail to move MAVEN_HOME" } } finally { try { Remove-Item $TMP_DOWNLOAD_DIR -Recurse -Force | Out-Null } catch { Write-Warning "Cannot remove $TMP_DOWNLOAD_DIR" } } Write-Output "MVN_CMD=$MAVEN_HOME/bin/$MVN_CMD" pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/pom.xml
New file @@ -0,0 +1,183 @@ <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <artifactId>pipIrr-mw</artifactId> <groupId>com.dy</groupId> <version>1.0.0</version> <relativePath>../pom.xml</relativePath> </parent> <groupId>com.dy</groupId> <artifactId>pipIrr-mw-simulate-rtu</artifactId> <version>1.0.0</version> <name>pipIrr-mw-simulate-rtu</name> <description>RTU模拟器,模拟RTU软件远程升级等</description> <url/> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-json</artifactId> </exclusion> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-logging</artifactId> </exclusion> </exclusions> </dependency> <!-- 动态加载新编译的类 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> </dependency> <!-- apache mina --> <dependency> <groupId>org.apache.mina</groupId> <artifactId>mina-core</artifactId> <version>2.2.2</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>2.0.7</version> </dependency> <!-- 测试 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <!-- 生成不包含依赖jar的可执行jar包 <plugin> !- spring boot提供的maven打包插件 - <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <executions> <execution> !- <goals> <goal>repackage</goal> </goals> - <configuration> !- 不加的话最终包名为: ${artifactId}-${version}.jar, 加了的话最终包名: ${artifactId}-${version}-${classifier}.jar - <classifier>execute</classifier> !- 不指定生成路径的话, 默认保存在 ${build.directory} 下 - <outputDirectory>${project.build.directory}/execute</outputDirectory> <finalName>${artifactId}-${version}</finalName> <layout>ZIP</layout> <mainClass>com.dy.pipIrrBase.PipIrrBaseApplication</mainClass> <includes> <include> <groupId>com.dy</groupId> <artifactId>pipIrr-common</artifactId> </include> <include> <groupId>com.dy</groupId> <artifactId>pipIrr-global</artifactId> </include> </includes> <excludes> <exclude> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </exclude> </excludes> </configuration> </execution> </executions> </plugin> --> <!-- 拷贝依赖的jar包到lib目录--> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <executions> <execution> <configuration> <!-- 不加的话最终包名为: ${artifactId}-${version}.jar, 加了的话最终包名: ${artifactId}-${version}-${classifier}.jar <classifier>execute</classifier> --> <!-- ${project.build.directory}是maven变量,内置的,表示target目录,如果不写,将在根目录下创建/lib --> <outputDirectory>${project.build.directory}/lib</outputDirectory> <!-- excludeTransitive:是否不包含间接依赖包,比如我们依赖A,但是A又依赖了B,我们是否也要把B打进去 默认不打--> <excludeTransitive>false</excludeTransitive> <!-- 复制的jar文件去掉版本信息 --> <stripVersion>false</stripVersion> <finalName>${project.artifactId}-${project.version}</finalName> <layout>ZIP</layout> <mainClass>com.dy.rtuMw.PipIrrMwAcceptApplication</mainClass> <includes> <include> <groupId>com.dy</groupId> <artifactId>pipIrr-common</artifactId> </include> <include> <groupId>com.dy</groupId> <artifactId>pipIrr-global</artifactId> </include> </includes> <excludes> <exclude> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </exclude> </excludes> </configuration> </execution> </executions> </plugin> <plugin> <!-- 设置java编译版本,运行环境版本 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <!-- source: 源代码编译版本;target: 目标平台编译版本;encoding: 字符集编码。 --> <configuration> <source>${java.version}</source> <target>${java.version}</target> <encoding>${encoding}</encoding> </configuration> </plugin> <plugin> <!-- 解决资源文件的编码问题 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-resources-plugin</artifactId> <configuration> <encoding>${encoding}</encoding> </configuration> </plugin> <plugin> <!-- maven里执行测试用例的插件 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-surefire-plugin</artifactId> <configuration> <skipTests>true</skipTests> </configuration> </plugin> <plugin> <!-- 下面解决:当进行Maven Lifecycle package时报错:Could not find artifact org.apache.mina:mina-core:bundle:2.2.1 in maven (https://repo1.maven.org/maven2/)--> <groupId>org.apache.felix</groupId> <artifactId>maven-bundle-plugin</artifactId> <extensions>true</extensions> </plugin> </plugins> </build> </project> pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/AdapterImp_TcpClUnit.java
New file @@ -0,0 +1,19 @@ package com.dy.simRtu; import com.dy.simRtu.tcpClient.TcpClUnitAdapter; import com.dy.simRtu.tcpClient.TcpClUnitConfigVo; public class AdapterImp_TcpClUnit implements TcpClUnitAdapter { private TcpClUnitConfigVo configVo ; public TcpClUnitConfigVo getConfig() { return configVo; } public void setConfig(TcpClUnitConfigVo configVo){ this.configVo = configVo ; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/PipIrrMwSimulateRtuApplication.java
New file @@ -0,0 +1,68 @@ package com.dy.simRtu; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.CommandLineRunner; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.FilterType; @SpringBootApplication(exclude = {DataSourceAutoConfiguration.class}) //禁止启动数据库连接池 @ComponentScan(basePackages = {"com.dy.common", "com.dy.pipIrrGlobal", "com.dy.simRtu"}, excludeFilters = { @ComponentScan.Filter(type = FilterType.ASSIGNABLE_TYPE, classes = { com.dy.common.apiDoc.SpringApiConfig.class //一种排除类的方式 }), @ComponentScan.Filter(type = FilterType.REGEX, pattern = { //二种排除类的方式,写正则表达式,需要对目标类的完全限定名完全匹配,否则不生效 "com.dy.common.aop..*", "com.dy.common.apiDoc..*", "com.dy.common.multiDataSource..*", "com.dy.common.mybatis..*", "com.dy.common.singleDataSource..*", "com.dy.common.webFilter..*", "com.dy.common.webListener..*", "com.dy.pipIrrGlobal.webCtrls..*" }) } ) public class PipIrrMwSimulateRtuApplication implements CommandLineRunner { public static void main(String[] args) { SpringApplication.run(PipIrrMwSimulateRtuApplication.class, args); } /** * Spring容器启动完成后,执行下面方法 * @param args 参数 * @throws Exception 异常 */ @Override public void run(String... args) throws Exception { try{ //等待一下 Thread.sleep(500L); }catch (Exception e){ e.printStackTrace(); } finally { this.startMwSv() ; } } private void startMwSv(){ if(sv != null){ sv.startServer(); } } private Server sv ; @Autowired public void setSv(Server sv){ this.sv = sv ; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/Server.java
New file @@ -0,0 +1,111 @@ package com.dy.simRtu; import com.dy.common.mw.UnitInterface; import com.dy.common.util.ConfigXml4Springboot; import com.dy.simRtu.tcpClient.TcpClUnit; import com.dy.simRtu.tcpClient.TcpClUnitConfigVo; import org.jdom2.Document; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.core.io.ResourceLoader; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.List; /** * @Author: liurunyu * @Date: 2024/11/18 9:54 * @Description */ @Component public class Server { @Autowired protected ResourceLoader resourceLoader ; private ConfigXml4Springboot conf = null ; private Document doc = null ; private boolean showStartInfo = false ; private String mwServerUrl ; private List<UnitInterface> units = new ArrayList<UnitInterface>() ; /** * 启动服务 */ public void startServer() { long start = System.currentTimeMillis(); try { this.conf = new ConfigXml4Springboot() ; this.doc = this.conf.createDom(resourceLoader, "config.xml") ; //////////////// //服务 配置 this.showStartInfo = this.conf.getSetAttrBoolean(this.doc, "config.server", "showStartInfo", null, null) ; this.startUnits() ; String svName ; try{ svName = this.conf.getSetAttrTxt(this.doc, "config.server", "name", null, false, null) ; }catch(Exception e){ svName = "" ; } String company ; try{ company = this.conf.getSetAttrTxt(this.doc, "config.server", "company", null, true, null) ; }catch(Exception e){ company = "" ; } System.out.println("OOOOOOOOOO OOOOOOOO OOOOOOOO") ; System.out.println("@@@@@@@@@@@@@@@@#O $@@@@@@@@& @@@@@@@@#") ; System.out.println("@@@@@@@@@@@@@@@@@@@# @@@@@@@@# $@@@@@@@@&") ; System.out.println("@@@@@@@@@@@@@@@@@@@@@# #@@@@@@@@@@@@@@@@O") ; System.out.println("@@@@@@@@@@@@@@@@@@@@@@@ &@@@@@@@@@@@@@@") ; System.out.println("@@@@@@$ $@@@@@@@@@& O@@@@@@@@@@@#") ; System.out.println("@@@@@@$ @@@@@@@@@ @@@@@@@@@& " + svName ) ; System.out.println("@@@@@@$ O@@@@@@@@@ &@@@@@@@@") ; if(this.mwServerUrl != null){ System.out.println("@@@@@@$ O@@@@@@@@@ &@@@@@@@@ 远程中间件服务 " + this.mwServerUrl ) ; }else{ System.out.println("@@@@@@$ O@@@@@@@@@ &@@@@@@@@") ; } System.out.println("@@@@@@$ #@@@@@@@@@$ &@@@@@@@@") ; System.out.println("@@@@@@@@@@@@@@@@@@@@@@# &@@@@@@@@ Runing in standalone mode" ) ; System.out.println("@@@@@@@@@@@@@@@@@@@@@& &@@@@@@@@ Startup in " + (System.currentTimeMillis() - start) + " MS" ) ; System.out.println("@@@@@@@@@@@@@@@@@@@# &@@@@@@@@ " + company) ; System.out.println("@@@@@@@@@@@@@@@@#O &@@@@@@@@") ; }catch(Exception e){ e.printStackTrace(); } } private void startUnits() { try { // /////////////// // 基础配置 ServerProperties.rtuAddr = conf.getSetAttrTxt(doc, "config.base", "rtuAddr", null, false, null); // /////////////// // TCP 模块 TcpClUnitConfigVo tcpVo = new TcpClUnitConfigVo(); tcpVo.mwServerIp = conf.getSetAttrTxt(doc, "config.tcpCl", "mwServerIp", null, false, null); tcpVo.mwServerPort = conf.getSetAttrPlusInt(doc, "config.tcpCl", "mwServerPort", null, 100, 65535, null); tcpVo.connectTimeout = conf.getSetAttrPlusInt(doc, "config.tcpCl", "connectTimeout", null, 1000, 10000, null); this.mwServerUrl = tcpVo.mwServerIp + ":" + tcpVo.mwServerPort ; AdapterImp_TcpClUnit tcpAdap = new AdapterImp_TcpClUnit(); tcpAdap.setConfig(tcpVo); TcpClUnit tcpUnit = TcpClUnit.getInstance(); tcpUnit.setAdapter(tcpAdap); tcpUnit.start(obj -> { }); units.add(tcpUnit) ; }catch (Exception e){ e.printStackTrace(); } } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/ServerProperties.java
New file @@ -0,0 +1,12 @@ package com.dy.simRtu; /** * @Author: liurunyu * @Date: 2024/11/18 9:53 * @Description */ public class ServerProperties { public static String rtuAddr ; } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/LocalCodecFactory.java
New file @@ -0,0 +1,35 @@ package com.dy.simRtu.tcpClient; import org.apache.mina.core.session.IoSession; import org.apache.mina.filter.codec.ProtocolCodecFactory; import org.apache.mina.filter.codec.ProtocolDecoder; import org.apache.mina.filter.codec.ProtocolEncoder; public class LocalCodecFactory implements ProtocolCodecFactory { private ProtocolEncoder encoder; private ProtocolDecoder decoder; public LocalCodecFactory() { encoder = new LocalEncoder(); decoder = new LocalDecoder(); } /** * 得到协议编码器 * @param ioSession 网络会话 * @return 协议编码器 */ @Override public ProtocolEncoder getEncoder(IoSession ioSession) { return encoder; } /** * 得到协议解码器 * @param ioSession 网络会话 * @return 协议解码器 */ @Override public ProtocolDecoder getDecoder(IoSession ioSession) { return decoder; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/LocalDecoder.java
New file @@ -0,0 +1,39 @@ package com.dy.simRtu.tcpClient; import com.dy.common.util.ByteUtil; import com.dy.simRtu.tcpClient.downData.DownData; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.apache.mina.core.buffer.IoBuffer; import org.apache.mina.core.session.IoSession; import org.apache.mina.filter.codec.CumulativeProtocolDecoder; import org.apache.mina.filter.codec.ProtocolDecoderOutput; import java.io.IOException; public class LocalDecoder extends CumulativeProtocolDecoder { private static final Logger log = LogManager.getLogger(LocalDecoder.class) ; private static final String DECODER_STATE_KEY = LocalDecoder.class.getName() + ".STATE"; public static final int MAX_SIZE = 2147483647 ; /** * 对网络传输来的数据进行解码 */ protected boolean doDecode(IoSession session, IoBuffer in, ProtocolDecoderOutput out) throws IOException, Exception{ int remain = in.remaining() ; if(remain > 0){ byte[] bs = new byte[remain]; in.get(bs) ; in.position(0) ; log.info("收到中间件下行数据:" + ByteUtil.bytes2Hex(bs, true)); new DownData().parseData(bs); } return true; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/LocalEncoder.java
New file @@ -0,0 +1,26 @@ package com.dy.simRtu.tcpClient; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.apache.mina.core.buffer.IoBuffer; import org.apache.mina.core.session.IoSession; import org.apache.mina.filter.codec.ProtocolEncoderAdapter; import org.apache.mina.filter.codec.ProtocolEncoderOutput; import java.io.IOException; public class LocalEncoder extends ProtocolEncoderAdapter { private static final Logger log = LogManager.getLogger(LocalEncoder.class) ; /** * 对数据进行编码,以备网络传输 */ public void encode(IoSession session, Object message, ProtocolEncoderOutput out) throws IOException, Exception{ byte[] data = (byte[])message; //log.info("上行数据:" + ByteUtil.bytes2Hex(data, true)); out.write(IoBuffer.allocate((data==null?0:data.length), false).put(data).flip()); } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/TcpClUnit.java
New file @@ -0,0 +1,119 @@ package com.dy.simRtu.tcpClient; import com.dy.common.mw.UnitAdapterInterface; import com.dy.common.mw.UnitCallbackInterface; import com.dy.common.mw.UnitInterface; import com.dy.common.util.Callback; import com.dy.simRtu.ServerProperties; import com.dy.simRtu.tcpClient.upData.UpData; import com.dy.simRtu.tcpClient.upData.UpHeartBeat; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.apache.mina.core.session.IoSession; public class TcpClUnit implements UnitInterface { private static final Logger log = LogManager.getLogger(TcpClUnit.class) ; private static TcpClUnit instance = new TcpClUnit() ; public static TcpClUnitAdapter adapter ; public static TcpClUnitConfigVo confVo ; public static IoSession session ; private TcpClUnit(){} ; public static TcpClUnit getInstance(){ return instance ; } @Override public void setAdapter(UnitAdapterInterface adapter) throws Exception { if(adapter == null){ throw new Exception("Tcp Client模块适配器对象不能为空!") ; } TcpClUnit.adapter = (TcpClUnitAdapter)adapter ; TcpClUnit.confVo = TcpClUnit.adapter.getConfig() ; if(TcpClUnit.confVo == null){ throw new Exception("Tcp Client模块配置对象不能为空!") ; } } @Override public void start(UnitCallbackInterface callback) throws Exception { System.out.println("Tcp Client模块成功启动"); this.doStart(); callback.call(null) ; } @Override public void stop(UnitCallbackInterface callback) throws Exception { callback.call(null); } private void doStart(){ new Thread(() -> { Exception ex ; while(true){ ex = null ; try { new TcpConnect().createSession( confVo.mwServerIp, confVo.mwServerPort, confVo.connectTimeout, new TcpHandler(), new Callback() { @Override public void call(Object obj) { if (obj == null) { log.error("创建网络会话返回为null"); } else { TcpClUnit.session = (IoSession) obj; log.info("成功创建与通信中间件的网络连接"); UpData.setSession(TcpClUnit.session); heartBeat() ; } } @Override public void call(Object... objs) { } @Override public void exception(Exception e) { } }); }catch (Exception e){ ex = e ; } if(ex == null){ break ; }else{ try{ Thread.sleep(100); }catch (Exception e){ } } } }).start(); } private void heartBeat(){ new Thread(new Runnable(){ @Override public void run() { while(true){ try { UpHeartBeat.upCd02Data(ServerProperties.rtuAddr); Thread.sleep(30000L); //Thread.sleep(30000000L); }catch (Exception e){ continue; } } } }).start(); } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/TcpClUnitAdapter.java
New file @@ -0,0 +1,9 @@ package com.dy.simRtu.tcpClient; import com.dy.common.mw.UnitAdapterInterface; public interface TcpClUnitAdapter extends UnitAdapterInterface { TcpClUnitConfigVo getConfig() ; } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/TcpClUnitConfigVo.java
New file @@ -0,0 +1,7 @@ package com.dy.simRtu.tcpClient; public class TcpClUnitConfigVo { public String mwServerIp ; public Integer mwServerPort ; public Integer connectTimeout ; } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/TcpConnect.java
New file @@ -0,0 +1,62 @@ package com.dy.simRtu.tcpClient; import com.dy.common.util.Callback; import org.apache.mina.core.future.ConnectFuture; import org.apache.mina.core.session.IoSession; import org.apache.mina.filter.codec.ProtocolCodecFilter; import org.apache.mina.transport.socket.SocketConnector; import org.apache.mina.transport.socket.nio.NioSocketConnector; import java.net.InetSocketAddress; public class TcpConnect { /** * 判断会话是否有效 * @param se 网络会话 * @return 是否连接 */ public boolean isConnected(IoSession se) { return (se != null && se.isConnected()); } /** * 创建新会话 * @param host 服务器URI * @param port 服务器端口 * @param connectTimeout 连接超时时长 * @param handler 数据处理者 * @param callback 回调 * @return 网络会话 */ public void createSession(String host , int port , int connectTimeout , TcpHandler handler, Callback callback) throws Exception{ SocketConnector connector = new NioSocketConnector(); connector.getFilterChain().addLast("codec", new ProtocolCodecFilter(new LocalCodecFactory())); connector.setHandler(handler); ConnectFuture connectFuture = connector.connect(new InetSocketAddress(host, port)); connectFuture.awaitUninterruptibly(connectTimeout); IoSession se = connectFuture.getSession(); callback.call(se) ; } /** * 关闭会话联接 * @param se * @param connectTimeout */ public void disconnect(IoSession se , int connectTimeout) { if (se != null) { try{ se.closeNow().awaitUninterruptibly(connectTimeout); }catch(Exception e){ }finally{ se = null; } } } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/TcpHandler.java
New file @@ -0,0 +1,92 @@ package com.dy.simRtu.tcpClient; import com.dy.common.util.ByteUtil; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import org.apache.mina.core.service.IoHandlerAdapter; import org.apache.mina.core.session.IdleStatus; import org.apache.mina.core.session.IoSession; import org.apache.mina.filter.FilterEvent; public class TcpHandler extends IoHandlerAdapter { private static Logger log = LogManager.getLogger(TcpHandler.class.getName()) ; /** * {@inheritDoc} */ @Override public void sessionCreated(IoSession session) throws Exception { super.sessionCreated(session); } /** * {@inheritDoc} */ @Override public void sessionOpened(IoSession session) throws Exception { super.sessionOpened(session); } /** * {@inheritDoc} */ @Override public void sessionClosed(IoSession session) throws Exception { super.sessionClosed(session); } /** * {@inheritDoc} */ @Override public void sessionIdle(IoSession session, IdleStatus status) throws Exception { super.sessionIdle(session, status); } /** * {@inheritDoc} */ @Override public void exceptionCaught(IoSession session, Throwable cause) throws Exception { } /** * {@inheritDoc} */ @Override public void messageReceived(IoSession session, Object message) throws Exception { if(message != null){ byte[] bs = (byte[])message ; log.info("收到中间件数据:" + ByteUtil.bytes2Hex(bs, true)); } } /** * {@inheritDoc} */ @Override public void messageSent(IoSession session, Object message) throws Exception { log.info("网络发送了数据," + (session==null?"":(session.getRemoteAddress() != null?("中间件网址是:" + session.getRemoteAddress().toString()):"")) ); if(message != null){ byte[] bs = (byte[])message ; log.info("网络发送了数据:" + ByteUtil.bytes2Hex(bs, true)); } } /** * {@inheritDoc} */ @Override public void inputClosed(IoSession session) throws Exception { session.closeNow(); } /** * {@inheritDoc} */ @Override public void event(IoSession session, FilterEvent event) throws Exception { } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/downData/DownData.java
New file @@ -0,0 +1,56 @@ package com.dy.simRtu.tcpClient.downData; import com.dy.common.mw.protocol.p206V1.ProtocolConstantV206V1; import com.dy.common.util.ByteUtil; import com.dy.simRtu.tcpClient.upData.*; /** * @Author: liurunyu * @Date: 2024/11/18 10:57 * @Description 中间件的下行数据 */ public class DownData { public void parseData(byte[] bs){ if(bs != null && bs.length >= ProtocolConstantV206V1.lenHead2Code){ if(bs.length >= (ProtocolConstantV206V1.ctrlIndex) && bs[0] == ProtocolConstantV206V1.P_Head_Byte && bs[2] == ProtocolConstantV206V1.P_Head_Byte){ this.dealP206V1(bs); }else if(bs.length >= (ProtocolConstantV206V1.UG_codeIndex) && bs[0] == ProtocolConstantV206V1.UG_P_Head_Byte && bs[3] == ProtocolConstantV206V1.UG_P_Head_Byte){ this.dealUpgrade(bs); } } } private void dealP206V1(byte[] bs){ //应该是链路检测数据 } private void dealUpgrade(byte[] bs){ String cdPre = ByteUtil.bytes2Hex(bs, false, ProtocolConstantV206V1.codeIndex, 1); if(cdPre.equals("16")){ //升级功能码 UpHeartBeat.upHeartBeat = false ;//不上行心跳 if(bs.length >= ProtocolConstantV206V1.lenHead2Code + 1){ String cdSuf = ByteUtil.bytes2Hex(bs, false, ProtocolConstantV206V1.codeIndex + 1, 1); String cd = cdPre + cdSuf; if(cd.equals("1601")){ //升级配置 UpCd9601.upData() ; }else if(cd.equals("1602")){ //升级数据 UpCd9602.upData() ; }else if(cd.equals("1603")){ //升级校验 UpCd9603.upData() ; }else if(cd.equals("1600")){ //升级复位 UpCd9600.upData() ; UpHeartBeat.upHeartBeat = true ;//不上行心跳 } } } } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpCd9600.java
New file @@ -0,0 +1,21 @@ package com.dy.simRtu.tcpClient.upData; import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate; import com.dy.common.util.ByteUtil; import com.dy.simRtu.ServerProperties; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; /** * @Author: liurunyu * @Date: 2024/11/18 11:26 * @Description */ public class UpCd9600 extends UpData { private static final Logger log = LogManager.getLogger(UpCd9600.class); public static void upData() { //无上行数据 } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpCd9601.java
New file @@ -0,0 +1,53 @@ package com.dy.simRtu.tcpClient.upData; import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate; import com.dy.common.util.ByteUtil; import com.dy.simRtu.ServerProperties; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; /** * @Author: liurunyu * @Date: 2024/11/18 11:26 * @Description */ public class UpCd9601 extends UpData { private static final Logger log = LogManager.getLogger(UpCd9601.class); public static void upData() { try { if (UpData.session != null && UpData.session.isConnected()) { byte[] bs = createData(ServerProperties.rtuAddr); UpData.upSend(bs); } else { log.error("未连接通信中间件,不能发送数据"); } } catch (Exception e) { log.error("向通信中间件发送数据产生异常", e); } } /** * 构造数据 * * @return 字节数组 * @throws Exception 异常 */ private static byte[] createData(String rtuAddr) throws Exception { byte[] bytes = creatHead4Upgrade(rtuAddr, "96","01"); byte[] bs = new byte[1]; bs[0] = (byte) 0x00;//00 正确 ,0xXX 错误 bytes = ByteUtil.bytesMerge(bytes, bs); GlCreate.createLen4PUg(bytes);//长度放字节数组中 byte[] bsTail = GlCreate.createCrcTail4Ug(bytes);//CRC和尾叠加字节数组中 bytes = ByteUtil.bytesMerge(bytes, bsTail); return bytes; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpCd9602.java
New file @@ -0,0 +1,53 @@ package com.dy.simRtu.tcpClient.upData; import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate; import com.dy.common.util.ByteUtil; import com.dy.simRtu.ServerProperties; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; /** * @Author: liurunyu * @Date: 2024/11/18 11:26 * @Description */ public class UpCd9602 extends UpData { private static final Logger log = LogManager.getLogger(UpCd9602.class); public static void upData() { try { if (UpData.session != null && UpData.session.isConnected()) { byte[] bs = createData(ServerProperties.rtuAddr); UpData.upSend(bs); } else { log.error("未连接通信中间件,不能发送数据"); } } catch (Exception e) { log.error("向通信中间件发送数据产生异常", e); } } /** * 构造数据 * * @return 字节数组 * @throws Exception 异常 */ private static byte[] createData(String rtuAddr) throws Exception { byte[] bytes = creatHead4Upgrade(rtuAddr, "96","02"); byte[] bs = new byte[1]; bs[0] = (byte) 0x00;//00 正确 ,0xXX 错误 bytes = ByteUtil.bytesMerge(bytes, bs); GlCreate.createLen4PUg(bytes);//长度放字节数组中 byte[] bsTail = GlCreate.createCrcTail4Ug(bytes);//CRC和尾叠加字节数组中 bytes = ByteUtil.bytesMerge(bytes, bsTail); return bytes; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpCd9603.java
New file @@ -0,0 +1,53 @@ package com.dy.simRtu.tcpClient.upData; import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate; import com.dy.common.util.ByteUtil; import com.dy.simRtu.ServerProperties; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; /** * @Author: liurunyu * @Date: 2024/11/18 11:26 * @Description */ public class UpCd9603 extends UpData { private static final Logger log = LogManager.getLogger(UpCd9603.class); public static void upData() { try { if (UpData.session != null && UpData.session.isConnected()) { byte[] bs = createData(ServerProperties.rtuAddr); UpData.upSend(bs); } else { log.error("未连接通信中间件,不能发送数据"); } } catch (Exception e) { log.error("向通信中间件发送数据产生异常", e); } } /** * 构造数据 * * @return 字节数组 * @throws Exception 异常 */ private static byte[] createData(String rtuAddr) throws Exception { byte[] bytes = creatHead4Upgrade(rtuAddr, "96","03"); byte[] bs = new byte[1]; bs[0] = (byte) 0x00;//00 正确 ,0xXX 错误 bytes = ByteUtil.bytesMerge(bytes, bs); GlCreate.createLen4PUg(bytes);//长度放字节数组中 byte[] bsTail = GlCreate.createCrcTail4Ug(bytes);//CRC和尾叠加字节数组中 bytes = ByteUtil.bytesMerge(bytes, bsTail); return bytes; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpData.java
New file @@ -0,0 +1,76 @@ package com.dy.simRtu.tcpClient.upData; import com.dy.common.mw.protocol.p206V1.ProtocolConstantV206V1; import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate; import com.dy.common.util.ByteUtil; import org.apache.mina.core.session.IoSession; /** * @Author: liurunyu * @Date: 2024/7/15 14:20 * @Description */ public class UpData { protected static IoSession session ; private static Object synObj = new Object() ; public static void setSession(IoSession session){ UpData.session = session ; } protected static void upSend(byte[] bs) throws Exception{ synchronized (synObj){ session.write(bs) ; } } protected static byte[] creatHead(String rtuAddr, String code, byte ctrl)throws Exception { byte[] bsHead = new byte[ProtocolConstantV206V1.lenHead2Code] ; byte index = 0 ; bsHead[index] = ProtocolConstantV206V1.P_Head_Byte ; index++ ; bsHead[index] = 0 ;//帧长度 index++ ; bsHead[index] = ProtocolConstantV206V1.P_Head_Byte ; index++ ; bsHead[index] = ctrl; //控制域功能码 index++ ; GlCreate.createRtuAddr4P206(rtuAddr, bsHead, index); index += 5 ; ByteUtil.hex2Bytes(code, bsHead, index) ; return bsHead ; } protected static byte[] creatHead4Upgrade(String rtuAddr, String preCode, String sufCode)throws Exception { byte[] bsHead = new byte[12] ; byte index = 0 ; bsHead[index] = ProtocolConstantV206V1.P_Head_Byte ; index++ ; bsHead[index] = 0 ;//帧长度 index++ ; bsHead[index] = 0 ;//帧长度 index++ ; bsHead[index] = ProtocolConstantV206V1.P_Head_Byte ; index++ ; bsHead[index] = ByteUtil.hex2Bytes(preCode)[0]; //功能码域 index++ ; bsHead[index] = ByteUtil.hex2Bytes(sufCode)[0]; //功能码域 index++ ; GlCreate.createRtuAddr4P206(rtuAddr, bsHead, index); return bsHead ; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/java/com/dy/simRtu/tcpClient/upData/UpHeartBeat.java
New file @@ -0,0 +1,56 @@ package com.dy.simRtu.tcpClient.upData; import com.dy.common.mw.protocol.p206V1.parse.global.GlCreate; import com.dy.common.util.ByteUtil; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; /** * @Author: liurunyu * @Date: 2024/7/15 14:18 * @Description */ public class UpHeartBeat extends UpData { private static final Logger log = LogManager.getLogger(UpHeartBeat.class) ; public static boolean upHeartBeat = true ;//是否可以发送心跳 public static void upCd02Data(String rtuAddr){ if(upHeartBeat){ try{ if(UpData.session != null && UpData.session.isConnected()){ byte[] bs = createData(rtuAddr) ; UpData.upSend(bs) ; }else{ log.error("未连接通信中间件,不能发送数据"); } }catch (Exception e){ log.error("向通信中间件发送数据产生异常", e); } } } /** * 构造心跳数据 * @return 字节数组 * @throws Exception 异常 */ private static byte[] createData(String rtuAddr) throws Exception { byte[] bytes = creatHead(rtuAddr, "02", (byte)0xB0); byte[] bs = new byte[1] ; bs[0] = (byte)0xF2 ;//数据域: 1 个字节,F0 登录, F1 退出登录,F2 在线保持。 bytes = ByteUtil.bytesMerge(bytes, bs) ; GlCreate.createLen(bytes);//长度放字节数组中 byte[] bsTail = GlCreate.createCrcTail4P206(bytes) ;//CRC和尾叠加字节数组中 bytes = ByteUtil.bytesMerge(bytes, bsTail) ; return bytes ; } } pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/resources/application.yml
New file @@ -0,0 +1,27 @@ logging: charset: console: UTF-8 config: classpath: log4j2.yml #禁用白标错误页面 server: error: whitelabel: enabled: false #servlet配置 servlet: encoding: #取消默认的字符集编码 enabled: true #设置强制使用指定字符编码集 force: true #使用的字符编码 charset: utf-8 context-path: /simRtu #web访问上下文路径 context-parameters: #GenerateIdSetSuffixListener中应用,取值范围是0-99 idSuffix: 0 #web服务端口号 port: 65530 pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/main/resources/log4j2.xml
New file @@ -0,0 +1,31 @@ <?xml version="1.0" encoding="UTF-8"?> <Configuration status="OFF"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout charset="GBK" pattern="%d %-5p [%t] (%F:%L) - %m%n%throwable"/> </Console> <RollingFile name="File" fileName="logs/simRtu.log" filePattern="logs/simRtu-%d{yyyyMMdd}-%i.log"> <PatternLayout charset="UTF-8" pattern="%d %-5p [%t] (%class.%method:%L) - %m%n%throwable"/> <Policies> <TimeBasedTriggeringPolicy interval="7" /> <SizeBasedTriggeringPolicy size="10MB"/> </Policies> <DefaultRolloverStrategy max="50" /> </RollingFile> </Appenders> <Loggers> <!-- <Logger name="com.zhzc.jgTest" level="debug"> <AppenderRef ref="Console"/> </Logger> <Logger name="org.jgroups" level="info"> <AppenderRef ref="File"/> </Logger> --> <!-- Root与各个Logger同时起作用 --> <Root level="info"> <AppenderRef ref="Console"/> <AppenderRef ref="File"/> </Root> </Loggers> </Configuration> pipIrr-platform/pipIrr-mw/pipIrr-mw-simulate-rtu/src/test/java/com/dy/simRtu/PipIrrMwSimulateRtuApplicationTests.java
New file @@ -0,0 +1,13 @@ package com.dy.simRtu; import org.junit.jupiter.api.Test; import org.springframework.boot.test.context.SpringBootTest; @SpringBootTest class PipIrrMwSimulateRtuApplicationTests { @Test void contextLoads() { } }