Home  >  Article  >  Backend Development  >  PHP笔试题

PHP笔试题

WBOY
WBOYOriginal
2016-06-23 14:37:301125browse

1、不用新变量直接交换现有两个变量的值

(1)list($a,$b)=array($b,$a);(2)a=a+b,b=a-b,a=a-b

2、PHP 数字金额转大小格式,同时说明思路

  function daxie($num){      $da_num = array('零','一','二','三','四','五','六','七','八','九');      $return = '';      $len_num = strlen($num);      if(!is_numeric($num) || $len_num < 0){          return '';      }      for($i=0;$i<$len_num;$i++){          $return .= $da_num[ substr($num,$i,1)];      }      return $return;  }

3.SQL查询语句如下:
select * from table where (ID = 10) or (ID = 32) or (ID = 22) or (ID = 76) or (ID = 13) or (ID = 44)
让结果按10,32,22,76,13,44的顺序检索出来,请问如何书写?

select * from tablewhere id in (10,32,22,76,13,44)          order by charindex(id,'10,32,22,76,13,44') desc

4.用PHP打印出前一天的时间,格式是2006-5-10 22:21:21

(1)echo date('Y-m-d H:i:s',time()-60*60*24);(2)echo date('Y-m-d H:i:s',strtotime('-1 day'))

5. echo(),print(),print_r()的区别

echo是语言结构,无返回值;print功能和echo基本相同,不同的是print是函数,有返回值;print_r是递归打印,用于输出数组或对象

 6.能够使HTML和PHP分离开使用的模板

PHP本身是一种模版引擎,我用过的是smarty,常见的还有PHPLib,FastTemplate,Savant

7.如何实现PHP、JSP交互?

题目有点含糊不清,SOAP,XML_RPC,Socket function,CURL都可以实现这些,如果是考PHP和Java的整合,PHP内置了这种机制(如果考PHP和.NET的整合,也可以这么回答),例如$foo = new Java('java.lang.System');

8.使用哪些工具进行版本控制?

CVS和SVN,SVN号称下一代CVS,功能强大,不过CVS是老牌,市占率很高.我一直用SVN,题目是问用什么工具,呃,这个可能需要这么回答:CVS Server on Apache作服务端,WinCVS作客户端;Subversion on Apache/DAV 做服务端,TortoiseSVN做客户端,或者Subclipse做客户端

9.如何实现字符串翻转?

其实PHP本身就有字符串翻转的函数:strrev(),不过这种方法都不能解决中文字符串翻转的问题,会出错的。<?phpfunction reverse($var){$res="";for($i=0,$j=strlen($var);$i<$j;$i++){$res=$var[$i].$res;}return $res;}$tmpvar="wofang";$res=reverse($tmpvar);echo $res;?>

 10.优化MYSQL数据库的方法

(1).数据库设计方面,这是DBA和Architect的责任,设计结构良好的数据库,必要的时候,去正规化(英文是这个:denormalize),    允许部分数据冗余,避免JOIN操作,以提高查询效率(2).系统架构设计方面,表散列,把海量数据散列到几个不同的表里面.快慢表,快表只留最新数据,慢表是历史存档.集群,主服务器Read & write,    从服务器read only,或者N台服务器,各机器互为Master(3).(1)和(2)超越PHP Programmer的要求了,会更好,不会没关系.检查有没有少加索引(4).写高效的SQL语句,看看有没有写低效的SQL语句,比如生成笛卡尔积的全连接啊,大量的Group By和order by,没有limit等等.    必要的时候,把数据库逻辑封装到DBMS端的存储过程里面.缓存查询结果,explain每一个sql语句(5).所得皆必须,只从数据库取必需的数据,比如查询某篇文章的评论数,select count(*) … where article_id = ?     就可以了,不要先select * … where article_id = ?然后msql_num_rows.    只传送必须的SQL语句,比如修改文章的时候,如果用户只修改了标题,那就update … set title = ? where article_id = ?    不要set content = ?(大文本)(6).必要的时候用不同的存储引擎.比如InnoDB可以减少死锁.HEAP可以提高一个数量级的查询速度

11.谈谈事务处理

A给B的账户转账50美元的例子

12.apache+mysql+php实现最大负载的方法

参考第10题。

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

(1)mb_substr()(2)function GBsubstr($string, $start, $length) {    if(strlen($string)>$length){        $str=null;        $len=$start+$length;        for($i=$start;$i<$len;$i++){            if(ord(substr($string,$i,1))>0xa0){                $str.=substr($string,$i,2);                $i++;            }else{                $str.=substr($string,$i,1);            }        }        return $str;    }else{        return $string;    }}

14.用PHP写出显示客户端IP与服务器IP的代码:

echo '客户端IP:'.$_SERVER['REMOTE_ADDR'].'<br />';echo '服务器端IP:'.gethostbyname($_SERVER['SERVER_NAME']);

 15.在PHP中,当前脚本的名称(不包括路径和查询字符串)记录在预定义变量(1)中;而链接到当前页面的URL记录在预定义变量(2)中。

  前执行脚本的绝对路径名(3),正在浏览当前页面用户的 IP 地址(4),查询(query)的字符串(URL 中第一个问号 ? 之后的内容):id=1&bi=2(5),当前运行脚本所在的文档根目录(6)。

(1)$_SERVER['SCRIPT_FILENAME'];或者$_SERVER['PHP_SELF'](2)$_SERVER['HTTP_REFERER'](3)$_SERVER['SCRIPT_FILENAME'];(4)$_SERVER['REMOTE_ADDR'];(5)$_SERVER['QUERY_STRING'];(6)$_server['DOCUMENT_ROOT'];

 16.执行程序段 将输出__。

(1)echo 8%(-2)。输出:0(2)echo (-8)%3 .输出:-2(3)echo 8%(-3).输出:2

17.在HTTP 1.0中,状态码 401 的含义是____;如果返回“找不到文件”的提示,则可用 header 函数,其语句为____。

(1)401表示未授权;(2)header(“HTTP/1.0 404 Not Found”);[

18.数组函数 arsort 的作用是____;语句 error_reporting(2047)的作用是____。

arsort:对数组进行逆向排序并保持索引关系 error_reporting(2047)的作用是:report All errors and warnings

 19.写出一个正则表达式,过虑网页上的所有JS/VBS脚本(即把script标记及其内容都去掉):

$a="<script type='text/javascript'>XXXXXXXXXXXXXXX</script>";echo preg_replace('/\<script[^>]*?>.*<\/script\>/is','',$a);

20.以Apache模块的方式安装PHP,在文件http.conf中首先要用语句____动态装载PHP模块,
然后再用语句____使得Apache把所有扩展名为php的文件都作为PHP脚本处理。

LoadModule php5_module "c:/php/php5apache2.dll";AddType application/x-httpd-php .php

 21.语句 include 和 require 都能把另外一个文件包含到当前文件中,它们的区别是____;为了避免多次包含同一文件,可以用语句____来代替它们。

在如何处理失败时,include() 产生一个警告而 require() 则导致一个致命错误;require_once()/include_once()

22.一个函数的参数不能是对变量的引用,除非在php.ini中把____设为on 

allow_call_time_pass_reference boolean :是否启用在函数调用时强制参数被按照引用传递

23..SQL 中LEFT JOIN的含义是__,如果 tbl_user记录了学生的姓名(name)和学号(ID),
  tbl_score记录了学生(有的学生考试以后被开除了,没有其记录)的学号(ID)和考试成绩(score)以及考试科目(subject),要想打印出 各个学生姓名及对应的的各科总成绩,则可以用SQL语句____.

答:自然左外连接create database phpinterview;use phpinterviewcreate table tbl_user(ID int not null PRIMARY KEY,name varchar(50) not null,primary key (ID));create table tbl_score(ID int not null ,score dec(6,2) not null,subject varchar(20) not null);insert into tbl_user (ID, name) values (1, 'beimu');insert into tbl_user (ID, name) values (2, 'aihui');insert into tbl_score (ID, score, subject) values (1, 90, '语文');insert into tbl_score (ID, score, subject) values (1, 80, '数学');insert into tbl_score (ID, score, subject) values (2, 86, '数学');insert into tbl_score (ID, score, subject) values (2, 96, '语文');select A.id,sum(B.score) as sumscorefrom tbl_user A left join tbl_score Bon A.ID=B.IDgroup by A.id

24.在PHP中,heredoc是一种特殊的字符串,它的结束标志必须____

结束标识符所在的行不能包含任何其它字符除";"

25.写一个函数,能够遍历一个文件夹下的所有文件和子文件夹。

<?phpfunction my_scandir($dir){    $files=array();    if(is_dir($dir))    {        if($handle=opendir($dir))        {            while(($file=readdir($handle))!==false)            {                if($file!="." && $file!="..")                {                    if(is_dir($dir."/".$file))                    {                        $files[$file]=my_scandir($dir."/".$file);                    }else{                        $files[]=$dir."/".$file;                    }                }            }            closedir($handle);            return $files;        }    }}print_r(my_scandir("D:Program FilesInternet ExplorerMUI"));?>

26.类的属性可以序列化后保存到 session 中,从而以后可以恢复整个类,这要用到的函数是 

serialize() /unserialize()

 

 

 

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn