亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

php語(yǔ)言

php常見(jiàn)面試題及答案(33道)

時(shí)間:2024-07-12 22:34:35 php語(yǔ)言 我要投稿
  • 相關(guān)推薦

php常見(jiàn)面試題及答案(33道)

  為了幫助同學(xué)們面試PHP工程師,以下是百分網(wǎng)小編搜索整理的關(guān)于php常見(jiàn)面試題及答案(33道),有需要的朋友可以參考一下!想了解更多相關(guān)信息請(qǐng)持續(xù)關(guān)注我們應(yīng)屆畢業(yè)生考試網(wǎng)!

php常見(jiàn)面試題及答案(33道)

  1.在PHP中,當(dāng)前腳本的名稱(不包括路徑和查詢字符串)記錄在預(yù)定義變量(1)中;而鏈接到當(dāng)前頁(yè)面的URL記錄在預(yù)定義變量(2)中。

  代碼如下:

  答:echo $_SERVER['PHP_SELF']; echo $_SERVER["HTTP_REFERER"];

  2.執(zhí)行程序段將輸出(3)。

  代碼如下:

  答:0

  3.在HTTP 1.0中,狀態(tài)碼 401 的含義是(4);如果返回“找不到文件”的提示,則可用 header 函數(shù),其語(yǔ)句為(5)。

  代碼如下:

  答:(4)未授權(quán) (5) header("HTTP/1.0 404 Not Found");

  4.數(shù)組函數(shù) arsort 的作用是(6);語(yǔ)句 error_reporting(2047)的作用是(7)。

  代碼如下:

  答:(6)對(duì)數(shù)組進(jìn)行逆向排序并保持索引關(guān)系  (7)All errors and warnings

  5.寫出一個(gè)正則表達(dá)式,過(guò)慮網(wǎng)頁(yè)上的所有JS/VBS腳本(即把標(biāo)記及其內(nèi)容都去掉):(9)。

  代碼如下:

  答:/<[^>].*?>.*?</>/si

  6.以Apache模塊的方式安裝PHP,在文件http.conf中首先要用語(yǔ)句(10)動(dòng)態(tài)裝載PHP模塊,

  然后再用語(yǔ)句(11)使得Apache把所有擴(kuò)展名為php的文件都作為PHP腳本處理。

  代碼如下:

  答:(10) LoadModule    php5_module "D:/xampp/apache/bin/php5apache2.dll"

  (11) AddType application/x-httpd-php-source .phps

  AddType application/x-httpd-php .php .php5 .php4 .php3 .phtml

  7.語(yǔ)句 include 和 require 都能把另外一個(gè)文件包含到當(dāng)前文件中,它們的區(qū)別是(12);為了避免多次包含同一文件,可以用語(yǔ)句(13)來(lái)代替它們。

  代碼如下:

  答:(12) 發(fā)生異常時(shí)include產(chǎn)生警告require產(chǎn)生致命錯(cuò)誤  (13) require_once()/include_once()

  8.類的屬性可以序列化后保存到 session 中,從而以后可以恢復(fù)整個(gè)類,這要用到的函數(shù)是(14)。

  代碼如下:

  答:serialize() /unserialize()

  9.一個(gè)函數(shù)的參數(shù)不能是對(duì)變量的引用,除非在php.ini中把(15)設(shè)為on.

  代碼如下:

  答:allow_call_time_pass_reference

  10.SQL 中LEFT JOIN的含義是(16)。

  如果 tbl_user記錄了學(xué)生的姓名(name)和學(xué)號(hào)(ID),

  tbl_score記錄了學(xué)生(有的學(xué)生考試以后被開(kāi)除了,沒(méi)有其記錄)的學(xué)號(hào)(ID)和考試成績(jī)(score)以及考試科目(subject),

  要想打印出各個(gè)學(xué)生姓名及對(duì)應(yīng)的的各科總成績(jī),則可以用SQL語(yǔ)句(17)。

  代碼如下:

  答:(16) 自然左外連接

  (17) select name , count(score) as sum_score from tbl_user left join tbl_score on tbl_user.ID=tbl_score.ID  group by tbl_user.ID

  11..在PHP中,heredoc是一種特殊的字符串,它的結(jié)束標(biāo)志必須(18)。

  代碼如下:

  答:結(jié)束標(biāo)識(shí)符所在的行不能包含任何其它字符除";"

  12.用PHP打印出前一天的時(shí)間格式是2006-5-10 22:21:21

  代碼如下:

  答:echo date('Y-m-d H:i:s', strtotime('-1 day'));

  13.echo(),print(),print_r()的區(qū)別

  代碼如下:

  答:echo是語(yǔ)言結(jié)構(gòu),無(wú)返回值;print功能和echo基本相同,不同的是print是函數(shù),有返回值;print_r是遞歸打印,用于輸出數(shù)組對(duì)象

  14.如何實(shí)現(xiàn)字符串翻轉(zhuǎn)?

  代碼如下:

  答:.用strrev函數(shù)唄,不準(zhǔn)用PHP內(nèi)置的就自己寫:

  strrev($str)

  {

  $len=strlen($str);

  $newstr = '';

  for($i=$len;$i>=0;$i--)

  {

  $newstr .= $str{$i};

  }

  return $newstr;

  }

  15.實(shí)現(xiàn)中文字串截取無(wú)亂碼的方法。

  代碼如下:

  答:mb_substr()

  16.使用php寫一段簡(jiǎn)單查詢,查出所有姓名為“張三”的內(nèi)容并打印出來(lái)

  表名User

  Name          Tel              Content         Date

  張三        13333663366        大專畢業(yè)       2006-10-11

  張三        13612312331        本科畢業(yè)       2006-10-15

  張四        021-55665566       中專畢業(yè)       2006-10-15

  代碼如下:

  答:SELECT Name,Tel,Content,Date FROM User WHERE Name='張三'

  17.如何使用下面的類,并解釋下面什么意思?

  class test

  {

  Get_test($num)

  {

  $num=md5(md5($num)."En");

  return $num;

  }

  }

  答:用法:

  代碼如下:

  $get_test = new test();

  $result = $get_test->Get_test(2);

  將$num變量進(jìn)行兩次md5后返回,第2次的md5中的參數(shù),在第一次md5($num)后多加了En

  18.使用五種以上方式獲取一個(gè)文件的擴(kuò)展名

  要求:dir/upload.image.jpg,找出 .jpg 或者 jpg ,

  代碼如下:

  答:使用五種以上方式獲取一個(gè)文件的擴(kuò)展名

  1)

  get_ext1($file_name)

  {

  return strrchr($file_name, '.');

  }

  2)

  get_ext2($file_name)

  {

  return substr($file_name, strrpos($file_name, '.'));

  }

  3)

  get_ext3($file_name)

  {

  return array_pop(explode('.', $file_name));

  }

  4)

  get_ext4($file_name)

  {

  $p = pathinfo($file_name);

  return $p['extension'];

  }

  5)

  get_ext5($file_name)

  {

  return strrev(substr(strrev($file_name), 0, strpos(strrev($file_name), '.')));

  }

  19.如何修改SESSION的生存時(shí)間

  這個(gè)函式庫(kù)讓你處理和顯示各式格式的圖檔,它的另一個(gè)常見(jiàn)用途是制作所圖檔。GD 以外的另一個(gè)選擇是 ImageMagick,但這個(gè)函式庫(kù)并不內(nèi)建于 PHP 之中,必須由系統(tǒng)管理員安裝在伺服器上答:其實(shí) Session 還提供了一個(gè)函數(shù) session_set_cookie_params(); 來(lái)設(shè)置 Session 的生存期的,該函數(shù)必須在 session_start() 函數(shù)調(diào)用之前調(diào)用:

  <?php

  // 保存一天

  $lifeTime = 24 * 3600;

  session_set_cookie_params($lifeTime);

  session_start();

  $_SESSION["admin"] = true;

  ?>

  20. 請(qǐng)寫一個(gè)函數(shù),實(shí)現(xiàn)以下功能: 字符串“open_door” 轉(zhuǎn)換成 “OpenDoor”、”make_by_id” 轉(zhuǎn)換成 ”MakeById”。

  代碼如下:

  答:

  Function test($str){

  $arr1=explode('_',$str);

  //$arr2=array_walk($arr1,ucwords( ));

  $str = implode(' ',$arr1);

  return ucwords($str);

  }

  $aa='open_door';

  echo test($aa);

  ?>

  21. 如何用php的環(huán)境變量得到一個(gè)網(wǎng)頁(yè)地址的內(nèi)容?ip地址又要怎樣得到?

  代碼如下:

  答:$_SERVSR[‘REQUEST_URI']

  $_SERVER[‘REMOTE_ADDR']

  22.求兩個(gè)日期的差數(shù),例如2007-2-5 ~ 2007-3-6 的日期差數(shù)

  代碼如下:

  答:(strtotime(‘2007-3-6')-strtotime(‘2007-2-5'))/3600*24

  23.表中有A B C三列,用SQL語(yǔ)句實(shí)現(xiàn):當(dāng)A列大于B列時(shí)選擇A列否則選擇B列,當(dāng)B列大于C列時(shí)選擇B列否則選擇C列。

  代碼如下:

  答:select case when A>B then A else B end,

  case when B>C then B else C end

  From test

  24.請(qǐng)簡(jiǎn)述項(xiàng)目中優(yōu)化sql語(yǔ)句執(zhí)行效率的方法,從哪些方面,sql語(yǔ)句性能如何分析?

  代碼如下:

  答:(1)選擇最有效率的表名順序

  (2)WHERE子句中的連接順序

 。3)SELECT子句中避免使用‘*'

 。4)用Where子句替換HAVING子句

 。5)通過(guò)內(nèi)部函數(shù)提高SQL效率

 。6)避免在索引列上使用計(jì)算。

 。7)提高GROUP BY 語(yǔ)句的效率, 可以通過(guò)將不需要的記錄在GROUP BY 之前過(guò)濾掉。

  25.mysql_fetch_row() 和 mysql_fetch_array() 有什么分別?

  代碼如下:

  mysql_fetch_row() 把數(shù)據(jù)庫(kù)的一列儲(chǔ)存在一個(gè)以零為基數(shù)的陣列中,第一欄在陣列的索引 0,第二欄在索引 1,如此類推。mysql_fetch_assoc() 把數(shù)據(jù)庫(kù)的一列儲(chǔ)存在一個(gè)關(guān)聯(lián)陣列中,陣列的索引就是欄位名稱,例如我的數(shù)據(jù)庫(kù)查詢送回“first_name”、“l(fā)ast_name”、 “email”三個(gè)欄位,陣列的索引便是“first_name”、“l(fā)ast_name”和“email”。mysql_fetch_array() 可以同時(shí)送回 mysql_fetch_row() 和 mysql_fetch_assoc() 的值。

  26.下面的代碼用來(lái)做什么?請(qǐng)解釋。

  $date='08/26/2003';print ereg_replace("([0-9]+)/([0-9]+)/([0-9]+)","\2/\1/\3",$date);

  代碼如下:

  這是把一個(gè)日期從 MM/DD/YYYY 的格式轉(zhuǎn)為 DD/MM/YYYY 格式。我的一個(gè)好朋友告訴我可以把這個(gè)正規(guī)表達(dá)式拆解為以下的語(yǔ)句,對(duì)于如此簡(jiǎn)單的表示是來(lái)說(shuō)其實(shí)無(wú)須拆解,純粹為了解說(shuō)的方便:

  // 對(duì)應(yīng)一個(gè)或更多 0-9,后面緊隨一個(gè)斜號(hào)$regExpression = "([0-9]+)/";// 應(yīng)一個(gè)或更多 0-9,后面緊隨另一個(gè)斜號(hào)$regExpression .= "([0-9]+)/";// 再次對(duì)應(yīng)一個(gè)或更多 0-9$regExpression .= "([0-9]+)";至于 \2/\1/\3 則是用來(lái)對(duì)應(yīng)括號(hào),第一個(gè)括號(hào)對(duì)的是月份,

  27.GD 函式庫(kù)用來(lái)做什么?

  代碼如下:

  答:這個(gè)函式庫(kù)讓你處理和顯示各式格式的圖檔,它的另一個(gè)常見(jiàn)用途是制作所圖檔。GD 以外的另一個(gè)選擇是 ImageMagick,但這個(gè)函式庫(kù)并不內(nèi)建于 PHP 之中,必須由系統(tǒng)管理員安裝在伺服器上

  28.請(qǐng)舉例說(shuō)明在你的開(kāi)發(fā)過(guò)程中用什么方法來(lái)加快頁(yè)面的加載速度

  代碼如下:

  答:要用到服務(wù)器資源時(shí)才打開(kāi),及時(shí)關(guān)閉服務(wù)器資源,數(shù)據(jù)庫(kù)添加索引,頁(yè)面可生成靜態(tài),圖片等大文件單獨(dú)服務(wù)器。使用代碼優(yōu)化工具啦

  29.防止SQL注射漏洞一般用__addslashes___函數(shù)。

  30.PHP中傳值和傳引用、傳地址的區(qū)別是什么?

  代碼如下:

  答:傳值是把實(shí)參的值賦值給行參 那么對(duì)行參的修改,不會(huì)影響實(shí)參的值

  傳地址 是傳值的一種特殊方式,只是他傳遞的是地址,不是普通的如int 那么傳地址以后,實(shí)參和行參都指向同一個(gè)對(duì)象

  31.如何通過(guò)javascript判斷一個(gè)窗口是否已經(jīng)被屏蔽

  代碼如下:

  答:獲取open()的返回值,如果是null,就是屏蔽了

  33.對(duì)于大流量的網(wǎng)站,您采用什么樣的方法來(lái)解決訪問(wèn)量問(wèn)題

  代碼如下:

  答:首先,確認(rèn)服務(wù)器硬件是否足夠支持當(dāng)前的流量

  其次,優(yōu)化數(shù)據(jù)庫(kù)訪問(wèn)。

  第三,禁止外部的盜鏈。

  第四,控制大文件的下載。

  第五,使用不同主機(jī)分流主要流量

  第六,使用流量分析統(tǒng)計(jì)軟件


【php常見(jiàn)面試題及答案(33道)】相關(guān)文章:

PHP常見(jiàn)面試題及答案10-09

精選php面試題及答案06-01

PHP面試題及答案06-27

流行的php面試題及答案09-14

PHP面試題及答案(匯總)10-10

PHP常見(jiàn)面試題及解析08-14

2017年P(guān)HP面試題與答案09-08

英文題目的PHP面試題及答案08-21

php面試題10-26

最新PHP面試題05-27