Heim  >  Artikel  >  Backend-Entwicklung  >  Die umfassendsten und detailliertesten PHP-Interviewfragen (mit Antworten)

Die umfassendsten und detailliertesten PHP-Interviewfragen (mit Antworten)

不言
不言Original
2018-05-14 14:24:04162213Durchsuche

Dieser Artikel stellt die umfassendsten und detailliertesten PHP-Interviewfragen (mit Antworten) vor, die einen gewissen Referenzwert haben. Jetzt können Freunde in Not darauf verweisen

Verwandte Empfehlung: Zusammenfassung der PHP-Interviewfragen im Jahr 2019 (Sammlung)

1 Was bedeutet __FILE__? (5 Punkte)
Vollständiger Pfad und Dateiname der Datei. Bei Verwendung in einer Include-Datei wird der Name der Include-Datei zurückgegeben. Ab PHP 4.0.2 enthält __FILE__ immer einen absoluten Pfad, während frühere Versionen manchmal einen relativen Pfad enthielten.
2. Wie erhalte ich die IP-Adresse des Kunden? (5 Punkte)

$_SERVER[‘REMOTE_ADDR’]

3. Schreiben Sie eine Anweisung, die die Header-Funktion verwendet, um zur Seite zu springen (5 Punkte)

Header(‘location:index.php’);

4 str ist ein Absatz-HTML-Text. Verwenden Sie reguläre Ausdrücke, um alle js-Skripte zu entfernen (5 Punkte)

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

5. Schreiben Sie eine Anweisung, um Nullwerte in einem Array zu entfernen (5 Punkte). )

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

Erste Methode:

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

Zweite Methode:

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

6 Zeit Die Funktion des Stempelns und die Methode zum Drucken der Uhrzeit des Vortages (Format: Jahr-Monat-Tag Stunden: Minuten: Sekunden) (5 Minuten)

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

7. Schreiben Sie PHP für die Kodierungskonvertierungsfunktion (5 Punkte)

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

8. $str = "1,3,5,7,9,10,20", welche Funktion kann zum Konvertieren der Zeichenfolge verwendet werden str in ein Array einzelner Zahlen? (5 Punkte)

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

9. Die Rolle der Funktion serialize() /unserialize() (5 Punkte)
Die Erklärung von serialize() und unserialize() in PHP Handbuch ist:
serialisieren – Erzeugt eine Darstellung eines speicherbaren Werts. Der Rückgabewert ist ein String. Dieser String enthält einen Bytestrom, der einen Wert darstellt, ohne seinen Typ und seine Struktur zu verlieren, und kann an einem beliebigen Ort gespeichert werden.
unserialisieren – Erstellt einen PHP-Wert aus einer gespeicherten Darstellung
Spezifische Verwendung:

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

//Verwenden Sie eine beliebige Methode (z. B. wenn $sarr in einer Textdatei vorhanden ist). kann file_get_contents verwenden, um den gespeicherten Wert abzurufen und in $newarr zu speichern. 10. Schreiben Sie eine Funktion, deren Parameter das Jahr und den Monat sind und deren Ausgabeergebnis die Anzahl der Tage ist der angegebene Monat. (5 Punkte)

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

11. Der Pfad einer Datei ist /wwwroot/include/page.class.php. Schreiben Sie eine Methode, um die Dateierweiterung zu erhalten )

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

12. Welche PHP-Template-Engine haben Sie verwendet? (5 Punkte)
Smarty, die Template-Engine, die mit thinkphp geliefert wird

13. Bitte schreiben Sie einfach eine Klasse, instanziieren Sie diese Klasse und schreiben Sie Anweisungen, um die Attribute und Methoden der Klasse aufzurufen (5 Punkte)
$arr = pathinfo(“/wwwroot/include/page.class.php”);
$str = substr($arr[‘basename’],strrpos($arr[‘basename’],’.’));



14. Es gibt einen Tabellenfreund in der lokalen MySQL-Datenbank db_test. Der Datenbankverbindungsbenutzer ist root und das Passwort ist 123.
Die Felder der Freundestabelle sind: ID, Name, Alter, Geschlecht, Telefon, E-Mail

Bitte verwenden Sie PHP, um eine Verbindung zu MySQL herzustellen, wählen Sie alle Datensätze mit einem Alter > 20 in der Freundestabelle aus, drucken Sie die Ergebnisse aus und zählen Sie die Gesamtzahl der Abfrageergebnisse. (5 Punkte)
Class myclass{
Public $aaa;
Public $bbb;
Public function myfun(){
Echo “this is my function”;
}
}
$myclass = new myclass();
$myclass->$aaa;
$myclass->myfun();



15. Es gibt zwei Tabellen unten:
Benutzertabellenfeld-ID (int), Name (varchar)

Score-Tabellenfeld-UID (int), Betreff (varchar), Score (int)
<?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’];
….
}
Das UID-Feld der Score-Tabelle ist mit dem ID-Feld der Benutzertabelle verknüpft

Erforderlich, um die folgende SQL-Anweisung zu schreiben
1) Fügen Sie einen neuen Datensatz in den Benutzer ein Tabelle, in der Bewertungstabelle Fügen Sie zwei Datensätze ein, die mit dem neu hinzugefügten Datensatz verknüpft sind (5 Punkte)
2) Holen Sie sich die fünf Datensätze mit der höchsten Bewertung für den Benutzer mit UID 2 in der Bewertungstabelle (5 Punkte)
3 ) Verwenden Sie eine gemeinsame Abfrage, um den Namen zu erhalten. Die Gesamtpunktzahl für den Benutzer „Zhang San“ (5 Punkte)
4) Löschen Sie den Benutzer mit dem Namen „Li Si“, einschließlich der Punktedatensätze (5 Punkte)
5) Löschen die Punktetabelle (5 Punkte)
6) Benutzertabelle löschen (5 Punkte)



Verwandte Empfehlungen:

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-Interviewfrage 8: Der Unterschied zwischen innoDB und myisam

Das obige ist der detaillierte Inhalt vonDie umfassendsten und detailliertesten PHP-Interviewfragen (mit Antworten). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn