Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

fileData.js 3.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. import {
  2. TextEncoder,
  3. TextDecoder
  4. } from "../node-model/text-decoding";
  5. export function IntegerToHexString(num, nLen) {
  6. if (num == null) {
  7. let str = "";
  8. for (let i = 0; i < nLen; i++) {
  9. str += "0";
  10. }
  11. return str;
  12. }
  13. return HighAddZero(num.toString(16), nLen);
  14. }
  15. export function HighAddZero(str, nLen) {
  16. let length = str.length;
  17. let nAddLen = nLen - length;
  18. if (length > nLen) {
  19. str = str.substring(0, nLen);
  20. } else {
  21. for (let i = 0; i < nAddLen; i++) {
  22. str = "0" + str;
  23. }
  24. }
  25. return str;
  26. }
  27. // export function AsciToHexString(strAsci, nLen) {
  28. // let s = String(strAsci);
  29. // let encoder = new TextEncoder("UTF-8");
  30. // let bytes = encoder.encode(s);
  31. // let strResult = HexToString(bytes);
  32. // let strLen = strResult.length;
  33. // if (strLen >= nLen) {
  34. // strResult = strResult.substring(0, nLen);
  35. // } else {
  36. // let nAddLen = nLen - strLen;
  37. // for (let i = 0; i < nAddLen; i++) {
  38. // strResult += "0";
  39. // }
  40. // }
  41. // return strResult;
  42. // }
  43. const DIGITS_UPPER = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D',
  44. 'E', 'F'
  45. ];
  46. export function HexToString(inHex) {
  47. let i;
  48. let strResult = "";
  49. for (i = 0; i < inHex.length; i++) {
  50. strResult += DIGITS_UPPER[(0xF0 & inHex[i]) >>> 4];
  51. strResult += DIGITS_UPPER[inHex[i] & 0x0F];
  52. }
  53. return strResult;
  54. }
  55. /**
  56. * 十六进制转汉字
  57. *
  58. * @param {string} data
  59. * @returns {string}
  60. */
  61. export function HexToStrig(data, charType = 1) {
  62. let str = data.substring(data.length - 2);
  63. while (str === "00") {
  64. data = data.substring(0, data.length - 2);
  65. if (data.length === 0) {
  66. return "";
  67. }
  68. str = data.substring(data.length - 2);
  69. }
  70. const asd = hexStringToByteArray(data);
  71. try {
  72. str = new TextDecoder("GBK").decode(asd);
  73. } catch (e) {
  74. console.error(e);
  75. }
  76. return str;
  77. }
  78. /**
  79. * 十六进制字符串转字节数组
  80. *
  81. * @param {string} str
  82. * @returns {Uint8Array}
  83. */
  84. export function hexStringToByteArray(str) {
  85. if (!str) {
  86. return new Uint8Array();
  87. }
  88. const result = new Uint8Array(str.length / 2);
  89. for (let i = 0; i < str.length; i += 2) {
  90. result[i / 2] = parseInt(str.substr(i, 2), 16);
  91. }
  92. return result;
  93. }
  94. /**
  95. * 十六进制转十进制
  96. *
  97. * @param {string} data
  98. * @returns {string}
  99. */
  100. export function HexToInt(data) {
  101. let num = -1;
  102. try {
  103. num = parseInt(data, 16);
  104. } catch (e) {
  105. console.error(e);
  106. }
  107. return num.toString();
  108. }
  109. function guessEncoding(bytes) {
  110. // 检查字节序列是否以 BOM(字节顺序标记)开头
  111. if (bytes[0] === 0xEF && bytes[1] === 0xBB && bytes[2] === 0xBF) {
  112. return 'UTF-8';
  113. } else if (bytes[0] === 0xFE && bytes[1] === 0xFF) {
  114. return 'UTF-16BE';
  115. } else if (bytes[0] === 0xFF && bytes[1] === 0xFE) {
  116. return 'UTF-16LE';
  117. } else {
  118. // 统计每个字节的频率
  119. let freq = {};
  120. for (let i = 0; i < bytes.length; i++) {
  121. let b = bytes[i];
  122. freq[b] = freq[b] ? freq[b] + 1 : 1;
  123. }
  124. // 检查是否存在 GBK 的特定字节序列
  125. if (freq[0x81] && freq[0x81] > 0 && freq[0x40] && freq[0x40] > 0) {
  126. return 'GBK';
  127. }
  128. // 如果没有特定的 GBK 字节序列,则假设为 UTF-8
  129. return 'UTF-8';
  130. }
  131. }