Perl命令行应用介绍
http://tech.ddvip.com 2007年10月07日 社区交流
内容摘要:这篇文章讲解了一些常用的命令行参数,通过它可以让你的程序更简练,并且可以写出很多只有一行命令的perl。
Perl 有很多命令行参数。通过它可以让你的程序更简练,并且可以写出很多只有一行命令的perl。在这篇文章里我们来了解一些常用的命令行参数。
安全网参数有三个参数我认为可以起到“安全网”的作用,因为它们可以让你避免犯错,特别是当你在使用 Perl 尝试一些特别聪明(或这愚蠢)的想法时, 错误难免会发生。有经验的 Perl 程序员常常使用这三个参数来提前找到错误所在。
-C 是第一个。这个参数编译 Perl 程序但并不真正运行它。由此检查所有语法错误。每次修改 perl 程序之后我都会立刻使用它来找到任何语法错误。
$ perl -c program.pl这保证了程序依然可以编译。很显然,当你输入一小段代码之后立即进行检查,比起一下子输入几百行代码然后开始 debug 要容易很多。
-W 是第二个参数。它会提示你任何潜在的bug。Perl 5.6.0 之后的版本已经用 use warnings; 替换了 -w。你应该使用 use warnings 因为它要比 -w 更灵活。
-T 是第三个参数。它让 perl 出于了 taint 模式中。在这个模式里,Perl 会质疑任何程序外传来的数据。例如,从命令行读取,外部文件里读取 或是 CGI 程序里传来的数据。这些数据在 -T 模式里都会被 Tainted(污染)。
Tainted 数据不可以被用来和外部交互。例如 使用在 system 调用和用作 open 的文件名。关于什么数据会被Tainted,请参阅perlsec 文档,那里有一个完整的列表。
要想使用 Tainted 的数据就必须 untaint这个数据。untaint 是通过正则表达式来实现的,关于 taint 本身的内容足够写一篇单独的文章,所以这里我不会太多的讲述 taint 模式。如果你要编写的程序(例如 CGI 程序)需要从从用户那里接受不可知的输入,我推荐使有 taint 模式。
作者:qiang 责编:豆豆技术应用