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

来源:https://www.cnblogs.com/a609251438/archive/2019/12/29/12116693.html
-Advertisement-
Play Games

這篇文章介紹的內容是關於最全最詳細的PHP面試題(帶有答案),有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下 相關推薦: 分享一波騰訊PHP面試題 2019年PHP最新面試題(含答案) Redis 高級面試題 學會這些還怕進不了大廠? 阿裡面試官三年經驗PHP程式員知識點彙總,學會你就 ...


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

相關推薦:

分享一波騰訊PHP面試題

2019年PHP最新面試題(含答案)

Redis 高級面試題 學會這些還怕進不了大廠?

阿裡面試官三年經驗PHP程式員知識點彙總,學會你就是下一個阿裡人!

php面試題之PHP核心技術

掌握 Redis這些 知識點,面試官一定覺得你很 NB

 

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('  ',1,'',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面試題(帶有答案)的詳細內容


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 位運算是指按二進位進行的運算。在系統軟體中,常常需要處理二進位位的問題。C語言提供了6個位操作運算符。這些運算符只能用於整型操作數,即只能用於帶符號或無符號的char,short,int與long類型。 ...
  • 簡單抓取網頁的代碼 import requests#導入requests包 from bs4 import BeautifulSoup#從bs4中導入BeauifulSoup包 import re#導入正則表達式的包 r = requests.get("http://baidu.com") r.en ...
  • Java是一種區分字母的大小寫的語言,所以我們在定義變數名的時候應該註意區分大小寫的使用和一些規範,接下來我們簡單的來講講Java語言中包、類、變數等的命名規範。 (一)Package(包)的命名 Package的名字應該都是由一個小寫單片語成,例如com、xuetang9、company等。 (二 ...
  • 新聞 "介紹DataFrame" "介紹System.Threading.Channels" "ConfigureAwait常見問題" "第三次年度C 降臨節" ".NET會議——2020年1月14日" "如何找到F 的工作" "MiniScaffold是什麼" "函數式編程辭彙表" 視頻及幻燈片 ...
  • 設計模式就是在大量的實踐中總結和理論之後優選的代碼結構、編程風格、以及解決問題的思考方式。 說白了設計模式就是在實際編程中逐漸總結出的解決問題的套路,類似於數學公式。 類的單例設計模式:在開發過程中有且只有一個實例化對象。 怎麼做到在整個系統運行過程中,這個類只被實例化一次?不論在哪只調用這一個實例 ...
  • 前言 曾經我認為最快的是麥迪的第一步,後來我覺得 7 醬逃跑速度更快,現在我懂了,原來我們都在跟時間賽跑. 年底了,給自己一個 "交代" 吧 2019 的我 2019 年寫了 很多 篇文章, 受到一些贊賞,也遭到一些批評. 我就不要臉地把它們都當做鼓勵吧~ 帶著它們,砥礪前行 !!! 也希望自己 2 ...
  • 新建資料庫my_db,新建表student_tb id為主鍵,不自動遞增 下載MyBatis https://github.com/mybatis/mybatis-3/releases 解壓。 新建Java項目,什麼都不用勾選(如果要在IDEA中操作資料庫,可勾選SQL Support)。 勾選後, ...
  • 轉載!!! 百度網盤鏈接 救救孩子吧!!! 素材+文件+源碼 共16.5G │ 觀看視頻必讀.txt │ 運行必讀.txt │ 運行環境.txt │ ├─資料庫文件 │ db_base_project.sql │ ├─視頻教程 │ 第一講系統開發環境搭建及項目基本情況介紹.mp4 │ 第二講ssm框 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...