第一篇:PHP面試題
PHP程序員初級(jí)面試題
一、解釋一下語(yǔ)句作用,并標(biāo)示出以下哪一句不會(huì)把 John 新增到 users 陣列?
$users[] = 'john';
array_add($users,?john?);
array_push($users,?john?);
$users ||= 'john';
二、sort()、assort()、和 ksort()有什么分別?它們分別在什么情況下使用? sort()
asort()
ksort()
三、以下的代碼會(huì)產(chǎn)生什么?為什么? $num =10;function multiply(){ $num =$num *10;} multiply();echo $num;
四、reference 跟一個(gè)正規(guī)的變量有什么分別?如何 pass by reference?在什么情況下我們需要這樣做?
五、哪些函式可以用來(lái)向正在執(zhí)行的腳本中插入函式庫(kù)?
六、foo()與 @foo()有什么分別?
七、你如何替 PHP 的應(yīng)用程式偵錯(cuò)?
八、“===”是什么?試舉一個(gè)“==”是真但“===”是假的例子。
九、你會(huì)如何定義一個(gè)沒(méi)有成員函式或特性的類別 myclass?
十、include 和 include_once 有什么分別?require 又如何?
十一、以下哪一個(gè)函式可以把瀏覽器轉(zhuǎn)向到另一個(gè)頁(yè)面? redir()
header()
location()
redirect()
十二、以下哪一個(gè)函式可以用來(lái)開(kāi)啟檔案以便讀/寫? fget()
file_open()
fopen()
open_file()
十三、mysql_fetch_row()和 mysql_fetch_array()有什么分別?
十四、下面的代碼用來(lái)做什么?請(qǐng)解釋。
$date='08/26/2003';print ereg_replace(“([0-9]+)/([0-9]+)/([0-9]+)”,“[url=file://2///1///3%22,$date]2/1/3”,$date[/url]);
十五、試寫出幾個(gè)輸出一段 HTML 代碼的方法。(一)
成功把 John 新增到陣列 users。函式 array_add()無(wú)定義。
成功把 John 新增到陣列 users。
語(yǔ)法錯(cuò)誤。
(二)根據(jù)陣列中元素的值,以英文字母順序排序,索引鍵會(huì)由 0 到 n-1 重新編號(hào)。主要是當(dāng)陣列索引鍵的值無(wú)關(guān)疼癢時(shí)用來(lái)把陣列排序。
與 sort()一樣把陣列的元素按英文字母順序來(lái)排列,不同的是所有索引鍵都獲得保留,特別適合替聯(lián)想陣列排序。
根據(jù)陣列中索引鍵的值,以英文字母順序排序,特別適合用于希望把索引鍵排序的聯(lián)想陣列。
(三)由于函式 multiply()沒(méi)有指定 $num 為全域變量(例如 global $num 或者 $_GLOBALS['num']),所以 $num 的值是 10。
(四)Reference 傳送的是變量的地址而非它的值,所以在函式中改變一個(gè)變量的值時(shí),整個(gè)應(yīng)用都見(jiàn)到這個(gè)變量的新值。一個(gè)正規(guī)變量傳送給函式的是它的值,當(dāng)函式改變這個(gè)變量的值時(shí),只有這個(gè)函式才見(jiàn)到新值,應(yīng)用的其他部分仍然見(jiàn)到舊值。
$myVariable = “its' value”;Myfunction(&$myVariable);// 以 reference 傳送參數(shù)以 reference 傳送參數(shù)給函式,可以使函式改變了的變量,即使在函式結(jié)束后仍然保留新值。
(五)對(duì)這道題目不同的理解會(huì)有不同的答案,我的第一個(gè)想法是插入 PHP 函式庫(kù)不外乎 include()、include_once()、require()、require_once(),但細(xì)心再想,“函式庫(kù)”也應(yīng)該包括 com 物件和.net 函式庫(kù),所以我們的答案也要分別包括 com_load 和 dotnet_load,下次有人提起“函式庫(kù)”的時(shí)候,別忘記這兩個(gè)函式。
(六)foo()會(huì)執(zhí)行這個(gè)函式,任何解譯錯(cuò)誤、語(yǔ)法錯(cuò)誤、執(zhí)行錯(cuò)誤都會(huì)在頁(yè)面上顯示出來(lái)。@foo()在執(zhí)行這個(gè)函式時(shí),會(huì)隱藏所有上述的錯(cuò)誤訊息。
很多應(yīng)用程式都使用 @mysql_connect()和 @mysql_query 來(lái)隱藏 mysql 的錯(cuò)誤訊息,我認(rèn)為這是很嚴(yán)重的失誤,因?yàn)殄e(cuò)誤不該被隱藏,你必須妥善處理它們,可能的話解決它們。
(七)我并不常這樣做,我曾經(jīng)試過(guò)很多不同的偵錯(cuò)工具,在 Linux 系統(tǒng)中設(shè)定這些工具一點(diǎn)也不容易。不過(guò)以下我會(huì)介紹一個(gè)近來(lái)頗受注目的偵錯(cuò)工具。
PHPAPD,第一步是執(zhí)行以下的指令安裝: pear install apd安裝后在你的腳本的開(kāi)頭位置加入以下的語(yǔ)句開(kāi)始進(jìn)行偵錯(cuò): apd_set_pprof_trace();執(zhí)行完畢,打開(kāi)以下檔案來(lái)查閱執(zhí)行日志: apd.dumpdir 你也可以使用 pprofp 來(lái)格式化日志。
(八)“===”是給既可以送回布爾值“假”,也可以送回一個(gè)不是布爾值但卻可以賦與“假”值的函式,strpos()和 strrpos()便是其中兩個(gè)例子。
問(wèn)題的第二部份有點(diǎn)困難,想一個(gè)“==”是假,但是“===”是真的例子卻很容易,相反的例子卻很少。但我終于找到以下的例子:
if(strpos(“abc”, “a”)== true){ // 這部分永不會(huì)被執(zhí)行,因?yàn)?“a” 的位置是 0,換算成布爾值“假”}if(strpos(“abc”, “a”)=== true){ // 這部份會(huì)被執(zhí)行,因?yàn)椤?==”保證函式 strpos()的送回值不會(huì)換算成布爾值.}(九)
class myclass{}(十)$obj = new myclass();(十一)
使用語(yǔ)句:$this->propertyName,例如:
class myclass{ private $propertyName;public function __construct(){ $this->propertyName = “value”;}}(十二)
三者都是用來(lái)在腳本中插入其他檔案,視乎 url_allow_fopen 是否核準(zhǔn),這個(gè)檔案可以從系統(tǒng)內(nèi)部或外部取得。但他們之間也有微細(xì)的分別:
include():這個(gè)函式容許你在腳本中把同一個(gè)檔案插入多次,若果檔案不存在,它會(huì)發(fā)出系統(tǒng)警告并繼續(xù)執(zhí)行腳本。include_once():它跟 include()的功能相似,正如它的名字所示,在腳本的執(zhí)行期間,有關(guān)檔案只會(huì)被插入一次。require():跟 include()差不多,它也是用來(lái)在腳本中插入其他檔案,但若果檔案不存在,它會(huì)發(fā)出系統(tǒng)警告,這個(gè)警告會(huì)引致致命錯(cuò)誤令腳本中止執(zhí)行
(十三)這不是一個(gè) PHP 函式,會(huì)引致執(zhí)行錯(cuò)誤。
這個(gè)是正確答案,header()用來(lái)插入卷頭資料,可以用來(lái)使瀏覽器轉(zhuǎn)向到另一個(gè)頁(yè)面,例如:
header(“Location: http:// 標(biāo)簽,為何要自行編寫正規(guī)表達(dá)式?好了,便當(dāng)作是面試的一道考題吧,我會(huì)這樣回答:
$stringOfText = ”
This is a test
“;$expression = ”/<(.*?)>(.*?)(.*?)>/“;echo preg_replace($expression, ”[url=file://2/]2[/url]“, $stringOfText);// 有人說(shuō)也可以使用 /(<[^>]*>)/ $expression = ”/(<[^>]*>)/“;echo preg_replace($expression, ”“, $stringOfText);(十八)這正是為何我老是告訴別人選擇適當(dāng)?shù)木幊陶Z(yǔ)言,若果你只用一種語(yǔ)言的話你怎么能回答這道問(wèn)題?這道問(wèn)題很簡(jiǎn)單,Perl 所有陣列變量都是以 @ 開(kāi)頭,例如 @myArray,PHP 則沿用 $ 作為所有變量的開(kāi)頭,例如 $myArray。至于 Perl 表示散列表則用 %,例如 %myHash,PHP 則沒(méi)有分別,仍是使用 $,例如
$myHash。
(十九)最主要的倆各選擇是 session 和 cookie。使用 session 的方法是在每一頁(yè)的開(kāi)始加上 session_start(),然后利用 $_SESSION 散列表來(lái)儲(chǔ)存 session 變量。至于 cookie 你只需記著一個(gè)原則:在輸出任何文字之前調(diào)用 set_cookie()函式,此外只需使用 $_COOKIE 散列表便可以存取所有 cookie 變量。
還有一個(gè)不那么可靠的方法,就是利用訪客的 IP 地址,這個(gè)方法有特定的危險(xiǎn)性。
(二十)這個(gè)可能是我最喜歡的函式庫(kù),自從 PHP 4.3.0 版本后 GD 便內(nèi)建在 PHP 系統(tǒng)中。這個(gè)函式庫(kù)讓你處理和顯示各式格式的圖檔,它的另一個(gè)常見(jiàn)用途是制作所圖檔。GD 以外的另一個(gè)選擇是 ImageMagick,但這個(gè)函式庫(kù)并不內(nèi)建于 PHP 之中,必須由系統(tǒng)管理員安裝在伺服器上。
(二十一)嗯,你可以使用 PHP 中任何一種輸出語(yǔ)句,包括 echo、print、printf,大部分人都使用如下例的 echo: echo ”My string $variable";你也可以使用這種方法:
echo <<
我們不要為一個(gè)簡(jiǎn)單的問(wèn)題引發(fā)一場(chǎng)舌戰(zhàn),正如我經(jīng)常說(shuō)的:“為工作選擇適合的語(yǔ)言,不要把工作遷就語(yǔ)言?!蔽覀€(gè)人認(rèn)為 Perl 十分適合用作命令行工具,雖然它在網(wǎng)頁(yè)應(yīng)用上也有不錯(cuò)的表現(xiàn),但是它的真正實(shí)力在命令行上才能充分發(fā)揮。同樣地,PHP 雖然可以在控制臺(tái)的環(huán)境中使用,但是個(gè)人認(rèn)為它在網(wǎng)頁(yè)應(yīng)用上有更好的表現(xiàn),PHP 有大量專門為網(wǎng)頁(yè)應(yīng)用而設(shè)計(jì)的函式,Perl 則似乎以命令行為設(shè)計(jì)之本。
個(gè)人來(lái)說(shuō)兩種語(yǔ)言我都喜歡,在大學(xué)期間我經(jīng)常使用 Perl、PHP 和 Java,可惜工作上我使用 C#,但在家里我花不少時(shí)間操練 PHP、Perl、Ruby(現(xiàn)正學(xué)習(xí))和 Java,保持我的技能知識(shí)在最新?tīng)顟B(tài)。很多人問(wèn)我 C 和 C++ 怎么樣,它們是否仍有機(jī)會(huì)在我的應(yīng)用中占一席位,我的答案基本上是“否”,我近來(lái)的工作主要集中在網(wǎng)頁(yè)開(kāi)發(fā),雖然 C 和 C++ 也可以用來(lái)寫網(wǎng)頁(yè),但它們到底不是為這種工作而設(shè)計(jì)的,“為工作選擇適合的語(yǔ)言”,若果我需要編寫一個(gè)控制臺(tái)應(yīng)用,用來(lái)展示 bubble sort、quick sort 和 merge sort 的效能比較,我一定會(huì)使用 C / C++。若果我需要編寫一個(gè)相片簿系統(tǒng),我會(huì)使用 PHP 或者 C#(我認(rèn)為制作用戶介面方面.NET 語(yǔ)言比網(wǎng)頁(yè)更加)。
第二篇:PHP程序員面試題
北京融入網(wǎng)絡(luò)科技有限公司
PHP工程師面試題
1、請(qǐng)寫一個(gè)實(shí)現(xiàn)中文字串截取無(wú)亂碼的方法。(超出部分用’…..’替換)。
2、ThinkPHP框架中,下列定義有什么不同?
$userModel = M(“User”);
$userMode l= D(“User”);
3、如果讓你模擬登陸微信公眾平臺(tái)并設(shè)置微信的開(kāi)發(fā)模式中的URL和Token,你會(huì)如何去做?(思路或代碼皆可)。
4、談?wù)剬?duì)你對(duì)PHP的認(rèn)識(shí)或你擅長(zhǎng)的技術(shù)。
5、假設(shè)有一個(gè)博客系統(tǒng),數(shù)據(jù)庫(kù)存儲(chǔ)采用mysql,用戶數(shù)量為1000萬(wàn),預(yù)計(jì)文章總數(shù)為10億,每天有至少10萬(wàn)的更新量,每天訪問(wèn)量為5000萬(wàn),對(duì)數(shù)據(jù)庫(kù)的讀寫操作的比例超過(guò)10:1,你如何設(shè)計(jì)該系統(tǒng),以確保其系統(tǒng)高效,穩(wěn)定的運(yùn)行?
提示:可以從數(shù)據(jù)庫(kù)設(shè)計(jì),系統(tǒng)框架,及網(wǎng)絡(luò)架構(gòu)方面進(jìn)行描述,可以自由發(fā)揮。
6、你經(jīng)常去那些網(wǎng)站?有沒(méi)有自己的博客或git 開(kāi)源項(xiàng)目。
/ 1
第三篇:PHP面試題(一)
PHP程序員面試題
1.在PHP中,當(dāng)前腳本的名稱(不包括路徑和查詢字符串)記錄在預(yù)定義變量(1)中;而鏈接到當(dāng)前頁(yè)面的的前一頁(yè)面URL記錄在預(yù)定義變量(2)中 ”;//鏈接到當(dāng)前頁(yè)面的前一頁(yè)面的 URL 地址: echo $_SERVER['HTTP_REFERER'].“
”;
//其它的見(jiàn)參考手冊(cè):語(yǔ)言參考》變量》預(yù)定義變量
//前執(zhí)行腳本的絕對(duì)路徑名:D:Inetpub,如何得到它的內(nèi)容?($1分)
//需要讀取的page地址
$http_page_url=“http://”;//打開(kāi)遠(yuǎn)程文件
$read_file=fopen($http_page_url,“rb”);if(!feof($read_file)){ //讀取遠(yuǎn)程文件 $file_stream = “";do { $data = fread($read_file, 8192);if(strlen($data)== 0){ break;} $file_stream.= $data;} while(true);}
echo $file_stream;//輸出內(nèi)容
對(duì) PHP 5 及更高版本可以:
$handle = fopen(”http://“, ”rb“);
$contents = stream_get_contents($handle);
fclose($handle);
echo $contents;?>
最簡(jiǎn)單的方法是調(diào)用函數(shù):
print file_get_contents('http://');
?>
18、在HTTP 1.0中,狀態(tài)碼401的含義是(?);如果返回“找不到文件”的提示,則可用 header 函數(shù),其語(yǔ)句為(?);(2分)
狀態(tài)值為401,代表未被授權(quán);header(”Location: http://代碼的辦法。(1分)
1.echo ‘’;直接輸出
2.require include 包含進(jìn)來(lái)一段html代碼
3.由XML文件得到
36、下面哪個(gè)函數(shù)可以打開(kāi)一個(gè)文件,以對(duì)文件進(jìn)行讀和寫操作?(1分)(a)fget()(b)file_open()(c)fopen()(d)open_file()
(c)是正確的
37、下面哪個(gè)選項(xiàng)沒(méi)有將 john 添加到users 數(shù)組中?(1分)(a)$users[] = ‘john’;
(b)array_add($users,’john’);
(c)array_push($users,‘john’);(d)$users ||= ‘john’;
(b)(d)均是錯(cuò)誤的寫法
38、下面的程序會(huì)輸入是否?(1分)$num = 10;function multiply(){ $num = $num * 10;} multiply();echo $num;?> 輸出 10
39、使用php寫一段簡(jiǎn)單查詢,查出所有姓名為“張三”的內(nèi)容并打印出來(lái)(2分)表名User Name Tel Content Date 張三 *** 大專畢業(yè) 2006-10-11 張三 *** 本科畢業(yè) 2006-10-15 張四 021-55665566 中專畢業(yè) 2006-10-15
請(qǐng)根據(jù)上面的題目完成代碼:
$mysql_db=mysql_connect(“l(fā)ocal”,“root”,“pass”);@mysql_select_db(“DB”,$mysql_db);
$result=mysql_query(“select * from User where Name='張三'”);while($row=mysql_fetch_array($result)){ echo $row['Name'].$row['Tel'].$row['Content'].$row['Date'];echo “ ”;}
40、如何使用下面的類,并解釋下面什么意思?(3)class test{ function Get_test($num){ $num=md5(md5($num).“En”);return $num;} }
雙重md5加密
$testObject = new test();$encryption = $testObject->Get_test(“xiaotian_ls”);
41、寫出 SQL語(yǔ)句的格式 : 插入,更新,刪除(4分)表名User Name Tel Content Date 張三 *** 大專畢業(yè) 2006-10-11 張三 *** 本科畢業(yè) 2006-10-15 張四 021-55665566 中專畢業(yè) 2006-10-15(a)有一新記錄(小王 *** 高中畢業(yè) 2007-05-06)請(qǐng)用SQL語(yǔ)句新增至表中
Insert INTO User('Name','Tel','Content','Date')VALUES('小王','***','高中畢業(yè)','2007-05-06')(b)請(qǐng)用sql語(yǔ)句把張三的時(shí)間更新成為當(dāng)前系統(tǒng)時(shí)間
Update User SET Date=DATE_FORMAT(NOW(),'%Y-%m-%d')Where Name='張三'(c)請(qǐng)寫出刪除名為張四的全部記錄
Delete FROM User Where Name='張四'
42、請(qǐng)寫出數(shù)據(jù)類型(int char varchar datetime text)的意思;請(qǐng)問(wèn)varchar和char有什么區(qū)別(2分)
int 數(shù)值類型 char 固定長(zhǎng)度字符串 varchar 可變長(zhǎng)字符串 datetime 日期時(shí)間型 text 字符字符串
char列的長(zhǎng)度固定為創(chuàng)建表時(shí)聲明的長(zhǎng)度.varchar列中的值為可變長(zhǎng)字符串.43、MySQ自增類型(通常為表ID字段)必需將其設(shè)為(?)字段(1分)
AUTO_INCREMENT
44、寫出以下程序的輸出結(jié)果(1分)$b=201;$c=40;$a=$b>$c?4:5;echo $a;?> 4
45、檢測(cè)一個(gè)變量是否有設(shè)置的函數(shù)是否?是否為空的函數(shù)是?(2分)
isset($a)empty($a)
46、取得查詢結(jié)果集總數(shù)的函數(shù)是?(1分)
mysql_num_rows($res);
47、$arr = array('james', 'tom', 'symfony');請(qǐng)打印出第一個(gè)元素的值(1分)
echo $arr[0];
48、請(qǐng)將47題的數(shù)組的值用','號(hào)分隔并合并成字串輸出(1分)
echo $arr[0].$arr[1].$arr[2];
49、$a = 'abcdef';請(qǐng)取出$a的值并打印出第一個(gè)字母(1分)
echo $a{0};
50、PHP可以和sql server/oracle等數(shù)據(jù)庫(kù)連接嗎?(1分)可以
51、請(qǐng)寫出PHP5權(quán)限控制修飾符(3分)
private protected public
52、請(qǐng)寫出php5的構(gòu)造函數(shù)和析構(gòu)函數(shù)(2分)
__construct __destruct
53、以下請(qǐng)用PHPMYADMIN完成
(一)創(chuàng)建新聞發(fā)布系統(tǒng),表名為message有如下字段(3分)id 文章id title 文章標(biāo)題 content 文章內(nèi)容
category_id 文章分類id hits 點(diǎn)擊量
Create TABLE 'message'('id' int(11)NOT NULL auto_increment, 'title' varchar(200)default NULL, 'content' blob, 'category_id' int(11)default NULL, 'hits' int(11)default NULL, PRIMARY KEY('id'))ENGINE=InnoDB DEFAULT CHARSET=utf8(二)同樣上述新聞發(fā)布系統(tǒng):表comment記錄用戶回復(fù)內(nèi)容,字段如下(4分)comment_id 回復(fù)id id 文章id,關(guān)聯(lián)message表中的id comment_content 回復(fù)內(nèi)容
現(xiàn)通過(guò)查詢數(shù)據(jù)庫(kù)需要得到以下格式的文章標(biāo)題列表,并按照回復(fù)數(shù)量排序,回復(fù)最高的排在最前面
文章id 文章標(biāo)題 點(diǎn)擊量 回復(fù)數(shù)量
用一個(gè)SQL語(yǔ)句完成上述查詢,如果文章沒(méi)有回復(fù)則回復(fù)數(shù)量顯示為0
Select message.id id,message.title title,IF(message.`hits` IS NULL,0,message.`hits`)hits,IF(comment.`id` is NULL,0,count(*))number FROM message LEFT JOIN comment ON message.id=comment.id GROUP BY message.`id`
(三)上述內(nèi)容管理系統(tǒng),表category保存分類信息,字段如下(3分)category_id int(4)not null auto_increment;categroy_name varchar(40)not null;用戶輸入文章時(shí),通過(guò)選擇下拉菜單選定文章分類 寫出如何實(shí)現(xiàn)這個(gè)下拉菜單
function categoryList(){ $result=mysql_query(“select category_id,categroy_name from category”)or die(“Invalid query: ”.mysql_error());print(“n”);while($rowArray=mysql_fetch_array($result)){ print(“".$rowArray['categroy_name'].”n“);} print(”");}
第四篇:php極品面試題
求職與招聘 往往少不了面試與筆試,作為一個(gè)php程序員、多多少少都會(huì)有類似的經(jīng)歷……以下是本人收集并整理的PHP面試題目,希望對(duì)同行們有所幫助,找到一份合適的php開(kāi)發(fā)工作!(共三節(jié))
以下是面試的題目
(一),下一篇:經(jīng)典面試題(PHP基礎(chǔ)型III)附答案 PHP已經(jīng)賦予答案:
12、在PHP中,heredoc是一種特殊的字符串,它的結(jié)束標(biāo)志必須?(1分)PHPMA.COM 在大部分語(yǔ)言里,雙引號(hào)是字符串,單引號(hào)是字符。但是在PHP里,字符串的表現(xiàn)形式有3種。即: 單引號(hào) 雙引號(hào)
定界符(heredoc syntax)
看見(jiàn)了吧,單引號(hào)居然可以用來(lái)表示字符串。那么如果我想表示單引號(hào)怎么辦?和大多數(shù)語(yǔ)言一樣,使用轉(zhuǎn)義符號(hào)吧。即反斜線‖".那么使用單引號(hào)和雙引號(hào)有什么區(qū)別呢?我的觀點(diǎn)是沒(méi)有多大區(qū)別。唯一的區(qū)別就是雙引號(hào)可以應(yīng)用更多的轉(zhuǎn)義符。
讓我們定界符吧。它的語(yǔ)法是‖<<<‖。用法是在其后提供一個(gè)標(biāo)識(shí)符,然后在標(biāo)識(shí)符后提供字符串,再在字符串后提供此標(biāo)識(shí)符來(lái)結(jié)尾。例如: 注意,這里的提供的標(biāo)志符是EOD,中間的是字符串。PHPMA.COM << 結(jié)束標(biāo)志必須頂格寫,并且要有分號(hào)結(jié)束 13、談?wù)刟sp,php,jsp的優(yōu)缺點(diǎn)(1分)–(具體請(qǐng)自己搜索) 14、談?wù)剬?duì)mvc的認(rèn)識(shí)(1分)MVC(Model/View/Controller)模式包括三類對(duì)象。Model是應(yīng)用對(duì)象,View是它在屏幕上的表示,Controller定義用戶界面對(duì)用戶輸入的響應(yīng)方式。 模型-視圖-控制器(MVC)是80年代Smalltalk-80出現(xiàn)的一種軟件設(shè)計(jì)模式,現(xiàn)在已經(jīng)被廣泛的使用。 1)模型(Model) 模型是應(yīng)用程序的主體部分。模型表示業(yè)務(wù)數(shù)據(jù),或者業(yè)務(wù)邏輯.2)視圖(View) 視圖是應(yīng)用程序中用戶界面相關(guān)的部分,是用戶看到并與之交互的界面。3)控制器(controller)控制器工作就是根據(jù)用戶的輸入,控制用戶界面數(shù)據(jù)顯示和更新model對(duì)象狀態(tài)。PHPMA.COM ——————————————————————- 15、寫出發(fā)貼數(shù)最多的十個(gè)人名字的SQL,利用下表:members(id,username,posts,pass,email)(2分)select members.username from members order by posts DESC limit 10 16.請(qǐng)說(shuō)明php中傳值與傳引用的區(qū)別。什么時(shí)候傳值什么時(shí)候傳引用?(2分)按值傳遞:函數(shù)范圍內(nèi)對(duì)值的任何改變?cè)诤瘮?shù)外部都會(huì)被忽略 按引用傳遞:函數(shù)范圍內(nèi)對(duì)值的任何改變?cè)诤瘮?shù)外部也能反映出這些修改phpma.com PHPma 優(yōu)缺點(diǎn):按值傳遞時(shí),php必須復(fù)制值。特別是對(duì)于大型的字符串和對(duì)象來(lái)說(shuō),這將會(huì)是一個(gè)代價(jià)很大的操作。 按引用傳遞則不需要復(fù)制值,對(duì)于性能提高很有好處。17.在PHP中error_reporting這個(gè)函數(shù)有什么作用?(1分)用來(lái)配置錯(cuò)誤信息回報(bào)的等級(jí) 18.請(qǐng)寫一個(gè)函數(shù)驗(yàn)證電子郵件的格式是否正確(2分)//if the email address is valid, return true,else return false function validateEmail($email){ if(eregi(?^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$‘,$email)){ return true;}else{ return false;} } 19.簡(jiǎn)述如何得到當(dāng)前執(zhí)行腳本路徑,包括所得到參數(shù)。(2分)echo $_SERVER['SCRIPT_FILENAME'].‖?‖.$_SERVER['QUERY_STRING'];20.如何修改SESSION的生存時(shí)間.(1分)setcookie()或 session_set_cookie_params($lifeTime) ——————————————————————– 21、JS表單彈出對(duì)話框函數(shù)是?獲得輸入焦點(diǎn)函數(shù)是?(2分)alert(),prompt(),confirm()focus() 22、JS的轉(zhuǎn)向函數(shù)是?怎么引入一個(gè)外部JS文件?(2分)window.location.href 23、foo()和@foo()之間有什么區(qū)別?(1分)PHP 支持一個(gè)錯(cuò)誤控制運(yùn)算符:@。當(dāng)將其放置在一個(gè) PHP 表達(dá)式之前,該表達(dá)式可能產(chǎn)生的任何錯(cuò)誤信息都被忽略掉。 注 意: @ 運(yùn)算符只對(duì)表達(dá)式有效。對(duì)新手來(lái)說(shuō)一個(gè)簡(jiǎn)單的規(guī)則就是:如果能從某處得到值,就能在它前面加上 @ 運(yùn)算符。例如,可以把它放在變量,函數(shù)和include()調(diào)用,常量,等等之前。不能把它放在函數(shù)或類的定義之前,也不能用于條件結(jié)構(gòu)例如 if 和 foreach 等。 24、如何聲明一個(gè)名為‖myclass‖的沒(méi)有方法和屬性的類?(1分)class myclass{}; 25、如何實(shí)例化一個(gè)名為‖myclass‖的對(duì)象?(1分)$newmyclass = new myclass(); 26、你如何訪問(wèn)和設(shè)置一個(gè)類的屬性?(2分)通過(guò)-〉 $newmyclass = new myclass();$temp=$newmyclass->testvalue;$newmyclass->testvalue=‖a‖; 27、mysql_fetch_row()和mysql_fetch_array之間有什么區(qū)別?(1分)mysql_fetch_row — 從結(jié)果集中取得一行作為枚舉數(shù)組 mysql_fetch_array — 從結(jié)果集中取得一行作為關(guān)聯(lián)數(shù)組,或數(shù)字?jǐn)?shù)組,或二者兼有 ——————————————————————– 28、GD庫(kù)是做什么用的?(1分)GD庫(kù)提供了一系列用來(lái)處理圖片的API,使用GD庫(kù)可以處理圖片,或者生成圖片。在網(wǎng)站上GD庫(kù)通常用來(lái)生成縮略圖或者用來(lái)對(duì)圖片加水印或者對(duì)網(wǎng)站數(shù)據(jù)生成報(bào)表。 29、指出一些在PHP輸入一段HTML代碼的辦法。(1分)print(― echo ― 30、下面哪個(gè)函數(shù)可以打開(kāi)一個(gè)文件,以對(duì)文件進(jìn)行讀和寫操作?(1分)(c)(a)fget()(b)file_open()(c)fopen()(d)open_file() 31、下面哪個(gè)選項(xiàng)沒(méi)有將 john 添加到users 數(shù)組中?(1分)(b)(c)(d)(a)$users[] = ?john‘; (b)array_add($users,‘john‘);//這個(gè)選項(xiàng)不敢確定,但是測(cè)試著沒(méi)有這個(gè)函數(shù)(c)array_push($users,?john‘);(d)$users ||= ?john‘; 32、下面的程序會(huì)輸入是否?(1分) 否,局部變量 33、使用php寫一段簡(jiǎn)單查詢,查出所有姓名為―張三‖的內(nèi)容并打印出來(lái)(2分)表名User Name Tel Content Date 張三 *** 大專畢業(yè) 2006-10-11 張三 *** 本科畢業(yè) 2006-10-15 張四 021-55665566 中專畢業(yè) 2006-10-15 請(qǐng)根據(jù)上面的題目完成代碼: $mysql_db=mysql_connect(―local‖,‖root‖,‖pass‖); @mysql_select_db(―DB‖,$mysql_db); $result=mysql_query(―select * from User where Name=‘張三‘‖);while($row=mysql_fetch_array($result)){ echo $row['Name'].$row['Tel'].$row['Content'].$row['Date'];echo ― 34、如何使用下面的類,并解釋下面什么意思?(3)class test{ function Get_test($num){ $num=md5(md5($num).‖En‖);return $num;} } 雙重md5加密 $testObject = new test();$encryption = $testObject->Get_test(―xiaotian_ls‖); PHP程序員面試題 一、選擇題 1、下列不屬于PHP的開(kāi)始結(jié)束標(biāo)記的是:() A、 B、?> C、<%%> D、<> 2、下列程序的輸出結(jié)果為() function test($a){ $a=’456’; } $a=’123’; test($a); echo $a++; ?> A、456 B、123 C、124 D、會(huì)報(bào)錯(cuò) 4、下列代碼的輸出結(jié)果為() function test($i) { return++$i+5; } echo test(1); ?> A、6 B、7 C、8 D、空 5、下列代碼的輸出結(jié)果為() $a=’123’; $b=&$a; $a=’789’; $b=’456’; echo $a; ?> A、123 B、456 C、789 D、空 二、簡(jiǎn)答題: 1、試寫一個(gè)PHP腳本對(duì)數(shù)組進(jìn)行排序,要求將數(shù)字?jǐn)?shù)組中所有奇數(shù)放在左邊,0放在中間,偶數(shù)放在右 邊。如數(shù)組:array(23, 94, 0, 2, 56, 10, 77, 231, 75, 48) 2、表uesr,有如下幾個(gè)字段:id,username,userpwd,regtime。 (1)、試寫出查詢?cè)摫硭杏涗浀膕ql語(yǔ)句 (2)、要將id為5的記錄中,username字段的值更新為“小王”,請(qǐng)寫出sql語(yǔ)句 (3)、要?jiǎng)h除id為10的記錄,請(qǐng)寫出sql語(yǔ)句 (4)、現(xiàn)在要新增一條記錄。username的值為:小李;userpwd的值為:123456;regtime的值為:2012-09-01。請(qǐng)寫出sql語(yǔ)句 3、試寫一個(gè)PHP函數(shù)遍歷一個(gè)文件夾【注:只需輸出該目錄的文件和子目錄,無(wú)須對(duì)子目錄再進(jìn)行遍歷】 4、請(qǐng)根據(jù)你的理解設(shè)計(jì)一個(gè)站內(nèi)信系統(tǒng)的數(shù)據(jù)庫(kù),并簡(jiǎn)要說(shuō)明字段意義和腳本實(shí)現(xiàn)細(xì)節(jié) 5、請(qǐng)使用PHP寫一個(gè)文件上傳腳本,要求只能上傳gif/jpeg圖像,并且圖像大小不能超過(guò)1024KB。 三、附加題 試述你對(duì)程序員職業(yè)的理解以及你的工作習(xí)慣和為人處事的態(tài)度。【提示:回答本題時(shí)應(yīng)該實(shí)事求是,盡量向面試官表現(xiàn)真實(shí)的自我】
‖);
‖;
‖;}第五篇:PHP程序員面試題