php面试题收集与整理(三)

1.echo print print_r的区别?

echo 是PHP语法,可以输出多个值,不能输出数组.

print()是PHP函数,可以输出单个简单类型的变量值

print_r()是php函数,可以打印出复杂类型变量的值,如数组,对象

2.mysql_fetch_row()和mysql_fetch_array()之间的区别?

mysql_fetch_row()以索引数组的方式取查询的结果集,mysql_fetch_array()以索引数组和关联数组两种方式查询结果集.

3.实现中文字串截取无乱码的方法?

mb_substr();

4.有一个网页地址,如何得到他的内容?

$url ="http://.....";

$str=file_get_contents($url);

5.请写一个函数验证电子邮件的格式是否正确

funcion checkMail($email)

{

      echo preg_match('/^[/w]+@[\.]([\w]+)$/',$email)?'ok':'error';

}

6.禁止了cookie后session能正常使用吗?session的缺点是什么?session在服务器端存在哪里?session是公有还是私有?

cookie保存在客户端,用户通过手段可以进行修改,不安全,单个cookie允许大小不能超过3K

而session保存在服务器端,相对比较安全,大小没有限制

禁用cookie不能正常使用session

session缺点:保存在服务器端,每次读取都从服务器进行读取,对服务器有资源消耗

session保存在服务器端的文件或数据库中,默认保存在文件中,文件路径由PHP配置文件的session.save_path指定

session文件是公有的

7.数据库的索引有几类,分别是什么?什么时候该用索引?

普通索引,主键索引,唯一索引

并非所有的数扰库都以相同的方式使用索引,作为通用规则,只有当经常查询列中的数据时才需要在表上创建索引

8.写几个魔术方法并说明作用?

__call()当调用不存的方法时会自动调用的方法

__autoload()在实例化一个尚未被定义的类时会自动调用此方法来加载类文件

__set()当给未定义的变量赋值时会自动调用的方法

__get()获取未定义变量值时会自动调用方法

__construct()构造方法,实例化类时自动调用的方法

__destroy()销毁对象自动调用的方法

__unset()当对一个未定义的变量调用unset()时自动调用的方法

__isset()当对一个未定义变量调用isset()方法时自动调用的方法

__clone()克隆一个对象

__toString()当输出一个对象时自动调用的方法

9.$_REQUEST,$_POST,$_GET,$_COOKIE,$_SESSION,$_FILE的意思是什么?

都是PHP的预定义变量.

$_REQUEST用来获取post或get方式提交的值

$_POST用来获取post方法提交的值

$_GET用来获取GET方式提交的值

$_COOKIE用来获取COOKIE存储的值

$_SESSION用来获取SESSION存储的值

$_FILE用来获取上传文件表单的值

10.数组中下标最好是什么类型的,为什么?

数组的下标最好是数字类型的,数字类型的处理速度快

11.++i效率比i++哪个效率更高,为什么?

++i效率比i++的效率更高,因为++i少了一个返回的过程

12.magic_quotes_gpc(),magic_quotes_runtime()的意思是什么?

magic_quotes_gpc()是php配置文件中的,如果设置为ON则会自动POST,GET,COOKIE中的字符串进行转义,在'前面加\

magic_quotes_runtime()是php中的函数,如果参数为true则会对数据库中取出来的单引号,双引号,反斜线自动动加上反斜杠

13.框架中什么是单一入口和多入口,单一入口的优缺点?

多入口就是通过访问不同的文件来完成用户请求.单一入口只WEB程序所有的请求都指向一个脚本文件.

单一入口更容易控制权限,方便对HTTP请求可以进行安全性检查.

缺点:URL看起来不是那么美观,特别是对搜索引擎来说不友好.

14.你对Memcache的理解,优点有哪些?

memcache是一种缓存技术,在一定的时间内将动态网页经过解析之后保存到文件,下次访问时动态网页就直接调用这个文件,而不必在重新访问数据库,使用memcache的好外是,提高 网站的访问速度,减少高并发时服务器的压力

memcache的优点:稳定,配置简单,多机分布式存储,速度快.

15.对于关系型数据库而言,索引是相当重要的概念.请回答有关索引 几个问题:

a)索引 的目的是什么?

快速访问数据表中的特定信息,有高检索速度

创建唯一性索引,保证数据表中每一行数据的唯一性

加速表与表之间的连接

使用分组和排序子句进行数据检索时,可以显著减少查询中分组和排序的时间

b)索引对数据库系统的负面影响是什么?

负面影响:创建索引和维护索引需要耗费时间,这个时间随着数据量的增加而增加;索引需要占用物理空间,不光是表需要占用数据空间,每个索引也需要占用物理空间,当对表进行增删改的时候索引也要动态维护,降低了数据的维护速度

c)为数据表建立索引 的原则有哪些?

在最频繁使用的,用以缩小查询范围的字段止建立索引

在频繁使用的,需要排序的字段上建立索引

d)什么情况下不宜建立索引

对于查询中很少涉及的列或者重复值比较多的列,不宜建立索引

对于一引起特殊的数据类型,不宜建立索引,如文本字段TEXT

16.WEB应用中,数据库的读取频率远高于写入频率,如何优化MYSQL而应对此种情景?

使用memcache缓存技术,将动态数据缓存到文件,访问动态页面时直接调用缓存文件而不必要重新访问数据库,这样减少查询数据库的次数.

如果网站的访问量很大,可以把数据库读写服务器分开,使用多态服务器去处理数据库查询,使用较少的服务器处理数据库的写入和修改.

17.php字符串中单引号与双引号的区别?

单引号不能解释变量,而双引号可以解释变量,单引号里不能转放字符,在双引号可以转义字符

18.指出sql注入漏洞以及解决方法(magic_quotes_gpc=off)?

msyql_query("select id,title from content where catid='{$_GET[catid]}' and title lick '%$_GET['keyword']%' ",$link);

注入漏洞主要存在用户提交的数据上,这里注入主要是$_GET[catid]和$_GET['keyword']

解决方案:

$_GET[catid] =intval($_GET[catid])

$sql = addslashes($sql);

.....

19.如何快速下载一个远程http服务器上的图片文件到本地

$file=""

$fp=fopen($file,'rb');

$img=fread($fp,10000);

$dir=""

$local=fopen($dir,'/'.basename($file),'w');

fwrite($local,$img)

20.什么是时间戳?如何取得当前时间戳

时间戳是从1970年1月1日 00:00:00到提定日期的秒数

获取当前时间戳的:time()

21.什么是XSS攻击?如何防止?

XSS是跨站脚本攻击,首先是利用跨站脚本漏洞以一个特权模式去执行攻击者构件的脚本,然后利用不安全的Activex执行恶意的行为

使用htmlspecialchars()函数进行过滤,使字符串里面的特殊符号实体化

22.sql注入漏洞产生的原因?如何防止?

sql注入产生的原因:程序开发过程中不注意规范书写SQL语句和对特殊字符进行过滤,导致客户端$_GET和$_POST担交一些SQL语句正常执行

防止SQL注入:

开启配置文件中的magic_quotes_gpc和magic_quotes_runtime设置

执行sql语句时使用addslashes进行sql语句转换

sql语句书写尽量不要省略小引号和单引号

过滤sql语句中的一引起关键字:update insert delete select *

提高数据库和字段的命名技巧,对一些重要的字段根据程序的特点命名,取不易被猜到的

PHP配置文件中调置register_globals为off关闭全局变量注册

控制错误信息,不要再浏览器输出错误信息,将错误贪睡 写到日志文件中

23.一个字节点多少个字节,一个IPV4地址占几个字节?一个IPV6地址占几个字节?

一个字节占8个BIT,一个IPV4占用4个字节,一个IPv6占用16个字节

24.windows平台, Apache Http Server启动失败, 排错思路是什么?
检查apache使用的80端口是否被占用,如果被占用,先停止占用80端口的服务,然后启动apache服务器
151.PHP session扩展默认将session数据储存在哪里? D
A)  SQLite Database B)  MySQL Database C)  Shared Memory D)  File System E)  Session Server
25.如果你想要自动加载类,下面哪种函数声明是正确的 C
A)function autoload($class_name) B)function __autoload($class_name, $file)
C)function __autoload($class_name) D)function _autoload($class_name) E)function autoload($class_name, $file)
26.PHP程序使用utf-8编码, 以下程序输出结果是什么? B
<?php
$str = ’hello你好世界’;
echo strlen($str);
?>
A) 9 B) 13 C) 18 D) 17
27.你所知道的php数组相关的函数?
Array_flip()
Array_pop()
Array_push()
Array_unshift()
End()
Sort()
Rsort()
Usort()
Count()
Key()
Current()
List()
Each()
Foreach()
Array_count_values()
Array_difff()
Arrry_keys()
Array_merge()
Array_pad()
Array_rand()
Array_shift()
Array_unique()
Array_values()
Next()
Prev()
Reset()
28.php读取文件内容的几种方法和函数?
打开文件,然后读取。Fopen() fread()
打开读取一次完成 file_get_contents()
29.以下程序,变量str什么值的情况下输入111? if( ! $str ) { echo 111; }
在$str值为:0,’0′,false,null,”"
30.你所知道的设计模式有哪些?
工厂模式、策略模式、单元素模式、观察者模式、命令链模式
31.说说你对代码管理的了解? 常使用那些代码版本控制软件?
通常一个项目是由一个团队去开发,每个人将自己写好的代码提交到版本服务器,由项目负责人按照版本进行管理,方便版本的控制,提高开发效率,保证需要时可以回到旧版本。
常用的版本控制器:SVN
32.说说你对SVN的了解?优缺点?
SVN是一种版本控制器,程序员开发的代码递交到版本服务器进行集中管理。
SVN的优点:代码进行集中管理,版本控制容易,操作比较简单,权限控制方便。
缺点:不能随意修改服务器项目文件夹。
33.怎么找到PHP.ini的路径?
一般都在php的安装目录下,或者window系统的windows目录下。
34.PHP加速模式/扩展? PHP调试模式/工具?
Zend Optimizer加速扩展
调试工具:xdebug
35.你常用到的mysql命令?
Select * from table
Update table set field=’value’ where id=
Delete from where id=
Insert into table values(‘value1′,’value2′)
Create table tablename
Show tables
36.进入mysql管理命令行的命令?
Mysql -u root -p
37.show databases; 这个命令的作用?
显示当前mysql服务器中有哪些数据库
38.show create database mysql; 这个命令的作用?
显示创建数据库的sql语句
39.show create table user; 这个命令的作用?
显示创建表的sql语句
40.desc user; 这个命令的作用?
查询user表的结构
41.explain select * from user; 这个命令的作用?
获取select相关信息
42.show processlist; 这个命令的作用?
显示哪些线程正在运行
43.SHOW VARIABLES; 这个命令的作用?
显示系统变量和值
44.SHOW VARIABLES like ’%conn%’; 这个命令的作用?
显示系统变量名包含conn的值
45.LEFT JOIN 写一个SQL语句?
Select A.id,A.class from A left join B on A.cid=B.id
46.in, not ni, exist, not exist的作用和区别?
in在什么中
Not in 不在什么中
Exists 存在
Not exists 不存在
47.怎么找到数据库的配置文件路径?
在数据库安装目录下,my.ini
181.简述Linux下安装PHP的过程?
安装软件之前先安装编译工具gcc、gcc-c++
拷贝源码包,解包解压缩
Cd /lamp/php进入php目录
./configure –prefix=/usr/local/php –with-config-file-path=/usr/local/php/etc指定安装目录和配置文件目录
Make 编译
Make install安装
48.简述Linux下安装Mysql的过程?
Groupadd mysql 添加一个用户组mysql
Useradd -g mysql mysql 添加一个mysql用户指定分组为mysql
Cd /lamp/mysql 进入mysql目录
./configure –prefix=/usr/local/mysql/ –with-extra-charsets=all
Make
Make all
49.简述Linux下安装apache的过程?
Cd /lamp/httpd 进去apache软件目录
./configure –prefix=/usr/local/apache2/ –sysconfdir=/etc/httpd/ –with-included-apr
Make
Make all
50.用javascript取得一个input的值?取得一个input的属性?
document.getElementById(‘name’).value;
document.getElementById(‘name’).type;
51.用Jquery取得一个input的值?取得一个input的属性?
$(“input[name='aa']“).val();
$(“input[name='aa']“).attr(‘name’);
52.面向对象中接口和抽象类的区别及应用场景
1、有抽象方法的类叫做抽象类,抽象类中不一定有抽象方法,抽象方法必须使用abstract关键字定义。
2、接口中全部是抽象方法,方法不用使用abstract定义。
3、当多个同类的类要设计一个上层,通常设计为抽象类,当多个异构的类要设计一个上层,通常设计为接口。
53.用面向对象来实现A对象继承B和C对象
Interface B{
}
Interface C{
}
Class A implements B,C{
}
54.创建索引语句:alert table tablename add index (`字段名`)
55.如下user表结构
名称     类型     说明     备注
Uid     Int unsigned     主键     
Name     Varchar(20)         
Age     Tinyint unsigned         
需求:
 增加一个字段性别sex,写出修改语句
Alert table user add sex enum(’0′,’1′);

查询出年龄介于20岁到30岁之间的用户
Select * from user where age>20 and age<30

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章