Shell脚本测试合法化输入


Shell脚本测试合法化输入
 
   合法化输入:只允许数字和字母 
   用户常常会忽略掉说明,并且输入错误的数据。作为一个Shell脚本开发人员,你需要拦截并纠正这些错误。 
   典型情况是,你或许会遇见文件名或是数据库的键。你提示用户要输入一个全部由大小写字母和数字组成的字符串,没有标点,没有特殊字符,没有空格。他们是否输入正确了?这就是这个脚本要测试的内容。
 
01
validAlphaNum.sh
02
 # validAlphaNum.sh - 确保输入只由数字、字母构成
03
  
04
 #!/bin/sh
05
  
06
 validAlphaNum()
07
 {
08
     # 合法化参数:都是大写字母+小写字母+数字,返回0;否则,返回1
09
  
10
     # 删除所有不可接受的字符
11
     compressed="$(echo $1 | sed -e 's/[^[:alnum:]]//g')"
12
  
13
     if [ "$compressed" != "$input" ]; then
14
         return 1
15
     else
16
         return 0
17
     fi
18
 }
该函数的示例用法。下面的代码直接添加到 validAlphaNum.sh中:
 
01
validAlphaNum.sh
02
 echo -n "输入:"
03
 read input
04
  
05
 if ! validAlphaNum "$input"; then
06
     echo "输入只能是字母和数字。" >&2
07
     exit 1
08
 else
09
     echo "输入合法。"
10
 fi
11
  
12
 exit 0
脚本分析:
   脚本的逻辑是很明确的。首先,它用sed将输入转换为全新的。然后,比较了新的数据和原始的。如果2个完全相同,那么非常完美。否则,转换中丢失的数据就不属于字符数字的集合,所以原始输入时非法的。
   sed的特殊作用是处理不在POSIX字符类[:alnum:]中的数据。该字符类是所有大写字母、小写字母、数字的集合。如果sed处理后的数据并不匹配之前的输入,那么所有字母数字的移动揭示了这样一个问题:在输入字符串(非法的)中有非数字字母的存在,然后函数会返回一个非0值。
 
运行脚本:
   这个脚本本身是完备的。它会提示输入,并通知你结果是否合法。这个函数的更典型的用法是放在一个脚本或者一个库的头部。会在第12个脚本中演示。
   这个脚本展示了一个非常好的一般性的shell脚本编程技术:先写下一个函数,然后紧接着就测试下。完毕后,再把这个函数放到一个更大、更完备的脚本中。这样,会给你以后省下不少事。
 
结果:
 
./validAlphaNum.sh 输入:valid123SAMPLE
输入合法。
./validAlphaNum.sh 输入:this is most assuredly NOT valid, 12345 输入只能是字母和数字。
 

相关内容

    暂无相关文章