亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

bat過(guò)濾任意字符

 更新時(shí)間:2006年09月08日 00:00:00   作者:  
文章作者:allyesno

早在寫(xiě) bat的一個(gè)小游戲猜數(shù)字的時(shí)候我就研究過(guò)這個(gè)問(wèn)題 如何在bat里面實(shí)現(xiàn) 對(duì)輸入的任意字符進(jìn)行過(guò)濾 當(dāng)時(shí)使用的幾種方法如下
Codz: 
if "%1"=="要過(guò)濾的字符" echo 你輸入的是非法字符 
例: if "%1"=="wrongpassword" echo 錯(cuò)誤口令 

set errorlevel=0 
echo 要過(guò)濾的字符|find "要過(guò)濾的字符" 
if "%errorlevel%"=="0" echo 你輸入的是是非法字符 
if "%errorlevel%"=="1" echo 該字符串不在非法列表中



主要是使用這兩種方法 這兩種方法可以過(guò)濾數(shù)字 和 英文字母 但是 對(duì) 特殊字符 不起作用

當(dāng)要過(guò)濾【_+|-=\[]{};':,./">~`!@#$%^&*()_+|-=\[]{};':,./<>? 】(包含空格和tab鍵值)的時(shí)候 我們要這樣

Codz: 
echo "anyword"|find "anywrod"

注意到有什么不同了嗎 是的 我們加入了""來(lái)包含anyword 可是過(guò)濾到此并沒(méi)完成 發(fā)現(xiàn)上面要過(guò)濾的字符 少了什么嗎 是的 少了" 字符本身 遺憾的是 這種方法 無(wú)法完美的過(guò)濾"字符本身 當(dāng)" 取值 為奇數(shù) 和 偶數(shù)的 時(shí)候 用find對(duì)她進(jìn)行 過(guò)濾 隨條件 不同可能會(huì)報(bào)錯(cuò)

這個(gè)問(wèn)題 困擾了 我半年之久 曾在安焦上 問(wèn)了一下 沒(méi)人回答 

事實(shí)上要過(guò)濾它 并不是那么的簡(jiǎn)單 我們先寫(xiě)幾個(gè)驗(yàn)證密碼的小程序 看看在不同情況下程序的反應(yīng)

我們先寫(xiě)一個(gè)驗(yàn)證密碼登錄的小程序

注:當(dāng)密碼驗(yàn)證字符為ph4nt0m的時(shí)候 授權(quán)登錄

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 請(qǐng)輸入登錄口令 
set/p password= 
echo "%password%"|findstr "ph4nt0m" 
if "%errorlevel%"=="0" echo 口令正確&goto end 
echo 口令錯(cuò)誤&goto allyesno 
:end 
echo 你成功登錄系統(tǒng)



將bat保存為key.bat執(zhí)行

執(zhí)行結(jié)果

Codz: 
C:test>key 
請(qǐng)輸入登錄口令 
test 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 
ph4nt0m 
"ph4nt0m" 
口令正確 
你成功登錄系統(tǒng)



事實(shí) 上 上面的代碼用來(lái)進(jìn)行一般的口令驗(yàn)證已經(jīng)足夠了 但是 要達(dá)到我們的目的 任意字符過(guò)濾還不行
我們換個(gè)方式執(zhí)行看看

執(zhí)行結(jié)果
Codz: 
C:test>key 
請(qǐng)輸入登錄口令 
test 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 

"""|findstr "ph4nt0m" 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 
ph4nt0m 
"ph4nt0m" 
口令正確 
你成功登錄系統(tǒng)



看見(jiàn)了嗎 當(dāng)我們輸入" 字符的時(shí)候 程序報(bào)錯(cuò)了 并顯示了密碼 為什么會(huì)這樣呢? 我們?cè)倏催@個(gè)語(yǔ)句的語(yǔ)法結(jié)構(gòu) echo "%password%"|findstr "ph4nt0m" 當(dāng)%password%="的時(shí)候 就是echo """|findstr "ph4nt0m"

之所以會(huì)如此 跟echo的特性有關(guān) 我們看下面幾個(gè)語(yǔ)句

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

I:>echo ""|cd 
I: 

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

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



當(dāng)"為奇數(shù)的時(shí)候 則打印整行 當(dāng)"為偶數(shù)的時(shí)候則 執(zhí)行 | 字符后面的命令 上面程序執(zhí)行的命令是cd

這里我想了一個(gè)辦法繞過(guò)echo的報(bào)錯(cuò)特性 我用set代替了echo 程序如下

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 請(qǐng)輸入登錄口令 
set/p password= 
set |findstr "ph4nt0m" 
if "%errorlevel%"=="0" echo 口令正確&goto end 
echo 口令錯(cuò)誤&goto allyesno 
:end 
echo 你成功登錄系統(tǒng)



執(zhí)行結(jié)果如下

Codz: 
請(qǐng)輸入登錄口令 
test 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 

口令錯(cuò)誤 
請(qǐng)輸入登錄口令 
ph4nt0m 
password=ph4nt0m 
口令正確 
你成功登錄系統(tǒng) 

C:\test>



程序進(jìn)一步的完美了

但是還是有問(wèn)題D 我們?cè)賮?lái)看 換一種方式執(zhí)行

Codz: 
請(qǐng)輸入登錄口令 
test 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 
ph4nt0mallyesno 
password=ph4nt0mallyesno 
口令正確 
你成功登錄系統(tǒng) 

C:test>



由于程序的驗(yàn)證方式是 set |findstr "ph4nt0m" 所以只要包含ph4nt0m字符的 密碼 都被當(dāng)成正確密碼 所以密碼ph4nt0mallyesno 也通過(guò)了

為了避免這個(gè)問(wèn)題 我設(shè)置了 匹配參數(shù)\<\> 對(duì)數(shù)據(jù)進(jìn)行檢驗(yàn) 修改后的程序 如下

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 請(qǐng)輸入登錄口令 
set/p password= 
set |findstr "\<ph4nt0m\>" 
if "%errorlevel%"=="0" echo 口令正確&goto end 
echo 口令錯(cuò)誤&goto allyesno 
:end 
echo 你成功登錄系統(tǒng)



執(zhí)行結(jié)果

Codz: 
請(qǐng)輸入登錄口令 
test 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 
ph4nt0mallyesno 
口令錯(cuò)誤 
請(qǐng)輸入登錄口令 
ph4nt0m 
password=ph4nt0m 
口令正確 
你成功登錄系統(tǒng) 

C:test>



最后再將程序 修整 如下 

Codz: 
@echo off 
cls 
:allyesno 
set errorlevel=>nul 
echo 請(qǐng)輸入登錄口令 
set/p password= 
rem 如果密碼字符串包含此行任一字符_+|-=[]{};':,./">~`!@#$%^&*()_+|-=[]{};':,./<>? 則必須使用匹配模式<> 
rem 需要雙寫(xiě)的字符 
rem 不可以作為密碼的字符 " 
set password|findstr "\<ph4nt0m\>" 
if "%errorlevel%"=="0" echo 口令正確&goto end 
echo 口令錯(cuò)誤&goto allyesno 
:end 
set password=>nul 
echo 你成功登錄系統(tǒng)



注:當(dāng)密碼字符串中有字符\的時(shí)候 需要將字符雙寫(xiě)\\ 
例 set password|findstr "\<\\\>"
登錄的時(shí)候 只需要寫(xiě)一次\不需要雙寫(xiě)

" 字符 不可以作為密碼字符串 如果密碼字符串包含此行任一字符_+|-=[]{};':,./">~`!@#$%^&*()_+|-=[]{};':,./<>? 則必須使用匹配模式\<\>

相關(guān)文章

最新評(píng)論