第一篇:php程序員 一度搜索面試題
一.必答題
1.(算法題)有1~5000一組亂序數(shù)列,請(qǐng)使用偽代碼對(duì)該數(shù)進(jìn)行排列
2.(算法題)公雞3元每只,母雞5元每只,小雞1元3只,一百元錢買一百只雞,請(qǐng)用偽代碼寫出求公雞,母雞和小雞的數(shù)目
3.(算法題)1,1,2,3,5,8,13,21,34.。。求第30位的數(shù)是多少,請(qǐng)用偽代碼描述其實(shí)現(xiàn)方法
二.基礎(chǔ)選答題——一下題目任選三道做答
1.(基礎(chǔ)題)請(qǐng)描述你經(jīng)常使用的php函數(shù)及其主要作用(最少5個(gè))2.(基礎(chǔ)題)請(qǐng)描述一種你常用的開發(fā)框架(語言不限),主要使用方法。(如果框架是自己開發(fā)的,請(qǐng)用類圖大致描述框架結(jié)構(gòu))3.(基礎(chǔ)題)請(qǐng)描述一種你常用的ajax調(diào)用方法。4.(基礎(chǔ)題)請(qǐng)描述你常用的HTML標(biāo)記及其主要作用。(最少5種)5.(基礎(chǔ)題)請(qǐng)描述你常用的javascript函數(shù)。
三.論述與擴(kuò)展選答題——論述與擴(kuò)展題各選一道作答
1.(論述題)請(qǐng)用類屯舉例描述mvc結(jié)構(gòu)
2.(論述題)請(qǐng)用簡(jiǎn)單的語言描述一下HTTP協(xié)議
3.(擴(kuò)展題)請(qǐng)描述一下在linux下php的編譯過程 4.(擴(kuò)展題)請(qǐng)描述一下本地字節(jié)序于網(wǎng)絡(luò)字節(jié)序的區(qū)別
第二篇:PHP程序員面試題
北京融入網(wǎng)絡(luò)科技有限公司
PHP工程師面試題
1、請(qǐng)寫一個(gè)實(shí)現(xiàn)中文字串截取無亂碼的方法。(超出部分用’…..’替換)。
2、ThinkPHP框架中,下列定義有什么不同?
$userModel = M(“User”);
$userMode l= D(“User”);
3、如果讓你模擬登陸微信公眾平臺(tái)并設(shè)置微信的開發(fā)模式中的URL和Token,你會(huì)如何去做?(思路或代碼皆可)。
4、談?wù)剬?duì)你對(duì)PHP的認(rèn)識(shí)或你擅長(zhǎng)的技術(shù)。
5、假設(shè)有一個(gè)博客系統(tǒng),數(shù)據(jù)庫存儲(chǔ)采用mysql,用戶數(shù)量為1000萬,預(yù)計(jì)文章總數(shù)為10億,每天有至少10萬的更新量,每天訪問量為5000萬,對(duì)數(shù)據(jù)庫的讀寫操作的比例超過10:1,你如何設(shè)計(jì)該系統(tǒng),以確保其系統(tǒng)高效,穩(wěn)定的運(yùn)行?
提示:可以從數(shù)據(jù)庫設(shè)計(jì),系統(tǒng)框架,及網(wǎng)絡(luò)架構(gòu)方面進(jìn)行描述,可以自由發(fā)揮。
6、你經(jīng)常去那些網(wǎng)站?有沒有自己的博客或git 開源項(xiàng)目。
/ 1
第三篇:PHP程序員面試題
PHP程序員面試題
一、選擇題
1、下列不屬于PHP的開始結(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語句
(2)、要將id為5的記錄中,username字段的值更新為“小王”,請(qǐng)寫出sql語句
(3)、要?jiǎng)h除id為10的記錄,請(qǐng)寫出sql語句
(4)、現(xiàn)在要新增一條記錄。username的值為:小李;userpwd的值為:123456;regtime的值為:2012-09-01。請(qǐng)寫出sql語句
3、試寫一個(gè)PHP函數(shù)遍歷一個(gè)文件夾【注:只需輸出該目錄的文件和子目錄,無須對(duì)子目錄再進(jìn)行遍歷】
4、請(qǐng)根據(jù)你的理解設(shè)計(jì)一個(gè)站內(nèi)信系統(tǒng)的數(shù)據(jù)庫,并簡(jiǎn)要說明字段意義和腳本實(shí)現(xiàn)細(xì)節(jié)
5、請(qǐng)使用PHP寫一個(gè)文件上傳腳本,要求只能上傳gif/jpeg圖像,并且圖像大小不能超過1024KB。
三、附加題
試述你對(duì)程序員職業(yè)的理解以及你的工作習(xí)慣和為人處事的態(tài)度。【提示:回答本題時(shí)應(yīng)該實(shí)事求是,盡量向面試官表現(xiàn)真實(shí)的自我】
第四篇:PHP程序員面試題經(jīng)典及答案集錦
都是經(jīng)典
基礎(chǔ)題: 1.表單中 get與post提交方法的區(qū)別? 答:get是發(fā)送請(qǐng)求HTTP協(xié)議通過url參數(shù)傳遞進(jìn)行接收,而post是實(shí)體數(shù)據(jù),可以通過表單提交大量信息.2.session與cookie的區(qū)別? 答:session:儲(chǔ)存用戶訪問的全局唯一變量,存儲(chǔ)在服務(wù)器上的php指定的目錄中的(session_dir)的位置進(jìn)行的存放
cookie:用來存儲(chǔ)連續(xù)訪問一個(gè)頁面時(shí)所使用,是存儲(chǔ)在客戶端,對(duì)于Cookie來說是存儲(chǔ)在用戶WIN的Temp目錄中的。
兩者都可通過時(shí)間來設(shè)置時(shí)間長(zhǎng)短
3.數(shù)據(jù)庫中的事務(wù)是什么? 答:事務(wù)(transaction)是作為一個(gè)單元的一組有序的數(shù)據(jù)庫操作。如果組中的所有操作都成功,則認(rèn)為事務(wù)成功,即使只有一個(gè)操作失敗,事務(wù)也不成功。如果所有操作完成,事務(wù)則提交,其修改將作用于所有其他數(shù)據(jù)庫進(jìn)程。如果一個(gè)操作失敗,則事務(wù)將回滾,該事務(wù)所有操作的影響都將取消。
簡(jiǎn)述題:
1、用PHP打印出前一天的時(shí)間格式是2006-5-10 22:21:21(2分)答:echo date('Y-m-d H:i:s', strtotime('-1 days'));
2、echo(),print(),print_r()的區(qū)別(3分)答:echo是PHP語句, print和print_r是函數(shù),語句沒有返回值,函數(shù)可以有返回值(即便沒有用)print()只能打印出簡(jiǎn)單類型變量的值(如int,string)print_r()可以打印出復(fù)雜類型變量的值(如數(shù)組,對(duì)象)echo 輸出一個(gè)或者多個(gè)字符串
3、能夠使HTML和PHP分離開使用的模板(1分)答:Smarty,Dwoo,TinyButStrong,Template Lite,Savant,phemplate,XTemplate
5、使用哪些工具進(jìn)行版本控制?(1分)答:cvs,svn,vss;
6、如何實(shí)現(xiàn)字符串翻轉(zhuǎn)?(3分)答:echo strrev($a);
7、優(yōu)化MYSQL數(shù)據(jù)庫的方法。(4分,多寫多得)答:
1、選取最適用的字段屬性,盡可能減少定義字段長(zhǎng)度,盡量把字段設(shè)置NOT NULL,例如'省份,性別',最好設(shè)置為ENUM
2、使用連接(JOIN)來代替子查詢: a.刪除沒有任何訂單客戶:DELETE FROM customerinfo WHERE customerid NOT in(SELECT customerid FROM orderinfo)b.提取所有沒有訂單客戶:SELECT FROM customerinfo WHERE customerid NOT in(SELECT customerid FROM orderinfo)c.提高b的速度優(yōu)化:SELECT FROM customerinfo LEFT JOIN orderid customerinfo.customerid=orderinfo.customerid WHERE orderinfo.customerid IS NULL
3、使用聯(lián)合(UNION)來代替手動(dòng)創(chuàng)建的臨時(shí)表
a.創(chuàng)建臨時(shí)表:SELECT name FROM `nametest` UNION SELECT username FROM `nametest2`
4、事務(wù)處理: a.保證數(shù)據(jù)完整性,例如添加和修改同時(shí),兩者成立則都執(zhí)行,一者失敗都失敗
mysql_query(“BEGIN”);mysql_query(“INSERT INTO customerinfo(name)VALUES('$name1')”;mysql_query(“SELECT * FROM `orderinfo` where customerid=”.$id“);mysql_query(”COMMIT“);
5、鎖定表,優(yōu)化事務(wù)處理: a.我們用一個(gè) SELECT 語句取出初始數(shù)據(jù),通過一些計(jì)算,用 UPDATE 語句將新值更新到表中。
包含有 WRITE 關(guān)鍵字的 LOCK TABLE 語句可以保證在 UNLOCK TABLES 命令被執(zhí)行之前,不會(huì)有其它的訪問來對(duì) inventory 進(jìn)行插入、更新或者刪除的操作 mysql_query(”LOCK TABLE customerinfo READ, orderinfo WRITE“);mysql_query(”SELECT customerid FROM `customerinfo` where id=“.$id);mysql_query(”UPDATE `orderinfo` SET ordertitle='$title' where customerid=“.$id);mysql_query(”UNLOCK TABLES“);
6、使用外鍵,優(yōu)化鎖定表
a.把customerinfo里的customerid映射到orderinfo里的customerid, 任何一條沒有合法的customerid的記錄不會(huì)寫到orderinfo里 CREATE TABLE customerinfo(customerid INT NOT NULL, PRIMARY KEY(customerid))TYPE = INNODB;CREATE TABLE orderinfo(orderid INT NOT NULL, customerid INT NOT NULL, PRIMARY KEY(customerid,orderid), FOREIGN KEY(customerid)REFERENCES customerinfo(customerid)ON DELETE CASCADE)TYPE = INNODB;注意:'ON DELETE CASCADE',該參數(shù)保證當(dāng)customerinfo表中的一條記錄刪除的話同時(shí)也會(huì)刪除order 表中的該用戶的所有記錄,注意使用外鍵要定義事務(wù)安全類型為INNODB;
7、建立索引: a.格式:(普通索引)-> 創(chuàng)建:CREATE INDEX <索引名> ON tablename(索引字段)修改:ALTER TABLE tablename ADD INDEX [索引名](索引字段)創(chuàng)表指定索引:CREATE TABLE tablename([...],INDEX[索引名](索引字段))(唯一索引)-> 創(chuàng)建:CREATE UNIQUE <索引名> ON tablename(索引字段)修改:ALTER TABLE tablename ADD UNIQUE [索引名](索引字段)創(chuàng)表指定索引:CREATE TABLE tablename([...],UNIQUE[索引名](索引字段))(主鍵)-> 它是唯一索引,一般在創(chuàng)建表是建立,格式為: CREATA TABLE tablename([...],PRIMARY KEY[索引字段])
8、優(yōu)化查詢語句
a.最好在相同字段進(jìn)行比較操作,在建立好的索引字段上盡量減少函數(shù)操作
例子1: SELECT * FROM order WHERE YEAR(orderDate)<2008;(慢)SELECT * FROM order WHERE orderDate<”2008-01-01“;(快)例子2: SELECT * FROM order WHERE addtime/7<24;(慢)SELECT * FROM order WHERE addtime<24*7;(快)例子3: SELECT * FROM order WHERE title like ”%good%“;SELECT * FROM order WHERE title>=”good“ and name<”good“;
8、PHP的意思(送1分)答:PHP是一個(gè)基于服務(wù)端來創(chuàng)建動(dòng)態(tài)網(wǎng)站的腳本語言,您可以用PHP和HTML生成網(wǎng)站主頁
9、MYSQL取得當(dāng)前時(shí)間的函數(shù)是?,格式化日期的函數(shù)是(2分)答:now(),date()
10、實(shí)現(xiàn)中文字串截取無亂碼的方法。(3分)答: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;} }
11、您是否用過版本控制軟件? 如果有您用的版本控制軟件的名字是?(1分)
12、您是否用過模板引擎? 如果有您用的模板引擎的名字是?(1分)答:用過,smarty
13、請(qǐng)簡(jiǎn)單闡述您最得意的開發(fā)之作(4分)答:信息分類
14、對(duì)于大流量的網(wǎng)站,您采用什么樣的方法來解決訪問量問題?(4分)答:確認(rèn)服務(wù)器硬件是否足夠支持當(dāng)前的流量,數(shù)據(jù)庫讀寫分離,優(yōu)化數(shù)據(jù)表, 程序功能規(guī)則,禁止外部的盜鏈,控制大文件的下載,使用不同主機(jī)分流主要流量
15、用PHP寫出顯示客戶端IP與服務(wù)器IP的代碼1分)答:打印客戶端IP:echo $_SERVER[‘REMOTE_ADDR’];或者: getenv('REMOTE_ADDR');打印服務(wù)器IP:echo gethostbyname(” 語言中,頁面頭部的 meta 標(biāo)記可以用來輸出文件的編碼格式,以下是一個(gè)標(biāo)準(zhǔn)的 meta 語句
請(qǐng)使用 PHP 語言寫一個(gè)函數(shù),把一個(gè)標(biāo)準(zhǔn) HTML 頁面中的類似 meta 標(biāo)記中的 charset 部分值改為 big5
請(qǐng)注意:
1.需要處理完整的 html 頁面,即不光此 meta 語句
2.忽略大小寫
3.' 和 “ 在此處是可以互換的
4.'Content-Type' 兩側(cè)的引號(hào)是可以忽略的,但 'text/html;charset=gbk' 兩側(cè)的不行
5.注意處理多余空格
3.寫一個(gè)函數(shù),算出兩個(gè)文件的相對(duì)路徑
如 $a = '/a/b/c/d/e.php';
$b = '/a/b/12/34/c.php';
計(jì)算出 $b 相對(duì)于 $a 的相對(duì)路徑應(yīng)該是../../c/d將()添上 答:function getRelativePath($a, $b){ $returnPath = array(dirname($b));$arrA = explode('/', $a);$arrB = explode('/', $returnPath[0]);for($n = 1, $len = count($arrB);$n < $len;$n++){ if($arrA[$n]!= $arrB[$n]){ break;} } if($len$n, '..'));}
$returnPath = array_merge($returnPath, array_slice($arrA, $n));return implode('/', $returnPath);} echo getRelativePath($a, $b);填空題: 1.在PHP中,當(dāng)前腳本的名稱(不包括路徑和查詢字符串)記錄在預(yù)定義變量__$_SERVER['PHP_SELF']__中;而鏈接到當(dāng)前頁面的URL記錄在預(yù)定義變量__$_SERVER['HTTP_REFERER']__ 中
2.執(zhí)行程序段將輸出__0__。
3.在HTTP 1.0中,狀態(tài)碼 401 的含義是____;如果返回“找不到文件”的提示,則可用 header 函數(shù),其語句為____。
4.數(shù)組函數(shù) arsort 的作用是__對(duì)數(shù)組進(jìn)行逆向排序并保持索引關(guān)系__;語句 error_reporting(2047)的作用是__報(bào)告所有錯(cuò)誤和警告__。5.PEAR中的數(shù)據(jù)庫連接字符串格式是____。
6.寫出一個(gè)正則表達(dá)式,過慮網(wǎng)頁上的所有JS/VBS腳本(即把scrīpt標(biāo)記及其內(nèi)容都去掉):preg_replace(” //si“, ”newinfo“, $script);7.以Apache模塊的方式安裝PHP,在文件http.conf中首先要用語句____動(dòng)態(tài)裝載PHP模塊,然后再用語句____使得Apache把所有擴(kuò)展名為php的文件都作為PHP腳本處理。
LoadModule php5_module ”c:/php/php5apache2.dll“ , AddType application/x-httpd-php.php, 8.語句 include 和 require 都能把另外一個(gè)文件包含到當(dāng)前文件中,它們的區(qū)別是____;為了避免多次包含同一文件,可以用語句__require_once||include_once__來代替它們。
9.類的屬性可以序列化后保存到 session 中,從而以后可以恢復(fù)整個(gè)類,這要用到的函數(shù)是____。
10.一個(gè)函數(shù)的參數(shù)不能是對(duì)變量的引用,除非在php.ini中把__allow_call_time_pass_reference boolean__設(shè)為on.11.SQL中LEFT JOIN的含義是__自然左外鏈接__。如果 tbl_user記錄了學(xué)生的姓名(name)和學(xué)號(hào)(ID),tbl_score記錄了學(xué)生(有的學(xué)生考試以后被開除了,沒有其記錄)的學(xué)號(hào)(ID)和考試成績(jī)(score)以及考試科目(subject),要想打印出各個(gè)學(xué)生姓名及對(duì)應(yīng)的的各科總成績(jī),則可以用SQL語句____。
12.在PHP中,heredoc是一種特殊的字符串,它的結(jié)束標(biāo)志必須____。編程題: 13.寫一個(gè)函數(shù),能夠遍歷一個(gè)文件夾下的所有文件和子文件夾。答: function my_scandir($dir){ $files = array();if($handle = opendir($dir)){ while(($file = readdir($handle))!== false){ if($file!= ”..“ && $file!= ”.“){ if(is_dir($dir.”/“.$file)){ $files[$file] = scandir($dir.”/“.$file);}else { $files[] = $file;} } } closedir($handle);return $files;} } 14.簡(jiǎn)述論壇中無限分類的實(shí)現(xiàn)原理。答:
function Get_Category($category_id = 0,$level = 0, $default_category = 0){ global $DB;$sql = ”SELECT * FROM category ORDER BY categoryID DESC“;$result = $DB->query($sql);while($rows = $DB->fetch_array($result)){ $category_array[$rows[categoryParentID]][$rows[categoryID]] = array('id' => $rows[categoryID], 'parent' => $rows[categoryParentID], 'name' => $rows [categoryName]);} if(!isset($category_array[$category_id])){ return ”“;} foreach($category_array[$category_id] AS $key => $category){ if($category['id'] == $default_category){ echo ”/n“;} else { echo ”>“.$category['name'].”/n“;} Get_Category($key, $level + 1, $default_category);} unset($category_array[$category_id]);} /* 函數(shù)返回的數(shù)組格式如下所示: Array([1] => Array([id] => 1 [name] => 一級(jí)類別 [level] => 0 [ParentID] => 0)[4] => Array([id] => 4 [name] => 二級(jí)類別 [level] => 1 [ParentID] => 1)[9] => Array([id] => 9 [name] => 哈哈 [level] => 2 [ParentID] => 4)[3] => Array([id] => 3 [name] => 二級(jí)類別 [level] => 1 [ParentID] => 1)[8] => Array([id] => 8 [name] => aqqqqqd [level] => 2 [ParentID] => 3)[2] => Array([id] => 2 [name] => 二級(jí)類別 [level] => 1 [ParentID] => 1)[7] => Array([id] => 7 [name] => 234234 [level] => 2 [ParentID] => 2)[6] => Array([id] => 6 [name] => 333332 [level] => 2 [ParentID] => 2)[5] => Array([id] => 5 [name] => 三級(jí)類別 [level] => 2 [ParentID] => 2)[10] => Array([id] => 10 [name] => 66333666 [level] => 3 [ParentID] => 5))*/ //指定分類id,然后返回?cái)?shù)組
function Category_array($category_id = 0,$level=0){ global $DB;$sql = ”SELECT * FROM category ORDER BY categoryID DESC“;$result = $DB->query($sql);while($rows = $DB->fetch_array($result)){ $category_array[$rows['categoryParentID']][$rows['categoryID']] = $rows;} foreach($category_array AS $key=>$val){ if($key == $category_id){ foreach($val AS $k=> $v){ $options[$k] = array('id' => $v['categoryID'], 'name' => $v['categoryName'], 'level' => $level, 'ParentID'=>$v['categoryParentID']);$children = Category_array($k, $level+1);if(count($children)> 0){ $options = $options + $children;} } } } unset($category_array[$category_id]);return $options;} ?> array('1' => array('id' => 1, 'parent' => 0, 'name' => '1111'), '2' => array('id' => 2, 'parent' => 0, 'name' => '2222'), '4' => array('id' => 4, 'parent' => 0, 'name' => '4444')), '1' => array('3' => array('id' => 3, 'parent' => 1, 'name' => '333333'), '5' => array('id' => 5, 'parent' => 1, 'name' => '555555')), '3' => array('6' => array('id' => 6, 'parent' => 3, 'name' => '66666'), '7' => array('id' => 7, 'parent' => 3, 'name' => '77777')), '4' => array('8' => array('id' => 8, 'parent' => 4, 'name' => '8888'), '9' => array('id' => 9, 'parent' => 4, 'name' => '9999')));if(!isset($arr[$category_id])){ return ”“;}
foreach($arr[$category_id] AS $key => $cate){ if($cate['id'] == $default_category){ $txt = ”/n“;}else{ $txt1 = ”>“.$cate['name'].”/n“;} $val = $txt.$txt1;echo $val;self::Get_Category($key, $level + 1, $default_category);} }
function getFlush($category_id = 0,$level = 0, $default_category = 0){
ob_start();self::Get_Category($category_id ,$level, $default_category);$out = ob_get_contents();ob_end_clean();return $out;} } $id =$_GET['id'];echo ”";?>
第五篇:PHP程序員面試題
PHP方面:
1:echo print print_r的區(qū)別
Echo是PHP語句,print與print_r是函數(shù),語句沒有返回值,函數(shù)可以有返回值。Print只能打印簡(jiǎn)單類型變量的值。
Print_r可以打印復(fù)雜變量值(數(shù)組或?qū)ο螅?/p>
Echo 輸出一個(gè)或者多個(gè)字符串。
2:mysql_fetch_array()與mysql_fetch_row()區(qū)別
mysql_fetch_array()返回根據(jù)從結(jié)果集取得的行生成的數(shù)組,如果沒有更多行,返回false除了將數(shù)據(jù)以字段做索引外,還可以用字段名作為索引。
mysql_fetch_row()返回從結(jié)果集中取得一行作為枚舉數(shù)組,返回一個(gè)數(shù)字索引的數(shù)組,偏移量從0開始。
mysql_fetch_array()是mysql_fetch_row()的擴(kuò)展版本。
3:PHP面向?qū)ο笾?_set()與_construct的作用
_set()——-用于為屬性設(shè)置值,_get()獲取屬性的值
_construct——-在一個(gè)類中只能聲明一個(gè)構(gòu)造方法,只有在每次創(chuàng)建對(duì)象的時(shí)候回去調(diào)用一次構(gòu)造方法,不能主動(dòng)的調(diào)用這個(gè)方法,所以通常用它執(zhí)行一些有用的初始化任務(wù)。4:PHP中session與cookie的區(qū)別
Cookie是保存在客戶端的信息,是一種在遠(yuǎn)程瀏覽器儲(chǔ)存數(shù)據(jù)并以此來跟蹤和識(shí)別用戶的機(jī)制。PHP的http協(xié)議的頭信息里發(fā)送cookie,因此setcookie()函數(shù)必須在其他信息輸出前調(diào)用,和header()函數(shù)的限制類似。
Session是保存在服務(wù)器端的信息,從這個(gè)角度,session比cookie更安全。當(dāng)會(huì)話創(chuàng)建時(shí),服務(wù)器返回客戶端一個(gè)加密的session_id 以標(biāo)識(shí)用戶身份,瀏覽器關(guān)閉時(shí),session會(huì)銷毀,從而session存的值就沒有了。
5:如何設(shè)置cookie并指定有效的時(shí)間
Bool setcookie(string name,string value,int expire,string path,string domain,bool secure,bool httponly)
Name :cookie變量名
Value :cookie 變量值
Expire:有效期結(jié)束的時(shí)間
Path:有效目錄
Domain:有效域名,頂級(jí)或唯一
Secure:如果值為1,則cookie只能在https連接上有效,如果為默認(rèn)值0,http和https都可以
Php設(shè)置cookie
$value = 'something from somewhere';
setcookie(“TestCookie”, $value);/* 簡(jiǎn)單cookie設(shè)置 */
setcookie(“TestCookie”, $value, time()+3600);/* 有效期1個(gè)小時(shí) */
setcookie(“TestCookie”, $value, time()+3600, “/~rasmus/”, “.example.com”, 1);/* 有效目錄 /~rasmus,有效域名example.com及其所有子域名 */
?>
使用header()設(shè)置cookie;
header(―Set-Cookie: name=$value[;path=$path[;domain=xxx.com[;]]‖);
后面的參數(shù)和上面列出setcookie函數(shù)的參數(shù)一樣.Cookie的機(jī)制原理:
a)服務(wù)器通過隨著響應(yīng)發(fā)送一個(gè)http的Set-Cookie頭,在客戶機(jī)中設(shè)置一個(gè)cookie(多個(gè)cookie要多個(gè)頭).b)客戶端自動(dòng)向服務(wù)器端發(fā)送一個(gè)http的cookie頭,服務(wù)器接收讀取.HTTP/1.x 200 OK
X-Powered-By: PHP/5.2.1Set-Cookie: TestCookie=something from somewhere;path=/
Expires: Thu, 19 Nov 2007 18:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0Pragma: no-cache
Content-type: text/html
這一行實(shí)現(xiàn)了cookie功能,收到這行后
Set-Cookie: TestCookie=something from somewhere;path=/
瀏覽器將在客戶端的磁盤上創(chuàng)建一個(gè)cookie文件,并在里面寫入:
TestCookie=something from somewhere;/
這一行就是我們用setcookie(?TestCookie‘,'something fromsomewhere‘,'/‘);的結(jié)果.也就是用header(?Set-Cookie: TestCookie=something fromsomewhere;path=/‘);的結(jié)果.6:PHP面向?qū)ο笾械脑L問控制
Public 表示全局,類內(nèi)部外部子類都可以訪問
Private 表示私有,只有本類內(nèi)部可以調(diào)用
Protected 表示受保護(hù)的,只有本類或子類或父類可以訪問
7:什么是PHP的MVC,MVC的作用及原理
MVC是一個(gè)設(shè)計(jì)模式,它強(qiáng)制性的使應(yīng)用程序的輸入,處理,輸出分開,使用MVC應(yīng)用程序本分成了三個(gè)核心部分:模型,視圖,控制器,它們各自處理自己的任務(wù)。
MVC的原理:首先控制器接受用戶的請(qǐng)求,并決定應(yīng)該調(diào)用用哪個(gè)模型來進(jìn)行處理,然后模型用業(yè)務(wù)邏輯來處理用戶的請(qǐng)求并返回?cái)?shù)據(jù),然后控制器用相應(yīng)的視圖格式化模型返回的數(shù)據(jù),并通過表示層呈現(xiàn)給用戶。
基本原理:表現(xiàn)層(V)的請(qǐng)求發(fā)送到控制器(C),控制器根據(jù)請(qǐng)求類型調(diào)用業(yè)務(wù)層(M),最終調(diào)用表現(xiàn)層顯示。
8:PHP中includerequire 的區(qū)別
這兩種結(jié)構(gòu)在處理失敗之外有不同,include產(chǎn)生一個(gè)警告,而require則導(dǎo)致一個(gè)致命的錯(cuò)誤,換句話說,如果你想在遇到丟失文件時(shí)停止處理頁面就用require。Include就不是這樣,腳本會(huì)繼續(xù)執(zhí)行。
Require的使用方法如require(―Myfile.php‖);這個(gè)表式通常放到PHP程式的最前面,PHP執(zhí)行前,就會(huì)讀入require所指定引入的檔案,使它變成PHP程式網(wǎng)頁的一部分。
Include使用方法和上面相同,這個(gè)程式一般放到流程控制的處理區(qū)段,php程式網(wǎng)頁在讀到include的檔案時(shí),才將它讀進(jìn)來,這種方式,可以把程式執(zhí)行時(shí)的流程簡(jiǎn)單化。
當(dāng)頁面執(zhí)行到require()時(shí),如果require是一個(gè)PHP、HTML頁面的話,這時(shí)就會(huì)馬上轉(zhuǎn)到去執(zhí)行該頁面了。而include,一般是用于include進(jìn)來一些inc文件。比如說可以將你的網(wǎng)站的頁頭和頁眉作為一個(gè)inc文件,這樣在每個(gè)PHP文件里面再include進(jìn)來。include實(shí)際只是將你要include的文件嵌入到當(dāng)前頁面當(dāng)中。而require則是馬上去執(zhí)行你所請(qǐng)求的頁面。
——————————————————————————–
incluce在用到時(shí)加載
require在一開始就加載
_once后綴表示已加載的不加載
php系統(tǒng)在加載php程序時(shí)有一個(gè)偽編譯過程,可使程序運(yùn)行速度加快。但incluce的文檔仍為解釋執(zhí)行
include的文件中出錯(cuò)了,主程序繼續(xù)往下執(zhí)行
require的文件出錯(cuò)了,主程序也停了
所以包含的文件出錯(cuò)對(duì)系統(tǒng)影響不大的話(如界面文件)就用include,否則用requireinclude_once()函數(shù),require_once()函數(shù)會(huì)先檢查目標(biāo)檔案的內(nèi)容是不是在之前就已經(jīng)導(dǎo)入過了,如果是的話,便不會(huì)再次重復(fù)導(dǎo)入同樣的內(nèi)容
9:計(jì)算兩個(gè)時(shí)間差 2009.5.122009.5.20
$regist1 = ―05/12/2006″;
$regist2 = ―10/05/2007″;
list($month1,$day1,$year1)= explode(―/‖,$regist1);
list($month2,$day2,$year2)= explode(―/‖,$regist2);
$regist1 = mktime(0,0,0,$month1,$day1,$year1);
$regist2 = mktime(0,0,0,$month2,$day2,$year2);$time_difference = $regist2-$regist1;
10:你了解的協(xié)議有哪些?HTTP協(xié)議的錯(cuò)誤提示代表什么?
SMTP(Simple Mail Transfer Protocal)稱為簡(jiǎn)單郵件傳輸協(xié)議,目標(biāo)是向用戶提供高效、可靠的郵件傳輸。
POP的全稱是 Post Office Protocol,即郵局協(xié)議,用于電子郵件的接收,它使用TCP的110端口,現(xiàn)在常用的是第三版,所以簡(jiǎn)稱為 POP3
IMAP是Internet Message Access Protocol的縮寫,顧名思義,主要提供的是通過Internet獲取信息的一種協(xié)議。
HTTP(HyperTextTransferProtocol)是超文本傳輸協(xié)議的縮寫,它用于傳送WWW方式的數(shù)據(jù),關(guān)于HTTP協(xié)議的詳細(xì)內(nèi)容請(qǐng)參考RFC2616。
IE提示 HTTP 403 – 禁止訪問
IE提示 HTTP 403.9 – 禁止訪問:連接的用戶過多
IE提示 HTTP 404 – 無法找到文件
IE提示 HTTP 500 – 內(nèi)部服務(wù)器錯(cuò)誤