c# HJ212协议组包

c# HJ212协议组包c#关于HJ212协议组包今天突然想起好久没有登过博客了又将近两年没有更新怪我太懒散了。。。工作中学习到的很多但也很容易忘记用过的东西某天可能想再用的时候却想不起来了或者找不到了只能挠头~~好了进入正题我在工作中关于HJ212协议这块用到的还是很多的今天来写一写在c#中HJ212协议如何组包以及有了报文内容如何转换为完整报文:先放一张转换为完整报文的成果图:以下为实际代码:publicpartialclassForm1:Form

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

c# 关于HJ212协议组包

今天突然想起好久没有登过博客了 又将近两年没有更新
太懒散。。太懒散了。。。
工作中学习到的很多 但也很容易忘记 用过的东西某天可能想再用的时候却想不起来了 或者找不到了 只能挠头哇~~
好了 进入正题 我在工作中关于HJ212协议这块用到的还是很多的 下面是一个简单的demo ——给现有HJ212报文加上报文头及检验码得到完整212报文
在demo中的HJ212辅助类中有212协议组包的相关代码 有需要的可自行参考~
先放一张转换为完整报文的成果图:
在这里插入图片描述

以下为完整代码:

    public partial class Form1 : Form
    { 
   
        public Form1()
        { 
   
            InitializeComponent();
            textBox1.Text="QN=20210119145656000;ST=31;CN=2011;PW=123456;MN=88800000111;Flag=5;CP=&&DataTime= 20200801084000;a21026-Rtd=10.5,a21026-Flag=N;a25002-Rtd=32.23,a25002-Flag=N&&";
        }

        private void btnChange_Click(object sender, EventArgs e)
        { 
   
            textBox2.Clear();
            textBox2.Text=  GetBackCmd(textBox1.Text);
        }
        public static string GetBackCmd(string Mode)
        { 
   
            string strHead = "##";
            string strlen = "";
            string strMode = Mode;
            strlen = strMode.Length.ToString("0000");
            strMode = strHead + strlen + strMode +HJ212Mode.Crc_16(strMode) + "\r\n";
            return strMode;
        }

    }
    public class HJ212Mode
    { 
   
        #region 212协议组包
        /// <summary>
        /// 获取212协议报文
        /// </summary>
        /// <param name="MN=27">设备唯一标识</param>
        /// <param name="CN=2011">命令编号</param>
        /// <param name="CP">数据</param>
        /// <param name="ST=31">系统编号</param>
        /// <param name="PW">访问密码</param>
        /// <param name="Flag">是否分包及应答标识(0:不应答,不分包 3:应答且分包)</param>
        /// <param name="RevAllData">原报文</param>
        /// <returns></returns>
        public static string GetBackCmd(string MN, string CN, string CP, string ST = "31", string PW = "123456", string Flag = "0", string RevAllData = null)
        { 
   
            string strHead = "##";
            string strlen = "";
            string strQN = "QN=" + DateTime.Now.ToString("yyyyMMddHHmmss000");
            string strST = "ST=" + ST;
            string strCN = "CN=" + CN;
            string strPW = "PW=" + PW;
            string strMN = "MN=" + MN;
            string strFlag = "Flag=" + Flag;
            string strCP = "CP=&&" + CP + "&&";
            //string strCRC = "";

            //从原报文中获取ST和PW
            if (RevAllData != null && RevAllData != "")
            { 
   
                string str = "";
                str = GetParamValue(RevAllData, "ST=");
                if (str != null && str != null)
                { 
   
                    strST = "ST=" + str;
                }
                str = GetParamValue(RevAllData, "PW=");
                if (str != null && str != null)
                { 
   
                    strPW = "PW=" + str;
                }
            }
            //组装需要计算长度及校验的部分
            string strMode = "";
            strMode = strQN + ";" +
                    strST + ";" +
                    strCN + ";" +
                    strPW + ";" +
                    strMN + ";" +
                    strFlag + ";" +
                    strCP;
            strlen = strMode.Length.ToString("0000");
            strMode = strHead + strlen + strMode + Crc_16(strMode) + "\r\n";
            return strMode;
        }
        #endregion
        #region 获取数据报文中指定参数的值
        /** * 获取数据报文中指定参数的值 * @param strData 完整字符串 * @param strParam 对应的字符串 * @return */
        public static String GetParamValue(String strData, String strParam)
        { 
   
            //string strDataLow = strData.ToLower();
            //##0147ST=32;CN=2011;PW=123456;MN=88888880000001;
            //CP=&&DataTime=20100623130500;010-Rtd=10.00,010-Flag=N;011-Rtd=10.00,011-Flag=N;015-Rtd=10.00,015-Flag=N&&D081

            String strDataLow = strData;
            int iPosBegin = strDataLow.IndexOf(strParam, 0);
            if (iPosBegin < 0) return null;
            int iPosC = strDataLow.IndexOf(",", iPosBegin);
            int iPosS = strDataLow.IndexOf(";", iPosBegin);
            int iPosA = strDataLow.IndexOf("&", iPosBegin);
            int iPosEnd = GetValuePos(iPosC, iPosS);
            iPosEnd = GetValuePos(iPosA, iPosEnd);
            int iPosE = strDataLow.IndexOf("=", iPosBegin);
            String strValue = null;
            try
            { 
   
                //if (iPosS < 0) //数据区只有一个数据
                //{ 
   
                // strValue = strDataLow.Substring(iPosE + 1, iPosA - iPosE - 1);
                // //System.out.println("SS"+strValue);
                // return strValue;
                //}
                if (iPosA < 0)
                { 
   
                    iPosA = strDataLow.Length;
                }
                if (iPosEnd == iPosA)
                { 
   
                    iPosEnd = strDataLow.IndexOf("&", iPosA + 2);
                    strValue = strDataLow.Substring(iPosA, iPosEnd - iPosA);
                    return strValue.Replace("&&", "");
                }

                if (iPosEnd > iPosE + 1)
                { 
   
                    strValue = strDataLow.Substring(iPosE + 1, iPosEnd - iPosE - 1);
                    return strValue.Replace(" ", "");
                }
                else return null;
            }
            catch (Exception ex)
            { 
   
                Console.WriteLine("HJ212_Mode", ex.ToString());
                return null;
            }
        }
        #endregion
        #region 判断分隔符的正确位置
        /** * 判断分隔符的正确位置 * @param iPos1 * @param iPos2 * @return */
        public static int GetValuePos(int iPos1, int iPos2)
        { 
   
            if (iPos1 >= 0 && iPos2 >= 0)
                return iPos1 > iPos2 ? iPos2 : iPos1;
            else if (iPos1 < 0 && iPos2 < 0)
                return -1;
            else if (iPos1 >= 0 && iPos2 < 0)
                return iPos1;
            else if (iPos1 < 0 && iPos2 >= 0)
                return iPos2;
            else return -1;
        }
        #endregion
        #region 212协议校验
        /// <summary>
        /// 212协议校验
        /// </summary>
        /// <param name="strData"></param>
        /// <returns></returns>
        public static string Crc_16(string strData)
        { 
   
            byte crc16Lo, crc16Hi;
            byte saveLo, saveHi;
            System.Text.Encoding chs = System.Text.Encoding.GetEncoding("gb2312");
            byte[] bits = chs.GetBytes(strData);

            crc16Hi = 0xFF;
            crc16Lo = 0x00;
            for (int i = 0; i < bits.Length; i++)
            { 
   
                crc16Lo = crc16Hi;
                crc16Hi = 0;
                crc16Lo ^= bits[i];

                for (int g = 0; g < 8; g++)
                { 
   
                    saveHi = crc16Hi;
                    saveLo = crc16Lo;
                    crc16Hi /= 2;
                    crc16Lo /= 2;
                    if (saveHi % 2 == 1)
                    { 
   
                        crc16Lo |= 0x80;
                    }
                    if (saveLo % 2 == 1)
                    { 
   
                        crc16Hi ^= 0xA0;
                        crc16Lo ^= 0x01;
                    }
                }
            }
            return crc16Hi.ToString("X2") + crc16Lo.ToString("X2");
        }
        #endregion
    }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159961.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 点到圆的最近距离公式推导

    点到圆的最近距离公式推导该距离公式在 CircleFittin 相关的一篇文章中用到 现实现其推导过程 设圆的一般的方程形式 任一点 P 的坐标 点 P 到圆上点得最短距离的公式 推导过程 1 由圆一般方程形式可以推导出圆的标准方程形式 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 且有 即 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 圆心坐标 nbsp 半径 2 点到圆的最短距离 nbsp nbsp nbsp nbsp nbsp nbsp 点到圆的最短距离等于点到圆心的距离减去半径的绝

    2025年6月10日
    0
  • Hashcode的作用_hashcode实现

    Hashcode的作用_hashcode实现根据API文档,java中的hashcode事实上是跟equals是有着密切联系的,hashcode是为了提高哈希表的性能下面的话来自JDK:hashCodepublicinthashCode()返回该对象的哈希码值。支持此方法是为了提高哈希表(例如java.util.Hashtable提供的哈希表)的性能。publicnativeinthashCode();说明是一个本地方法,它的…

    2022年9月7日
    0
  • pycharmdjango项目实战_django项目实例精解

    pycharmdjango项目实战_django项目实例精解创建项目我们创建django项目有两种方式,命令行方式和使用pycharm工具创建,本文就介绍常用的pycharm工具创建首先点击django,输入项目的名称,选择创建好的虚拟环境,最后点击cre

    2022年7月29日
    3
  • 阿里云申请免费ssl证书及安装_申请免费ssl证书

    阿里云申请免费ssl证书及安装_申请免费ssl证书本文参考以下文章并整理:阿里云SSL证书免费申请方法(图文教程)藏羚骸的博客~阿里云SSL证书部署(DigiCert免费版SSL)2022阿里云免费SSL证书品牌为DigiCertDV单域名证书,每个阿里云账号可以申请20个免费SSL证书资源包,SSL证书大全图文详解阿里云SSL证书免费申请和部署教程,包括SSL证书申请域名DNS验证等操作。阿里云DigiCert免费版SSL有效期一年,过期后需要重新部署SSL。所以,不管是第一次部署SSL还是刚接手公司项目SSL就到期的小伙伴都可

    2022年10月3日
    0
  • ringbuffer java例子_Java RingBuffer.publish方法代碼示例「建议收藏」

    ringbuffer java例子_Java RingBuffer.publish方法代碼示例「建议收藏」本文整理匯總了Java中com.lmax.disruptor.RingBuffer.publish方法的典型用法代碼示例。如果您正苦於以下問題:JavaRingBuffer.publish方法的具體用法?JavaRingBuffer.publish怎麽用?JavaRingBuffer.publish使用的例子?那麽恭喜您,這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法…

    2022年9月10日
    0
  • JVM参数汇总:JVM内存设置多大合适?Xmx和Xmn如何设置?[通俗易懂]

    JVM参数汇总链接:[#link](https://www.cnblogs.com/duanxz/p/3482366.html)一、java启动参数共分为三类:其一是标准参数(-),所有的JVM实现都必须实现这些参数的功能,而且向后兼容;其二是非标准参数(-X),默认jvm实现这些参数的功能,但是并不保证所有jvm实现都满足,且不保证向后兼容…

    2022年4月17日
    32

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号