bat过滤任意字符

所属分类: 脚本专栏 / DOS/BAT 阅读数: 225
收藏 0 赞 0 分享
文章作者:allyesno

早在写 bat的一个小游戏猜数字的时候我就研究过这个问题 如何在bat里面实现 对输入的任意字符进行过滤 当时使用的几种方法如下
Codz: 
if "%1"=="要过滤的字符" echo 你输入的是非法字符 
例: if "%1"=="wrongpassword" echo 错误口令 

set errorlevel=0 
echo 要过滤的字符|find "要过滤的字符" 
if "%errorlevel%"=="0" echo 你输入的是是非法字符 
if "%errorlevel%"=="1" echo 该字符串不在非法列表中



主要是使用这两种方法 这两种方法可以过滤数字 和 英文字母 但是 对 特殊字符 不起作用

当要过滤【_+|-=\[]{};':,./">~`!@#$%^&*()_+|-=\[]{};':,./<>? 】(包含空格和tab键值)的时候 我们要这样

Codz: 
echo "anyword"|find "anywrod"

注意到有什么不同了吗 是的 我们加入了""来包含anyword 可是过滤到此并没完成 发现上面要过滤的字符 少了什么吗 是的 少了" 字符本身 遗憾的是 这种方法 无法完美的过滤"字符本身 当" 取值 为奇数 和 偶数的 时候 用find对她进行 过滤 随条件 不同可能会报错

这个问题 困扰了 我半年之久 曾在安焦上 问了一下 没人回答 

事实上要过滤它 并不是那么的简单 我们先写几个验证密码的小程序 看看在不同情况下程序的反应

我们先写一个验证密码登录的小程序

注:当密码验证字符为ph4nt0m的时候 授权登录

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 请输入登录口令 
set/p password= 
echo "%password%"|findstr "ph4nt0m" 
if "%errorlevel%"=="0" echo 口令正确&goto end 
echo 口令错误&goto allyesno 
:end 
echo 你成功登录系统



将bat保存为key.bat执行

执行结果

Codz: 
C:test>key 
请输入登录口令 
test 
口令错误 
请输入登录口令 
ph4nt0m 
"ph4nt0m" 
口令正确 
你成功登录系统



事实 上 上面的代码用来进行一般的口令验证已经足够了 但是 要达到我们的目的 任意字符过滤还不行
我们换个方式执行看看

执行结果
Codz: 
C:test>key 
请输入登录口令 
test 
口令错误 
请输入登录口令 

"""|findstr "ph4nt0m" 
口令错误 
请输入登录口令 
ph4nt0m 
"ph4nt0m" 
口令正确 
你成功登录系统



看见了吗 当我们输入" 字符的时候 程序报错了 并显示了密码 为什么会这样呢? 我们再看这个语句的语法结构 echo "%password%"|findstr "ph4nt0m" 当%password%="的时候 就是echo """|findstr "ph4nt0m"

之所以会如此 跟echo的特性有关 我们看下面几个语句

Codz: 
I:>echo "|cd 
"|cd 

I:>echo ""|cd 
I: 

I:>echo """|cd 
"""|cd 

I:>echo """"|cd 
I:



当"为奇数的时候 则打印整行 当"为偶数的时候则 执行 | 字符后面的命令 上面程序执行的命令是cd

这里我想了一个办法绕过echo的报错特性 我用set代替了echo 程序如下

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 请输入登录口令 
set/p password= 
set |findstr "ph4nt0m" 
if "%errorlevel%"=="0" echo 口令正确&goto end 
echo 口令错误&goto allyesno 
:end 
echo 你成功登录系统



执行结果如下

Codz: 
请输入登录口令 
test 
口令错误 
请输入登录口令 

口令错误 
请输入登录口令 
ph4nt0m 
password=ph4nt0m 
口令正确 
你成功登录系统 

C:\test>



程序进一步的完美了

但是还是有问题D 我们再来看 换一种方式执行

Codz: 
请输入登录口令 
test 
口令错误 
请输入登录口令 
ph4nt0mallyesno 
password=ph4nt0mallyesno 
口令正确 
你成功登录系统 

C:test>



由于程序的验证方式是 set |findstr "ph4nt0m" 所以只要包含ph4nt0m字符的 密码 都被当成正确密码 所以密码ph4nt0mallyesno 也通过了

为了避免这个问题 我设置了 匹配参数\<\> 对数据进行检验 修改后的程序 如下

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 请输入登录口令 
set/p password= 
set |findstr "\<ph4nt0m\>" 
if "%errorlevel%"=="0" echo 口令正确&goto end 
echo 口令错误&goto allyesno 
:end 
echo 你成功登录系统



执行结果

Codz: 
请输入登录口令 
test 
口令错误 
请输入登录口令 
ph4nt0mallyesno 
口令错误 
请输入登录口令 
ph4nt0m 
password=ph4nt0m 
口令正确 
你成功登录系统 

C:test>



最后再将程序 修整 如下 

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 请输入登录口令 
set/p password= 
rem 如果密码字符串包含此行任一字符_+|-=[]{};':,./">~`!@#$%^&*()_+|-=[]{};':,./<>? 则必须使用匹配模式<> 
rem 需要双写的字符 
rem 不可以作为密码的字符 " 
set password|findstr "\<ph4nt0m\>" 
if "%errorlevel%"=="0" echo 口令正确&goto end 
echo 口令错误&goto allyesno 
:end 
set password=>nul 
echo 你成功登录系统



注:当密码字符串中有字符\的时候 需要将字符双写\\ 
例 set password|findstr "\<\\\>"
登录的时候 只需要写一次\不需要双写

" 字符 不可以作为密码字符串 如果密码字符串包含此行任一字符_+|-=[]{};':,./">~`!@#$%^&*()_+|-=[]{};':,./<>? 则必须使用匹配模式\<\>
更多精彩内容其他人还在看

XP下WORKSTATION启动慢导致系统启动时间过长问题的解决方法

通常安装过VMwareWorkstation导致系统启动过慢,经分析后,发现WORKSTATION服务启动时间较长,禁用后效果明显,可WORKSTATION是WINDOWS的共享基础服务,像我就离不开这个服务的,所以只需下面的脚本就可以解决问题了
收藏 0 赞 0 分享

IP动态切换bat脚本

因为公司办公室要设置固定IP才行,而家里的IP段和公司是不一样的,家里采用了DHCP机制,这样每次就得改IP设置,很是不方便,就写了这个脚本来动态切换,很流畅的说! WINXP,WIN7测试通过
收藏 0 赞 0 分享

奥汀管理员不切换bat脚本 V1.0-Design by Adobo

很多程序不能在管理员权限下运行,尤其是一些破解的程序。所以写了这个脚本,不影响正常的管理员,也不用切换到USERS账户~
收藏 0 赞 0 分享

cmd NTSD命令用法详解

ntsd 是一条dos命令,功能是用于结束一些常规下结束不了的死进程
收藏 0 赞 0 分享

win2003下杀任何进程的命令(taskkill,ntsd)

才能关掉一个用任务管理器关不了的进程?大多数人想到的都是专门工具,如IceSword。其实用Windows自带的工具就能杀大部分进程
收藏 0 赞 0 分享

Windows和 Linux下生成以当前时间命名文件的方法

在 Windows、Linux 操作系统,分别利用BAT批处理文件和Shell脚本,生成类似“20110228_082905.txt”以“年月日_时分秒”命名的文件
收藏 0 赞 0 分享

用批处理去掉快捷方式上的小箭头图案的代码

用批处理去掉快捷方式上的小箭头图案的代码,需要的朋友可以参考下。
收藏 0 赞 0 分享

xcopy 实现批处理拷贝文件或文件夹

xcopy 是一个很有用的doc命令,应该学习学习,XCOPY 还有众多的功能, 是加参数来完成的。上面的/s /e 参数的作用分别是把子目录和空目录都复制过去
收藏 0 赞 0 分享

安全工具netsh IPSec使用方法[ip安全策略]

IPSec的全称是Internet Protocol Security,翻译成中文就是Internet协议安全性。它的作用主要有两个:一个是保护 IP 数据包的内容,另外一点就是通过数据包筛选并实施受信任通讯来防御网络攻击
收藏 0 赞 0 分享

注册表危险组件删除功能批处理

用批处理实现的删除注册表危险组件的代码,主要应用于服务器,个人电脑不建议使用。
收藏 0 赞 0 分享
查看更多