首頁  >  文章  >  後端開發  >  最全最詳細的PHP面試題(附答案)

最全最詳細的PHP面試題(附答案)

不言
不言原創
2018-05-14 14:24:04162214瀏覽

這篇文章介紹的內容是關於最全最詳細的PHP面試題(有答案),有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

#相關推薦:2019年PHP面試題大總結(收藏)

1、__FILE__表示什麼意思? (5分)
檔案的完整路徑和檔名。如果用在包含檔案中,則傳回包含檔案名稱。自 PHP 4.0.2 起,__FILE__ 總是包含一個絕對路徑,而在此之前的版本有時會包含一個相對路徑。
2、如何取得客戶端的IP位址? (5分)

$_SERVER[‘REMOTE_ADDR’]

3、寫出使用header函數跳轉頁面的語句(5分)

Header(‘location:index.php’);

4、$str是一段html文本,使用正規表示式移除其中的所有js腳本(5分)

$pattern = ‘/<script.*>\.+<\/script>/’;
Preg_replace($pattern,’’,$str);

5、寫出將一個陣列裡的空值去掉的語句(5分)

$arr = array(‘’,1,2,3,’’,19);

第一種方法:

$array1 = array(&#39;  &#39;,1,&#39;&#39;,2,3);
print_r(array_filter($array1, "del"));
function del($var)
{
       return(trim($var)); 
}

第二種方法:

$arr=array("",1,2,3,"");
$ptn="/\S+/i";
print_r(preg_grep($ptn,$arr));

6、寫出取得目前時間戳記的函數,及列印前一天的時間的方法(格式:年-月-日 時:分:秒) (5分)

Time();
Date(“Y-m-d H:i:s”,Strtotime(“-1 day”));

7、寫出php進行編碼轉換的函數(5分)

Iconv(‘utf-8’,’gb2312’,$str);

8、$str = “1,3,5,7,9,10,20”,使用什麼函數可以將字串str轉換成包含各個數字的陣列? (5分)

$arr = explode(“,”,$str);

9、serialize() /unserialize()函數的功能(5分)
serialize()和unserialize()在php手冊上的解釋是:
serialize — 產生一個可儲存的值的表示,傳回值為字串,此字串包含了表示 value 的位元組流,並未遺失其類型和結構,可以儲存於任何地方。
unserialize — 從已儲存的表示中建立 PHP 的值
具體用法:

$arr = array(“测试1″,”测试2″,”测试3″);//数组
$sarr = serialize($arr);//产生一个可存储的值(用于存储)

//用任意方法(例如:你要是吧$sarr存在一個文字檔案中你就可以用file_get_contents取得)得到儲存的值保存在$newarr中;

$unsarr=unserialize($newarr);//从已存储的表示中创建 PHP 的值

10、寫出一個函數,參數為年份和月份,輸出結果為指定月的天數(5分)

Function day_count($year,$month){
Echo date(“t”,strtotime($year.”-”.$month.”-1”));
}

11、一個檔案的路徑為/wwwroot/include/page.class.php,寫出取得該檔案副檔名的方法(5分)

$arr = pathinfo(“/wwwroot/include/page.class.php”);
$str = substr($arr[‘basename’],strrpos($arr[‘basename’],’.’));

12、你使用過哪一種PHP的模板引擎? (5分)
Smarty,thinkphp自帶的模板引擎
13、請簡單寫一個類,實例化這個類,並寫出調用該類的屬性和方法的語句(5分)

Class myclass{
Public $aaa;
Public $bbb;
Public function myfun(){
Echo “this is my function”;
}
}
$myclass = new myclass();
$myclass->$aaa;
$myclass->myfun();

14、本機mysql資料庫db_test裡已建有表friend,資料庫的連線使用者為root,密碼為123
friend表格欄位為:id,name,age,gender,phone,email
請使用php連接mysql,選擇出friend表裡age > 20的所有記錄列印結果,並統計出查詢的結果總數。 (5分)

<?php
$link = Mysql_connect(“localhost”,”root”,”123”) or die(“数据库连接失败!”);
Mysql_select_db(“db_test”,$link) or die(“选择数据库失败!”);
$sql = “select id,name,age,gender,phone,email from friend where age>20”;
$result = mysql_query($sql);
$count = mysql_num_rows($result);
While($row = mysql_fetch_assoc($result)){
Echo $row[‘id’];
….
}

15、以下有兩個表
user表 字段id (int),name (varchar)
score表 字段uid (int),subject (varchar ) ,score (int)
score表的uid欄位與user表的id欄位關聯
要求寫出以下的sql語句
1)在user表裡新插入一筆記錄,在score表裡插入與新加入的記錄關聯的兩筆記錄(5分)
2)取得score表裡uid為2的用戶score最高的5筆記錄(5分)
3)使用聯合查詢取得name為“張三」的用戶的總分(5分)
4)刪除name為「李四」的用戶,包括分數記錄(5分)
5)清空score表(5分)
6 )刪除user表(5分)

1). mysql_query(“insert into user(name) values(‘test’)”);
$id = mysql_insert_id();
Mysql_query(“insert into score(uid,subjext,score) values(“.$id.”,’english’,’99’)”);
2).$sql = select uid,sunjext,score from score where uid=2 order by score desc limit 0,5;
3).select s.score from score s RIGHT JOIN user u ON u.id=s.uid where u.name=’张三;
4).delete from score where uid in(select id from user where name=’李四’);
Delete from user where name=’李四’;
5).delete from score;
6).drop table user;

相關推薦:

php面試題八之innoDB和myisam的差異

以上是最全最詳細的PHP面試題(附答案)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn