Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

fileData.js 3.2KB

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