PHP期末练习题(参考答案).docx
练习题一、 单选1. 以下控制选项及错误控制无关的是:( )a) error_reportingb) display_errorsc) log_errorsd) date.timezone2. 下面不属于PHP的标签是:( )a) <?php ?>3. 定义关联数组时,其键名及值之间的分隔符是:a) -> b)=> c): d)#4. 如果想要在文件末尾写入方式打开一个文件,该给fopen()传什么参数? a)w b)r c)a d)a+5. PHP类定义中不支持的访问控制是:( )a) publicb) privatec) protectedd) friend6. 以下关于XML的描述不正确的是:( )a) XML是区分大小写的。b) XML文档中可以有多个根元素。c) XML不允许缺失结束标记。d) XML不允许有重叠的标记。7. 不属于采用AJAX的原因是:( )a) AJAX是基于被广泛支持的公开标准技术。b) 不刷新整个页面,提高了数据处理效率。c) 将数据和显示分离。d) 因为它是一种新的技术。8. AJAX的核心是:( )a) 基于标准的表示技术:XHTML/CSSb) 数据交换和操作技术:XML/XSLTc) 数据获取技术:XMLHttpRequestd) 客户端控制技术:JavaScript9. 下面那一个正则表达式用来验证电子邮件(如:zhang.)的格式最正确:( )a)_.0-9a-z(0-9a-z+.)+0-9a-z.-2,6b)_.09az-*(09az-+.)+09az.+c)_.0-9a-z-+(0-9a-z-+.)+0-9a-z.+d)_.09az-+(09az-+.)+09az2,610. 以下脚本输出什么? ( )<?php echo 'Testing ' . 1 + 2 . '45' ?> ATesting 1245 BTesting 345 CTesting 1+245 D245二、填空1. PHP的构造函数是_ _construct ()_。2. 访问类属性必须通过_$this->_的方式进行访问。3. 访问类中静态成员或函数应通过特殊类_类名:_或_self:_进行访问。4. cookie存储在_客户端_,session是将数据存储在_服务器端_,会话的生命周期默认为_24分钟_。5. 表单的提交方式有_GET_ 和 _POST_。6. PHP5支持的两种复合数据类型是:_数组_ 和 _对象_。7. 面向对象编程的主要特征有_封装_、_继承_ 和 _多态_。8. 显示当前执行的PHP程序文件名的内置常量是_ _file_ _。9. MySQL服务器的默认连接端口是_3306_。10. PHP程序中跳出目前执行的循环的语句是_break_。11. MySQL数据库中可使用_ GRANT _ 语句增加新用户并限制用户访问数据库的权限。12. MySQL数据库查询操作中可使用_ ORDER BY 子句指定查询结果的排序规则。13. 在HTML表单中设置数组的方法:_在输入控件的name属性的名称后面加上一对中括号_。三、综合应用1. 功能:实现产生0到9的数组元素,查找0是否再数组里面,如果存在输出键名,不存在就提示“0不在数组中”。()<html><body><pre><?php$arr1 = range(0, 9);echo "数组arr1为:" ;print_r($arr1); if (in_array(0, $arr1) echo "0在数组arr1中。"echo $arr10; else echo "0不在数组arr1中。"</pre></body></html>2. 以下程序有错,请修改错误。(第4周02次设计练习)<?php$value1 = function ($x) return $x*$x; ;$value2 = function ($x) return $x*$x*$x; ;function compose($f, $g) return function ($x) use ($f, $g)return $f($g($x);$func = compose($value1, $value2);echo $func(5);修改代码:<?php$value1 = function ($x) return $x*$x; ;$value2 = function ($x) return $x*$x*$x; ;function compose($f, $g)return function ($x)use($f,$g) return $f($g($x);$func = compose($value1, $value2);echo $func(5);3. 已知在php.ini的magic_quotes_gpc设为off的情况下,以下SQL语句的生成代码存在注入漏洞,请在不增加数据检查等语句的情况下写出防SQL注入的方法。()<?php$username = $_POST'username'$password = $_POST'password'$statement = "SELECT * FROM users WHERE name = '$username' and password = '$password'"if (isset($_POST'submitted') $username = trim($_POST'username');$password = trim($_POST'password');$tips = ""if (!get_magic_quotes_gpc() $username = addslashes($username);$password = sha1(addslashes($password);if ($username=$store_username) && ($password=$store_password) $tips .= "登陆成功!"$statement = "SELECT * FROM users WHERE name = '$username' and password = '$password'"4. 请写出文件上传的表单设计代码()<form enctype="multipart/form-data" action="upload.php" method="post"> <input type="hidden" name="max_" value="100000"> <input name="userfile" type="file"> <input type="submit" value="上传文件"> </form>5.已知MySQL数据库服务器的数据库用户名为root和密码空,服务器中有一数据库lesson,库中含有一个学生成绩表student,student表的结构如下:(第七、八周第的相关数据库操作内容)字段名类型附加属性字段说明idnamemathenglishintvarchar(20)decimal(5,2)decimal(5,2)auto_increment序号学生姓名数学成绩英语成绩(1)写一个PHP程序,实现:统计所有同学数学和英语的平均成绩,按如下样式输出: $id=mysql_connect("localhost","root","");mysql_select_db("lesson",$id);mysql_query("set names gb2312");$result=mysql_query("SELECT avg(math) , avg(english) FROM student ");$res=mysql_fetch_array($result);Echo "数学平均分为:" $res' avg(math) '. "英语平均分为:"$res' avg(math) '第 4 页