《PHP面試題第九回》要點:
本文介紹了PHP面試題第九回,希望對您有用。如果有疑問,可以聯系我們。
1、HTTP狀態中的301和302是什么意思?二者有何不同?
301,302 都是HTTP狀態的編碼,都代表著某個URL發生了轉移,不同之處在于:
301 redirect: 301 代表永久性轉移(Permanently Moved).
302 redirect: 302 代表暫時性轉移(Temporarily Moved ).
2、如何用正則表達式獲得一個頁面內容中所有圖片的地址?
<script type="text/javascript">
//思路分兩步
//1,匹配出圖片img標簽(即匹配出所有圖片),過濾其他不需要的字符
//2.從匹配出來的結果(img標簽中)循環匹配出圖片地址(即src屬性)
var str = "this is test string <img src=\"http:yourweb.com/test.jpg\" width='50' > 123 and the end <img src=\"所有地址也能匹配.jpg\" /> 33! <img src=\"/uploads/attached/image/20120426/20120426225658_92565.png\" alt=\"\" />"
//匹配圖片(g表示匹配所有結果i表示區分大小寫)
var imgReg = /<img.*?(?:>|\/>)/gi;
//匹配src屬性
var srcReg = /src=[\'\"]?([^\'\"]*)[\'\"]?/i;
var arr = str.match(imgReg);
alert('所有已成功匹配圖片的數組:'+arr);
for (var i = 0; i < arr.length; i++) {
var src = arr[i].match(srcReg);
//獲取圖片地址
if(src[1]){
alert('已匹配的圖片地址'+(i+1)+':'+src[1]);
}
//當然你也可以替換src屬性
if (src[0]) {
var t = src[0].replace(/src/i, "href");
//alert(t);
}
}
</script>
3、Const和static二者有哪些相似和不同?
(1) static
static關鍵字在類中是,描述一個成員是靜態的,static能夠限制外部的訪問,因為static后的成員是屬于類的,是不屬于任何對象實例,其他類是無法訪問的,只對類的實例共享,能一定程序對該成員盡心保護.類的靜態變量,非常類似全局變量,能夠被所有類的實例共享,類的靜態方法也是一樣的,類似于全局函數.類的靜態方法能訪問類的靜態的屬性.另外說明的是,static的成員,必須使用self來訪問,使用this會出錯.
(2)const
const是一個定義常量的關鍵字,類似于C中的#define,能夠定義一個常量,如果在程序中改變了它的值,那么會出現錯誤.
4、已知任意一個合法日期,如何算出那一天所在星期的周一是幾月幾號?
<metacharset="utf-8">
<?php
date_default_timezone_set('PRC');
function zhuanhuan($strtime){
$time=strtotime($strtime);
$xingqi=date('w',$time);
switch($xingqi){
case 0:
echo date("Y-m-d",$time-3600*24*6);
break;
case 1:
echo date("Y-m-d",$time);
break;
case 2:
echo date("Y-m-d",$time-3600*24);
break;
case 3:
echo date("Y-m-d",$time-3600*24*2);
break;
case 4:
echo date("Y-m-d",$time-3600*24*3);
break;
case 5:
echo date("Y-m-d",$time-3600*24*4);
break;
case 6:
echo date("Y-m-d",$time-3600*24*5);
break;
case 6:
echo date("Y-m-d",$time-3600*24*6);
break;
default:
echo "呵呵";
}
}
zhuanhuan("2017-01-09");
//代碼輸出結果:2017-01-09
5、請寫出至少兩種獲取文件名中擴展名的方法?
方法一
<?php
$path = "/usr/www/html/index.php";
$pathinfo = pathinfo($path);
//var_dump($pathinfo);
echo "擴展名:$pathinfo[extension]";
?>
方法二
<?php
function extend_2( $file_name )
{
$extend = pathinfo ( $file_name );
$extend = strtolower ( $extend [ "extension" ]);
return $extend ;
}
echo extend_2('index.php');
6、如何以追加的方式打開一個文件進行寫操作?
<?php
file_put_contents("test.txt", "This is another something.", FILE_APPEND);
?>
7、寫出代碼的執行結果?
<?php
$a=null ;$b=false;echo $a==$b?'相等':'不想等';
echo "<br/>";
$a=0;$b=0;echo $a==$b?'相等':'不相等';
echo "<br/>";
$a='0';echo empty($a)?'true':'false';
echo "<br/>";
$a=null;echo empty($a)?'true':'false';
echo "<hr>";
$a='abc';printf('%d',count($a));
echo "<br/>";
$a=1;$b=&$a;$c=$a++;echo $a.$b.$c;
echo "<br/>";
$count=5;
function get_count(){
static $count=0;
return $count++;
}
echo $count;
++$count;
echo get_count();
echo get_count();
echo "<br/>";
$GLOBALS['var1']=5;
$var2=1;
function get_value(){
global $var2;
$var=0;
return $var2++;
}
get_value();
echo $var1;
echo $var2;
?>
8、已知一個函數如下
<?php
function output(array $arr){
foreach ($arr as $key =>$value)
echo $key.':'.$value,PHP_EOL;
}
/* 換行符
unix系列用 \n
windows系列用 \r\n
mac用 \r
PHP中可以用PHP_EOL來替代,以提高代碼的源代碼級可移植性
如:
<?php
echoPHP_EOL;
//windows平臺相當于 echo "\r\n";
//unix\linux平臺相當于 echo "\n";
//mac平臺相當于 echo "\r";
?> */
?>
如果需要將次函數的輸出結果賦給一個變量(如$toobar),如何實現?
9、有如下內容:
Group表
Group_id group_name
1 movie
2 music
Thread 表
Thread_id group_id username
1 1 matt
2 1 robi
3 2 robi
如何用一句sql語句得到如下的結果
group_id group_name count(group_id)
1 movie 2
2 music 1
請寫出相應的sql語句:
create database gg characterset gbk;
use gg;
createtable you(
group_id intprimarykey auto_increment,
group_name varchar(20)
);
insertinto you values(' ','movie');
insertinto you values(' ','music');
createtable she(
thread_id intprimarykey auto_increment,
group_id intreferences you(group_id),
username varchar(20)
);
insertinto she values (' ',1,'matt');
insertinto she values (' ',1,'robi');
insertinto she values (' ',2,'robi');
select a.group_id, a.group_name,b.c 'count(group_id)'from you a ,
(select group_id, count(group_id) c from she groupby group_id) b
where a.group_id=b.group_id;
10、現有以下內容
Id(int) name(text)
1 網友
2 網友
3 網友
4 網友
5 網友
請寫一個sql語句,把name字段更新成name+id
也就是變成網友1、網友2.........以此類推?
drop database name;
create database name characterset gbk;
use name;
createtable namet(
id intprimarykey auto_increment,
name text
);
insertinto namet values(' ','網友');
insertinto namet values(' ','網友');
insertinto namet values(' ','網友');
insertinto namet values(' ','網友');
insertinto namet values(' ','網友');
update namet set name=concat(name,id);
select * from namet;
維易PHP培訓學院每天發布《PHP面試題第九回》等實戰技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養人才。
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/6908.html