[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
本帖最后由 CommandBatCmd 于 2016-11-8 00:52 编辑

双引号不能屏障双引号成为普通字符,这是批处理的固有属性,除非叫MS重新设计批处理解释器或自己动手改造。
我们所看到的很多表象都是批处理解释器预处理的结果,或者说是我们传递的双引号被预处理后”巧合“或者”有意设计“得到了符合语法的一行正确命令。
不要在怎样用双引号来处理双引号成为普通字符的问题中纠结,在批处理中这个问题是不成立的。
在这个具体问题中,把某个值传递到双引号中的变量前,要首先把赋值结果中的所有双引号删除,再传递给变量进行比较,才是安全可靠有保障的。
在达到上述目的的同时,我们也损失了一个可用的普通字符--双引号。鱼和熊掌难以兼得到此又见!

TOP

http://www.bathome.net/redirect. ... 2&ptid=42296]1# 0000 [/url]
  1. @echo off
  2. :password
  3. cls&set /p a=password:
  4. set "a=%a:"=%
  5. echo,"%a%"
  6. if "%a%"=="abcdcb" goto start
  7. goto wrong
  8. :start
  9. rem 以下是我的代码
  10. goto :eof
  11. :wrong
  12. echo password error
  13. pause&goto password
复制代码
输入任何字符都不会自动退出。
除了输入的所有双引号在结果中不存在外,其余全部作为赋值。

TOP

回复 8# CrLf

标题中的问题放到批处理中来实现是个两难选择,是要程序的安全运行,还是要输入字段的完整性来保障密码的唯一性。
我想批处理在接受用户的输入上没有能力兼顾以上两点,这应该是批处理的局限性所在。
如果一个RAR压缩文件的密码字段包含双引号和空格,使用批处理接受用户输入传递密码字段给命令行模式的RAR.exe,以下
if not "%a%%a%"=="abcdcbabcdcb" (set/p=password error&exit)
不会安全运行。

TOP

关于批处理的种种,我只想说,换一种语言海阔天空
523066680 发表于 2016-11-8 20:22


高手都有这样的感慨,给心中的迷惑又添加了一条有力的诠释。

TOP

返回列表