AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 429594
Accepted
cmcginty
cmcginty
Asked: 2012-09-19 11:06:40 +0800 CST2012-09-19 11:06:40 +0800 CST 2012-09-19 11:06:40 +0800 CST

使用 Unix 行结尾编写批处理文件是否安全?

  • 772

我想我在批处理文件中遇到了一个错误,因为它是用 unix 行结尾编写的。这是 cmd.exe 在 Windows 中运行批处理文件的已知问题吗?

windows
  • 5 5 个回答
  • 4738 Views

5 个回答

  • Voted
  1. Best Answer
    TheCompWiz
    2012-09-19T11:10:21+08:002012-09-19T11:10:21+08:00

    这真的不是一个“错误”......因为它是设计使然。Windows 换行符被定义为“\r\n”...或“回车”和“换行”组合...而 *nix 风格更喜欢省略回车。在可能的情况下,您应该始终在 Windows 中的任何内容中使用“\r\n”。其他任何东西都可能被错误地解释......并导致大量意想不到的结果。

    • 15
  2. jeb
    2016-08-09T13:36:34+08:002016-08-09T13:36:34+08:00

    对于批处理文件,unix 行尾和 windows 行尾之间没有太大区别。

    目前,在搜索标签时,只有一个已知的 GOTO 和 CALL 行为的故障。如果标签位于相对于当前文件位置的 512 字节边界上,则标签解析器无法找到标签。不同之处在于,因为回车用于内部行重置。请参阅当批处理文件具有 Unix 行结尾时调用和转到可能会失败

    尽管使用了标签扫描器,但意外发现了更多问题,因为批处理解析器在百分比扩展阶段后直接删除了所有回车符。

    显示问题的示例:

    @echo off
    
    goto :main
    
    :func
    echo ************************************************
    echo ************************************************
    echo ************************************************
    echo ************************************************
    echo ************************************************
    echo ***********************************************
    echo ***********************************************
    echo ***********************************************
    echo ************************************************
    echo never go back to :main
    echo This is the end of :func
    exit /b
    
    :main
    :main
    echo This is main
    goto :func
    exit /b
    

    输出是

    这是 :func 的结尾

    • 6
  3. go2null
    2016-10-14T12:47:24+08:002016-10-14T12:47:24+08:00

    在文件中使用 (Unix line-ending)时,似乎会跳过批处理标签。LF.bat

    • 6
  4. Simon Streicher
    2021-09-14T05:48:45+08:002021-09-14T05:48:45+08:00

    有点,但是...

    你必须是一个偏执狂

    • 始终复制您的标签行!
    • 永远不要在标签定义之外使用冒号!

    例如。:

    @echo off
    goto main <- No use of colon
    ...
    
    :main
    :main <- Repeat label
    echo At least one of the above labels are discoverable
    
    REM main part done <- No use of colons in comments
    

    这个怎么运作

    使用 Unix 行结尾时,标签解析器将由于差一错误而跳过一些标签。这是由于解析器使用了 512 字节大小的块,并且假设行尾由两个字符表示\r\n,而不是一个\n。当一个标签被错误地跳过时,下一个错误的跳过只能发生在 512 字节的偏移处。如果您在下一行复制标签,则复制的标签将在 512 个限制内,并且可以作为后备。

    此外,正如 @jeb 所展示的,解析器还将每个 512 字节大小的块的末尾误解为换行(以及以某种方式忽略冒号和这些伪行上的下一个文本之间的空白字符)。诸如 之类的注释:: main section可以触发解析器以某种方式将文本读取: main为标签:main。

    总之,解析器不仅可以跳过标签,还可以将注释和其他文本片段误解为标签。

    为什么不坚持使用 dos 行结尾呢?

    假设您的批处理脚本将保留其行尾并不总是安全的,尤其是在使用 Git 或通过 GitHub 共享内容时。对于跨平台项目来说,不关心行尾并假设 Unix 行尾作为公分母也很方便。

    • 4
  5. Dave Rock
    2020-07-23T05:19:47+08:002020-07-23T05:19:47+08:00

    答案是:你可能会“走运”,它会与 LF 一起工作,但不要指望它。我们遇到了与原始请求者相同的问题。我们的过程最终会得到只有 LF 的 bat 文件,并且(抱歉找不到模式)有时标签会“找不到”,尽管很明显它在那里。必须转换为 CR-LF,或进行随机更改,直到它起作用!

    • 1

相关问题

  • 知道任何适用于 Windows 的快速可编写脚本的 ftp 客户端吗?[关闭]

  • 如果 Windows 服务崩溃,如何自动重新启动它?

  • 无法安排任务(访问被拒绝)

  • 物理机重启时自动重启虚拟机(VMWare)

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve