Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/wix/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Batch file 如何将二进制文件存储在批处理文件中并转换为文件?_Batch File - Fatal编程技术网

Batch file 如何将二进制文件存储在批处理文件中并转换为文件?

Batch file 如何将二进制文件存储在批处理文件中并转换为文件?,batch-file,Batch File,因此,当我看到成批的飞禽时,我查看了代码,看到了以下内容: ) Do >> "FLAPPY.zi_" (Echo.For b=1 To len^(%%b^) Step 2 Echo WScript.StdOut.Write Chr^(Clng^("&H"^&Mid^(%%b,b,2^)^)^) : Next) Cscript /b /e:vbs "FLAPPY.zi_" > "FLAPPY.zip" Del "FLAPPY.zi_" >

因此,当我看到成批的飞禽时,我查看了代码,看到了以下内容:

 ) Do >> "FLAPPY.zi_" (Echo.For b=1 To len^(%%b^) Step 2
   Echo WScript.StdOut.Write Chr^(Clng^("&H"^&Mid^(%%b,b,2^)^)^) : Next)
   Cscript /b /e:vbs "FLAPPY.zi_" > "FLAPPY.zip"
   Del "FLAPPY.zi_" >nul 2>&1
   UNZIP FLAPPY.ZIP
   Del/q UNZIP.EXE
   del/q FLAPPY.ZIP
   echo.
   echo Installed succesfully, press a key to play
   pause>nul
   goto:eof
及以上

) Do >> "FLAPPY.zi_" (Echo.For b=1 To len^(%%b^) Step 2
有二进制代码。完整代码如下:

有没有办法把文件转换成二进制文件


然后将其转换回文件?

纯批处理无法写入空字节0x00。您可以使用将batch与更强大的语言(如JScript、PowerShell)相结合,这些语言可以相对轻松地读取/写入二进制数据

但可能最简单的方法是CERTUTIL。它有各种谓词选项,可以将二进制数据转换为十六进制或base64,反之亦然

以下命令为相关谓词选项提供帮助:

:: Hexadecimal conversion
certutil -encodehex -?
certutil -decodehex -?

:: Base 64 conversion
certutil -encode -?
certutil -decode -?
编码谓词向输出中添加不干扰解码谓词的额外内容。您可以安全地删除额外的信息并重新格式化编码文件,解码谓词仍然可以工作

DosTips.com上的某个地方有一个很好的线程,演示了如何使用CERTUTIL读/写二进制文件,但我还没有找到它

下面是一个普通的.bat示例,它在脚本中嵌入了所有256字节的值,它将十六进制数据提取到一个临时文件中,使用CERTUTIL将十六进制解码为256字节的二进制文件,然后再次使用CERTUTIL将二进制文件编码为十六进制

@echo off
::: 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
::: 10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F
::: 20 21 22 23 24 25 26 27 28 29 2A 2B 2C 2D 2E 2F
::: 30 31 32 33 34 35 36 37 38 39 3A 3B 3C 3D 3E 3F
::: 40 41 42 43 44 45 46 47 48 49 4A 4B 4C 4D 4E 4F
::: 50 51 52 53 54 55 56 57 58 59 5A 5B 5C 5D 5E 5F
::: 60 61 62 63 64 65 66 67 68 69 6A 6B 6C 6D 6E 6F
::: 70 71 72 73 74 75 76 77 78 79 7A 7B 7C 7D 7E 7F
::: 80 81 82 83 84 85 86 87 88 89 8A 8B 8C 8D 8E 8F
::: 90 91 92 93 94 95 96 97 98 99 9A 9B 9C 9D 9E 9F
::: A0 A1 A2 A3 A4 A5 A6 A7 A8 A9 AA AB AC AD AE AF
::: B0 B1 B2 B3 B4 B5 B6 B7 B8 B9 BA BB BC BD BE BF
::: C0 C1 C2 C3 C4 C5 C6 C7 C8 C9 CA CB CC CD CE CF
::: D0 D1 D2 D3 D4 D5 D6 D7 D8 D9 DA DB DC DD DE DF
::: E0 E1 E2 E3 E4 E5 E6 E7 E8 E9 EA EB EC ED EE EF
::: F0 F1 F2 F3 F4 F5 F6 F7 F8 F9 FA FB FC FD FE FF
>hex.temp (
  for /f "delims=: tokens=*" %%A in ('findstr "^:::" "%~f0"') do echo %%A
)

certutil -f -decodeHex hex.temp out.bin >nul

certutil -f -encodeHex out.bin out.hex >nul

del hex.temp

我的防病毒程序不喜欢生成的某个exe文件。