1. 程式人生 > >鄧_php面試【003】——完整版

鄧_php面試【003】——完整版

兩個 lower figure 有效 索引 哪裏 group by 小寫 正則表達式驗證

php面試題匯總四(基礎篇附答案)

1. 什麽事面向對象?主要特征是什麽?

面向對象是程序的一種設計方式,它利於提高程序的重用性,使程序結構更加清晰。主要特征:封裝、繼承、多態。

2. SESSION COOKIE的區別是什麽,請從協議,產生的原因與作用說明?

1、http無狀態協議,不能區分用戶是否是從同一個網站上來的,同一個用戶請求不同的頁面不能看做是同一個用戶。

2、SESSION存儲在服務器端,COOKIE保存在客戶端。Session比較安全,cookie用某些手段可以修改,不安全。Session依賴於cookie進行傳遞。

禁用cookie後,session不能正常使用。Session

的缺點:保存在服務器端,每次讀取都從服務器進行讀取,對服務器有資源消耗。Session保存在服務器端的文件或數據庫中,默認保存在文件中,文件路徑由php配置文件的session.save_path指定。Session文件是公有的。

3. HTTP 狀態中302403 500代碼含義?

一二三四五原則: 一. 消息系列 二成功系列 三. 重定向系列四. 請求錯誤系列 五. 服務器端錯誤系列

302:臨時轉移成功,請求的內容已轉移到新位置403:禁止訪問 500:服務器內部錯誤 401代表未授權。

4. Linux下建立壓縮包,解壓縮包的命令

Tar.gz:

打包:tar czf file.tar.gz file.txt

解壓:tar xzf file.tar.gz

Bz2:

打包:bzip2 [-k] 文件

解壓:bunzip2 [-k] 文件

Gzip(只對文件,不保留原文件)

打包:gzip file1.txt

解壓:gunzip file1.txt.gz

Zip: -r 對目錄

打包:zip file1.zip file1.txt

解壓:unzip file1.zip

5. 請寫出數據類型(int char varchar datetime text)的意思;請問 varchar char有什麽區別?

Int 整數char 定長字符 Varchar 變長字符 Datetime 日期時間型Text 文本型 Varchar

char的區別 char是固定長度的字符類型,分配多少空間,就占用多長空間。Varchar是可變長度的字符類型,內容有多大就占用多大的空間,能有效節省空間。由於varchar類型是可變的,所以在數據長度改變的時,服務器要進行額外的操作,所以效率比char類型低。

6. MyISAM InnoDB 的基本區別?索引結構如何實現?

MyISAM類型不支持事務,表鎖,易產生碎片,要經常優化,讀寫速度較快,而InnoDB類型支持事務,行鎖,有崩潰恢復能力。讀寫速度比MyISAM慢。

創建索引:alerttable tablename add index (`字段名`)

7. 不使用cookie向客戶端發送一個cookie.

理解:session_start()開啟時,生成一個常量 SID,當COOKIE開啟時,這個常量為空,當COOKIE關閉時,這個常量中存儲了PHPSESSID的值。通過在URL後加一個SID參數來傳遞SESSIONID的值,從而使客戶端頁面可以使用SESSION裏面的值。當客戶端開啟COOKIE和服務器端開啟SESSION時。瀏覽器第一次請求,服務器會向瀏覽器端發送一個COOKIE裏面存儲SESSIONID.當瀏覽器第二次請求時,會把已存在

8. isset() empty() 區別

Isset判斷變量是否存在,可以傳入多個變量,若其中一個變量不存在則返回假,empty判斷變量是否為空為假,只可傳一個變量,如果為空為假則返回真。

9. 如何在頁面之間傳遞變量(至少兩種方式) ? GET,POST,COOKIE,SESSION,隱藏表單

1. 寫出匹配URL的正則表達式.

‘/^(https?|ftps?):\/\/(www)\.([^\.\/]+)\.(com|cn|org)(\/[\w-\.\/\?\%\&\=]*)?/i’

2. 請寫出常見的排序算法,並用PHP實現冒泡排序,將數組$a = array()按照從小到大的方式進行排序。

常見的排序算法: 冒泡排序法、快速排序法、簡單選擇排序法、堆排序法、直接插入排序法、希爾排序法、合並排序法。

冒泡排序法的基本思想是:對待排序記錄關鍵字從後往前(逆序)進行多遍掃描,當發現相鄰兩個關鍵字的次序與排序要求的規則不符時,就將這兩個記錄進行交換。這樣,關鍵字較小的記錄將逐漸從後面向前面移動,就象氣泡在水中向上浮一樣,所以該算法也稱為氣泡排序法。

// 冒泡排序法

Function mysort($arr){

For($i=0;$i<count($arr); $i++){

For($j=0; $j<count($arr)-1-$i; $j++){

If($arr[$j]> $arr[$j+1]){

$tmp=$arr[$j];

$arr[$j]=$arr[$j+1];

$arr[$j+1]=$tmp;

}

}

}

Return$arr;

}

$arr=array(3,2,1);

print_r(mysort($arr));

3. 請說明 PHP 中傳值與傳引用的區別。什麽時候傳值什麽時候傳引用?
按值傳遞:函數範圍內對值的任何改變在函數外部都會被忽略

按引用傳遞:函數範圍內對值的任何改變在函數外部也能反映出這些修改

優缺點:按值傳遞時,php必須復制值。特別是對於大型的字符串和對象來說,這將會是一個代價很大的操作。按引用傳遞則不需要復制值,對於性能提高很有好處。


PHPerror_reporting這個函數有什麽作用?
設置 PHP的報錯級別並返回當前級別。


請用正則表達式(Regular Expression)寫一個函數驗證電子郵件的格式是否正確。
if(isset($_POST[‘action‘]) && $_POST[‘action‘]==’submitted’){
$email=$_POST[‘email‘];
if(!preg_match(“/^[0-9a-zA-Z-]+@[0-9a-zA-Z-]+(\.[0-9a-zA-Z-]+){1,3}$/”,$email)){
echo“電子郵件檢測失敗”;
}else{
echo“電子郵件檢測成功”;
}
}

寫一個二維數組排序算法函數,能夠具有通用性,可以調用php內置函數(array_multisort())

//二維數組排序, $arr是數據,$keys是排序的健值,$order是排序規則,1是升序,0是降序

function array_sort($arr, $keys, $order=0) {

if(!is_array($arr)) {

return false;

}

$keysvalue =array();

foreach($arr as$key => $val) {

$keysvalue[$key] = $val[$keys];

}

if($order == 0){

asort($keysvalue);

}else {

arsort($keysvalue);

}

reset($keysvalue);

foreach($keysvalueas $key => $vals) {

$keysort[$key] = $key;

}

$new_array =array();

foreach($keysortas $key => $val) {

$new_array[$key] = $arr[$val];

}

return $new_array;

}

請以空格作為間隔,拆分字符串’Apple Orange BananaStrawberry’,組成數組$fruit

* 數組中所有元素都用小寫字母,並按照字母先後次序排序

class sort {

private $str;

public function__construct($str) {

$this->str=strtolower($str);

}

private functionexplodes() {

if(empty($this->str)) returnarray();

$arr=explode("",$this->str);

return is_array($arr)?$arr:array($arr);

}

public functionsort() {

$explode=$this->explodes();

sort($explode);

return $explode;

}

}

$str=‘Apple Orange Banana Strawberry‘;

$sortob=new sort($str);

var_dump($sortob->sort());

對於用戶輸入一串字符串$string,要求$string中只能包含大於0的數字和英文逗號,請用正則表達式驗證,對於不符合要求的$string返回出錯信息

class regx {

public staticfunction check($str) {

if(preg_match("/^([1-9,])+$/",$str)){

return true;

}

return false;

}

}

$str="12345,6";

if(regx::check($str)) {

echo "suc";

} else {

echo "fail";

}

windows平臺, Apache Http Server啟動失敗, 排錯思路是什麽?

檢查apache使用的80端口是否被占用,如果被占用,先停止占用80端口的服務,然後啟動apache服務器


PHP session擴展默認將session數據儲存在哪裏? D

A) SQLite Database

B) MySQL Database

C) Shared Memory

D) File System

E) Session Server

如果你想要自動加載類,下面哪種函數聲明是正確的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)

PHP程序使用utf-8編碼, 以下程序輸出結果是什麽? B
<?php
$str = ’hello你好世界’;

echo strlen($str);

?>

A) 9 B) 13(gbk) C) 18 D) 17(utf8)

你所知道的php數組相關的函數?

array()----創建數組

array_combine()----通過合並兩個數組來創建一個新數組

range()----創建並返回一個包含指定範圍的元素的數組

compact()----建立一個數組

array_chunk()----將一個數組分割成多個

array_merge()----把兩個或多個數組合並成一個數組

array_slice()----在數組中根據條件取出一段值

array_diff()----返回兩個數組的差集數組

array_intersect()----計算數組的交集

array_search()----在數組中搜索給定的值

array_splice()----移除數組的一部分且替代它

array_key_exists()----判斷某個數組中是否存在指定的key

shuffle()----把數組中的元素按隨機順序重新排列

array_flip()----交換數組中的鍵和值

array_reverse()----將原數組中的元素順序翻轉,創建新的數組並返回

array_unique()----移除數組中重復的值

php讀取文件內容的幾種方法和函數?

打開文件,然後讀取。Fopen()fread()

打開讀取一次完成file_get_contents()

以下程序,變量str什麽值的情況下輸入111?

if( ! $str ) { echo 111; }

在$str值為:0,’0′,false,null,”"

你所知道的PHP的一些技術(smarty等)?

Smarty,jquery,ajax,memcache,div+css,js,mysqli,pdo,svn,thinkphp,brophp,yii

你所熟悉的PHP論壇系統有哪些?

Discuz

你所熟悉的PHP商城系統有哪些?

Ecshop

你所熟悉的PHP開發框架有哪些?

Brophp,thinkphp

說說你對緩存技術的了解?

1、緩存技術是將動態內容緩存到文件中,在一定時間內訪問動態頁面直接調用緩存文件,而不必重新訪問數據庫。

2、使用memcache可以做緩存。

你所知道的設計模式有哪些?

工廠模式、策略模式、單元素模式、觀察者模式、命令鏈模式

說說你對代碼管理的了解?常使用那些代碼版本控制軟件?

通常一個項目是由一個團隊去開發,每個人將自己寫好的代碼提交到版本服務器,由項目負責人按照版本進行管理,方便版本的控制,提高開發效率,保證需要時可以回到舊版本。

常用的版本控制器:SVN

說說你對SVN的了解?優缺點?

SVN是一種版本控制器,程序員開發的代碼遞交到版本服務器進行集中管理。

SVN的優點:代碼進行集中管理,版本控制容易,操作比較簡單,權限控制方便。

缺點:不能隨意修改服務器項目文件夾。

怎麽找到PHP.ini的路徑?

一般都在php的安裝目錄下,或者window系統的windows目錄下。

PHP加速模式/擴展? PHP調試模式/工具?

Zend Optimizer加速擴展

調試工具:xdebug

你常用到的mysql命令?

Show databases

Show tables

Insert into 表名()values()

Update 表名 set字段=值 where ...

Delete from 表名where ...

Select * from 表名where 條件 order by ... Desc/asc limit ... Group by ... Having ...

進入mysql管理命令行的命令?

Mysql -uroot -p回車密碼

show databases; 這個命令的作用?

顯示當前mysql服務器中有哪些數據庫

show create database mysql; 這個命令的作用?

顯示創建數據庫的sql語句

show create table user; 這個命令的作用?

顯示創建表的sql語句

desc user; 這個命令的作用?

查詢user表的結構

explain select * from user; 這個命令的作用?

獲取select相關信息

show processlist; 這個命令的作用?

顯示哪些線程正在運行

SHOW VARIABLES; 這個命令的作用?

顯示系統變量和值

SHOW VARIABLES like ’%conn%’; 這個命令的作用?

顯示系統變量名包含conn的值

LEFT JOIN 寫一個SQL語句?

SELECTA.id,A.class FROM A LEFT JOIN B ON A.cid=B.id

in, not ni, exist, not exist的作用和區別?

in在什麽中

Not in 不在什麽中

Exists 存在

Not exists 不存在

怎麽找到數據庫的配置文件路徑?

在數據庫安裝目錄下,my.ini

簡述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安裝

簡述Linux下安裝Mysql的過程?

Groupadd mysql 添加一個用戶組mysql

Useradd -gmysql mysql 添加一個mysql用戶指定分組為mysql

Cd /lamp/mysql 進入mysql目錄

./configure–prefix=/usr/local/mysql/ –with-extra-charsets=all

Make

Make all

簡述Linux下安裝apache的過程?

Cd /lamp/httpd 進去apache軟件目錄

./configure–prefix=/usr/local/apache2/ –sysconfdir=/etc/httpd/ –with-included-apr

Make

Make all

HTML/CSS/DIV/Javascritp

1. 設計一個頁面(4 div 第一個div 960px 居中;2-4div 3等分960px;)

<style>

Body{Text-align:center; Margin:0; Padding:0; }

#box{Width:960px; Margin:0 auto; }

.small{Width:320px; Float:left; }

</style>

<divid=’box’>

<divclass=’small’></div>

<divclass=’small’></div>

<divclass=’small’></div>

</div>

javascript取得一個input的值?取得一個input的屬性?

document.getElementById(‘name’).value;

document.getElementById(‘name’).type;

Jquery取得一個input的值?取得一個input的屬性?

$(“input[name=‘aa‘]“).val();

$(“input[name=‘aa‘]“).attr(‘type’);

請您寫一段ajax提交的js代碼,或者寫出ajax提交的過程邏輯。

var xmlhttp;

if(window.XMLHttpRquest){

xmlhttp=newXMLHttpRequest();

}elseif(window.ActiveXObject){

xmlhttp=newActiveXObject(‘Microsoft.XMLHTTP’);

}

xmlhttp.open(‘GET’,’1.php?aa=name’,true);

xmlhttp.onreadystatechange=function(){

if(xmlhttp.readyState==4){

if(xmlhttp.status==200){

var text=xmlhttp.responseText;

}

}

}

xmlhttp.send(null);

簡述Cookie的設置及獲取過程

設置COOKIE的值:

Setcookie(名稱,值,保存時間,有效域);

獲取值:$_COOKIE[‘名稱‘];

面向對象中接口和抽象類的區別及應用場景?

1、有抽象方法的類叫做抽象類,抽象類中不一定只有抽象方法,抽象方法必須使用abstract關鍵字定義。

2、接口中全部是抽象方法,方法不用使用abstract定義。

3、當多個同類的類要設計一個上層,通常設計為抽象類,當多個異構的類要設計一個上層,通常設計為接口。

用面向對象來實現A對象繼承BC對象

Interface B{... }

Interface C{... }

Class Aimplements B,C{ ... }

鄧_php面試【003】——完整版