您好,登錄后才能下訂單哦!
這篇文章主要講解了“怎么用bat過濾任意字符”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“怎么用bat過濾任意字符”吧!
早在寫 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對她進行 過濾 隨條件 不同可能會報錯
這個問題 困擾了 我半年之久 曾在安焦上 問了一下 沒人回答
事實上要過濾它 并不是那么的簡單 我們先寫幾個驗證密碼的小程序 看看在不同情況下程序的反應
我們先寫一個驗證密碼登錄的小程序
注:當密碼驗證字符為ph5nt0m的時候 授權登錄
Codz:
@echo off
cls
:allyesno
set errorlevel=>nul
echo 請輸入登錄口令
set/p password=
echo "%password%"|findstr "ph5nt0m"
if "%errorlevel%"=="0" echo 口令正確&goto end
echo 口令錯誤&goto allyesno
:end
echo 你成功登錄系統
將bat保存為key.bat執行
執行結果
Codz:
C:test>key
請輸入登錄口令
test
口令錯誤
請輸入登錄口令
ph5nt0m
"ph5nt0m"
口令正確
你成功登錄系統
事實 上 上面的代碼用來進行一般的口令驗證已經足夠了 但是 要達到我們的目的 任意字符過濾還不行
我們換個方式執行看看
執行結果
Codz:
C:test>key
請輸入登錄口令
test
口令錯誤
請輸入登錄口令
"
"""|findstr "ph5nt0m"
口令錯誤
請輸入登錄口令
ph5nt0m
"ph5nt0m"
口令正確
你成功登錄系統
看見了嗎 當我們輸入" 字符的時候 程序報錯了 并顯示了密碼 為什么會這樣呢? 我們再看這個語句的語法結構 echo "%password%"|findstr "ph5nt0m" 當%password%="的時候 就是echo """|findstr "ph5nt0m"
之所以會如此 跟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 "ph5nt0m"
if "%errorlevel%"=="0" echo 口令正確&goto end
echo 口令錯誤&goto allyesno
:end
echo 你成功登錄系統
執行結果如下
Codz:
請輸入登錄口令
test
口令錯誤
請輸入登錄口令
"
口令錯誤
請輸入登錄口令
ph5nt0m
password=ph5nt0m
口令正確
你成功登錄系統
C:\test>
程序進一步的完美了
但是還是有問題D 我們再來看 換一種方式執行
Codz:
請輸入登錄口令
test
口令錯誤
請輸入登錄口令
ph5nt0mallyesno
password=ph5nt0mallyesno
口令正確
你成功登錄系統
C:test>
由于程序的驗證方式是 set |findstr "ph5nt0m" 所以只要包含ph5nt0m字符的 密碼 都被當成正確密碼 所以密碼ph5nt0mallyesno 也通過了
為了避免這個問題 我設置了 匹配參數\<\> 對數據進行檢驗 修改后的程序 如下
Codz:
@echo off
cls
:allyesno
set errorlevel=>nul
echo 請輸入登錄口令
set/p password=
set |findstr "\<ph5nt0m\>"
if "%errorlevel%"=="0" echo 口令正確&goto end
echo 口令錯誤&goto allyesno
:end
echo 你成功登錄系統
執行結果
Codz:
請輸入登錄口令
test
口令錯誤
請輸入登錄口令
ph5nt0mallyesno
口令錯誤
請輸入登錄口令
ph5nt0m
password=ph5nt0m
口令正確
你成功登錄系統
C:test>
最后再將程序 修整 如下
Codz:
@echo off
cls
:allyesno
set errorlevel=>nul
echo 請輸入登錄口令
set/p password=
rem 如果密碼字符串包含此行任一字符_+|-=[]{};':,./">~`!@#$%^&*()_+|-=[]{};':,./<>? 則必須使用匹配模式<>
rem 需要雙寫的字符
rem 不可以作為密碼的字符 "
set password|findstr "\<ph5nt0m\>"
if "%errorlevel%"=="0" echo 口令正確&goto end
echo 口令錯誤&goto allyesno
:end
set password=>nul
echo 你成功登錄系統
注:當密碼字符串中有字符\的時候 需要將字符雙寫\\
例 set password|findstr "\<\\\>"
登錄的時候 只需要寫一次\不需要雙寫
" 字符 不可以作為密碼字符串 如果密碼字符串包含此行任一字符_+|-=[]{};':,./">~`!@#$%^&*()_+|-=[]{};':,./<>? 則必須使用匹配模式\<\>
感謝各位的閱讀,以上就是“怎么用bat過濾任意字符”的內容了,經過本文的學習后,相信大家對怎么用bat過濾任意字符這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。