`

对于用户输入的任何数据,即使不考虑恶意企图,程序员也必须做最坏的打算[轉]

阅读更多
http://book.csdn.net/bookfiles/386/10038614376.shtml

对于用户输入的任何数据,如从表单提交中获取的数据,即使不考虑恶意企图,程序员也必须做最坏的打算。因此,程序员总是要面对检查数据是否正确及可用的问题。本章会展示一些在日常工作中能够发挥作用的算法与函数。

在检查数据正确性时,分解为两个步骤将会带来很大便利:一是将输入数据标准化,二是检查标准化之后的数据。输入数据的“标准化”就是将得到的数据调整为统一或是标准格式。各种信息本来都会有一些不同的表达方式,但对于特定的应用程序来说,它们都需要被转化为某种标准格式。之后,我们就可以对标准格式的数据应用有效性规则,从而确定输入的数据是可用的。

将数据检验分为两个步骤可以使过程更加简单和灵活。标准化过程只关心格式问题,程序可以让用户以更自由的方式提供信息,从而具有更高的用户友好度。当输入信息被标准化之后,检查过程就简单多了,因为信息格式是已知的。

当然,凡事皆有例外,有些场合就不适合这种标准化之后进行检验的方法。例如,有时表单输入是数据检验的组成部分,这样就打破了两个步骤的次序;如果输入信息不具有期望的格式,它就会立即变得无效。

下面这些范例都假设用户被要求以某种格式提供信息,而且没有其他程序对用户输入进行处理,范例中得到的数据是“原始的”。

快速提示
Ø   检查变量是否是数字或数字式字符串:

$success = is_numeric($variable);

如果变量是数字,或者是包含数字及符号、小数点、指数的字符串,这个函数就会返回True。

完整文档:http://php.net/is_numeric。

Ø   检查字符串是否只包含字母数字:

$success = ctype_alnum($string);

如果字符串里只包含字母或数字,这个函数就会返回True。

完整文档:http://php.net/ctype_alnum。

Ø   检查字符串是否只包含字母:

$success = ctype_alpha($string);

如果字符串里只包含字母“a”到“z”(不分大小写),函数就会返回True。

完整文档:http://php.net/ctype_alpha。

Ø   检查字符串里是否只包含数字:

$success = ctype_digit($string);

如果字符串里只包含字符“0”到“9”,函数就会返回True。注意,不允许有小数点。

完整文档:http://php.net/ctype_digit。

Ø   检查字符串里是否只包含十六进制数字:

$success = ctype_xdigit($string);

允许的字符是“0”到“9”和“a”到“f”(无论大小写)。

完整文档:http://php.net/ctype_xdigit。

Ø   检查字符串是否全是大写的或全是小写的:

$success = ctype_upper($string);

$success = ctype_lower($string);

如果字符串包含不同的大小写,函数就会返回False。

完整文档:http://php.net/ctype_upper和http://php.net/ctype_lower。

Ø   强制变量为指定类型:

$success = settype($variable, $type);

PHP利用其内部类型转化将变量强制为指定类型。如果转化不能实现,函数会返回False。

完整文档:http://php.net/settype。

Ø   使用类型转化将变量解释为特定类型:

$result = (typekeyword) $variable;

PHP将变量值从原始类型转化为typekeyword指定的类型。

完整文档:http://php.net/manual/language.types.type-juggling.php。

11.1  电话号码
本例中处理的电话号码是美国使用的标准格式,它包含三位区号,随后是三位局号,最后是四位数字。不幸的是,显示(及输入)这些数字的格式有很多种,如(999)555-0100、(999) 555-0100、9995550100、999.555.0100和999-555-0100。程序清单11.1.1可以接收上述(及其他)格式的数字,并且把它们标准化为最后一种形式,因为这便于计算机进行后续处理。

在检验电话号码时,除了确定它包含适当数量的数字之外,还有其他一些规则。例如,如果局号是555,那么后四位数字就不能在0100~0199之间,因为它们是被保留的。另外,区号不能以0或1开头,并且第二个数字不能为9。根据这些规则,我们就得到了如程序清单11.1.1所示的函数。

程序清单11.1.1  电话号码函数库
// A function that will accept US phone numbers, in most every format

// and standardize them to xxx-xxx-xxxx format.

function standardize_phone($phone) {

     // First, remove all non-digits from the string

     $p = preg_replace('/[^0-9]/', '', $phone);

     // Now, break it into its appropriate parts and insert dashes.

     return substr($p, 0, 3) . '-' . substr($p, 3, 3) . '-' . substr($p, 6);

}

// A function to check for phone number validity

// It requires a standardized number

function validate_phone($phone) {

     // First split the number into 3 parts:

     $parts = explode('-', $phone);

     // If the middle is '555'

     if ($parts[1] == '555') {

          // Invalid if the final part is between 0100 and 0199

          if (($parts[2] >= 100) && ($parts[2] < 200)) {

               return false;

          }

     }

     // Invalid if the first digit of the area code is 0 or 1

     if ($parts[0] < 200) {

          return false;

}

     // Invalid if the second digit of the area code, is 9

     if ($parts[0]{1} == '9') {

          return false;

     }

     // Check that the last number has 4 characters:

     if (strlen($parts[2]) != 4) {

          return false;

     }

     // Otherwise, we made it, it's valid.

     return true;

}

// Standardize & validate some phone numbers:

$phones = array('(108)355-4688', '354-555-0103', '294.423.8437',

                   '301 867-5309', '424-726 739', '829-56628426');

foreach ($phones as $num) {

     $st = standardize_phone($num);

     $valid = validate_phone($st);

     $output = $valid ? 'Valid' : 'Invalid';

     echo "<p>{$st} - {$output}</p>\n";

}


上述这些函数不允许电话号码以1开头,而有时人们确实会这样输入电话号码(因为美国的国家区号就是1)。如果想允许用户这样输入,只需要很简单的修改。最简单的方式是在标准化程序中删除号码前面的1就可以了,因为国内区号是不能以1开始的。
分享到:
评论

相关推荐

    程序员必须注意的十大安全之技巧

    - **解决方案**:为了防止这些问题的发生,程序员应该对所有用户输入进行严格的验证和过滤,确保输入数据符合预期格式,并使用参数化查询等方式来防止SQL注入攻击。 #### 2. 防止缓冲区溢出 - **定义**:缓冲区...

    程序员代码面试指南 IT名企算法与数据结构题目最优解.zip

    《程序员代码面试指南》是一本针对IT行业求职者,尤其是准备进入知名企业的程序员们的重要参考资料。这本书主要聚焦于算法和数据结构,旨在帮助读者掌握在面试中常见的问题,并提供最优解。"左神"作为标签,暗示了这...

    写给程序员的数据挖掘指南 代码

    数据挖掘是IT行业中一个至关重要的领域,特别是在大数据时代,它为程序员提供了从海量信息中提取有价值知识的能力。这本书“写给程序员的数据挖掘指南”显然旨在帮助程序员轻松进入这个领域,通过通俗易懂的方式讲解...

    一周学会C# java程序员转.NET必看

    【一周学会C#——java程序员转.NET必看】 C#是一种由微软开发的面向对象的编程语言,设计用于.NET Framework上。对于从Java转到.NET平台的程序员来说,理解C#的基本概念和语法是非常重要的。以下是一些关键知识点:...

    中英文程序员输入法

    "中英文程序员输入法"是一款专为编程人员设计的高效输入工具,旨在提升程序员在编写代码过程中的输入体验。这款输入法的独特之处在于它能够同时处理中英文输入,这对于经常需要混合输入编程词汇和中文注释的程序员来...

    程序员给女朋友做的精美3D相册

    这个“程序员给女朋友做的精美3D相册”项目是一个典型的HTML5技术应用案例,展示了Web开发中的创新和个性化设计。让我们深入探讨一下其中涉及到的技术和知识点。 首先,HTML5是现代网页开发的基础,它提供了更丰富...

    程序员专用 编程输入法

    标题中的“程序员专用编程输入法”指的是专门为程序员设计的特殊输入法工具,旨在提升编码效率。这类输入法通常具有以下特点: 1. **快捷代码输入**:程序员输入法能够通过快捷键、组合键或者自定义短语来快速输入...

    程序员数据结构笔记

    对于程序员来说,理解并掌握数据结构是提升编程能力和解决问题能力的关键。 首先,我们来了解一下数据结构中的对象。数据结构是数据的逻辑组织形式,它定义了数据之间的关系以及对这些数据进行操作的方法。在编程中...

    程序员专用记事本

    【程序员专用记事本】 在IT行业中,程序员是软件开发的核心角色,他们需要处理大量的代码、笔记和项目信息...它不仅能提高编程效率,还能帮助程序员更好地组织和管理他们的工作流程,是现代程序员不可或缺的辅助工具。

    数据挖掘 程序员面试题

    数据挖掘 程序员面试题 数据挖掘 程序员面试题 数据挖掘 程序员面试题 数据挖掘 程序员面试题

    程序员学习打算.pdf

    2. 程序员写的程序不是‘算法+语法’,而是要能够知足用户需求的工具,需要考虑业务、人机交互、效率等方面。 3. 提出一个问题,并在那个问题上不断的深化,看他解决问题的思路和方法。 4. 手写一段代码,紧考核那个...

    程序员计算器

    它的界面简洁,操作直观,使得即使是初学者也能迅速上手。同时,它提供的快捷键和自定义设置功能,使得习惯键盘操作的程序员能更高效地进行计算。 在安装方面,压缩包包含了两个文件:setup.exe和程序员计算器.msi...

    程序员年度工作打算.pdf

    * 程序员年度工作打算篇一:程序员工作打算XX年第一季度工作打算光阴如梭,XX年即将过去,XX年即以后临,新的一年意味之新的起点新的机缘和新的挑战,也是我超级重要的一年。 从这个部分可以看出,程序员对自己的...

    程序员项目交接文档

    在该模块中,程序员需要详细记录人事数据的结构和关系,包括用户表、角色表、部门表等,并且需要对人事数据的存储和查询进行详细的说明。 模块总目录结构是人事模块的重要组成部分,它涵盖了模块的所有目录结构,...

    程序员面试宝典(C/C++&数据结构&网络&数据库&操作系统)

    程序员面试宝典(C/C++&数据结构&网络&数据库&操作系统)

    《程序员教程》 电子书下载

    商业智能不仅仅是技术,也涉及业务理解和战略思维,因此书中可能会讨论如何将数据洞察与实际业务场景相结合。 商业分析部分可能涵盖统计学基础、假设检验、时间序列分析等,这些都是理解趋势、预测未来和制定策略的...

    程序员表白升级版

    总的来说,"程序员表白升级版"是一个结合了技术与情感的创意作品,它展示了Android开发的多样性和趣味性,同时也证明了程序员不仅能编写代码,还能用代码表达最真挚的感情。无论是技术实现还是设计思路,都值得我们...

    程序员必备.doc cmd

    描述中提到“程序员必备需要大于20个字符,不支持HTML标签”,这暗示了文档可能包含了对于程序员日常工作非常重要的基础知识,尤其是那些无法通过图形用户界面(GUI)完成,而必须借助命令行工具的任务。 从标签...

    2018程序员上午题

    试题中的错误分类,例如段落标题编号错误、语句不通顺、错别字、格式问题等,都是软件开发中需要注意的细节,尤其是文档规范性,对于专业程序员来说非常重要。 【知识点二】:统计学基础 试题中的调查问题涉及到了...

Global site tag (gtag.js) - Google Analytics