using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrpaonEMS.App.Com
{
///
/// 字节帮助类
///
public class ByteHelper
{
///
/// 字节数组转为16进制字符串
///
/// 字节数组
/// 16进制字符串
public static string ToHexString(byte[] bytes)
{
string hexString = string.Empty;
for (int i = 0; i < bytes.Length; i++)
{
hexString += ByteToHexStr(bytes[i]);
}
return hexString;
}
///
/// 字节转为16进制字符串(一个字节转为两个字符:[0-F][0-F])
///
/// 字节
/// 字符串
public static string ByteToHexStr(byte inByte)
{
string result = string.Empty;
try
{
char[] hexDict = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
char[] charParts = new char[2];
charParts[0] = hexDict[(inByte >> 4) & 0x0F]; //放在byte左半部分的重新移回右边并匹配十六进制字符;
charParts[1] = hexDict[inByte & 0x0F]; //放在byte右半部分的直接匹配十六进制字符;
result = new string(charParts);
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
return result;
}
///
/// 十六进制字符串转为字节数组
///
/// 十六进制字符串
/// 字节数组
public static byte[] HexStrToBytes(string hexStr)
{
/* 说明:1byte=8bit,中文char=2byte(此处不考虑),英文char=1byte,
1个“个位”的十六进制数占4bit,所以2个英文char转为十六进制数后占一个byte */
byte[] bytes = new byte[hexStr.Length / 2 + (((hexStr.Length % 2) > 0) ? 1 : 0)];
for (int i = 0; i < bytes.Length; i++)
{
char leftPart = hexStr[i * 2];
char rightPart;
if ((i * 2 + 1) < hexStr.Length)
rightPart = hexStr[i * 2 + 1];
else
rightPart = '0';
int a = ByteToHexValue((byte)leftPart);
int b = ByteToHexValue((byte)rightPart);
//由于16进制数的'个位'数只占4bit,所以左部分左移4位,加上右部分,共占8位,即一个byte;
bytes[i] = (byte)((a << 4) + b);
}
return bytes;
}
///
/// 转换字节(实际为英文char)为16进制数据(0-15)
///
/// 字节
/// 字节
public static byte ByteToHexValue(byte b)
{
byte value = 0;
if (b >= '0' && b <= '9')
{
//原值在ASCII中介于'0'-'9'之间的:减去0x30,即ASCII中'0'的十六进制表示(十进制为48),得到数值0-9。
value = (byte)(b - 0x30);
}
if (b >= 'A' && b <= 'F')
{
//原值在ASCII中介于'A'-'F'之间的:减去0x37,十进制为55,‘A’的ASCII十进制为65,所以可得到数值10-15。
value = (byte)(b - 0x37);
}
if (b >= 'a' && b <= 'f')
{
//原值在ASCII中介于'a'-'f'之间的:减去0x57,十进制为87,‘a’的ASCII十进制为97,所以可得到数值10-15。
value = (byte)(b - 0x57);
}
return value;
}
///
/// 区块字符串数据转为区块字节数据(不足则补位:16字节)
///
/// 区块字符串数据
/// List
public static List GetBlockBytes(string blockData)
{
List blockBytes = new List();
blockBytes.AddRange(HexStrToBytes(blockData));
if (blockBytes.Count < 16)
{
for (int i = blockBytes.Count; i < 16; i++)
{
blockBytes.Add(0x00);
}
}
return blockBytes;
}
///
/// 字节转二进制字符串(8个字符)
///
/// 单个字节
/// 二进制字符串(8个字符)
public static string ByteToBinaryStr(byte value)
{
return Convert.ToString(value, 2).PadLeft(8, '0');
}
///
/// 字节转字符数组(长度为8,形如:01010101)
///
/// 单个字节
/// 字符数组(长度为8)
public static char[] ByteToCharArray(byte value)
{
return ByteToBinaryStr(value).ToCharArray();
}
///
/// 获取算数累加校验和(超过1字节的进位忽略)
/// https://blog.csdn.net/qq_30725967/article/details/88364985
///
/// 字节数组
/// 1字节的校验和
public static byte GetChecksumCalculateAdd(byte[] buffer)//取低八位
{
int cks = 0;
foreach (byte item in buffer)
{
cks = (cks + item) % 0xffff;
}
//byte bt = (byte)((cks & 0xff00) >> 8);//取校验和高8位
byte bt = (byte)(cks & 0xff);//取校验和低8位
return bt;
}
}
}