Sept questions d'entretien PHP classiques (avec réponses)

藏色散人
Libérer: 2023-04-10 06:42:02
avant
4986 Les gens l'ont consulté

Cet article présente sept questions d'entretien PHP classiques (avec réponses). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

1. Il existe plusieurs façons de fusionner deux tableaux. Essayez de comparer leurs similitudes et leurs différences

façons :

1, array_merge()

2, '+'

3. array_merge_recursive

Similarités et différences :

array_merge fusionne simplement les tableaux

array_merge_recursive fusionne deux tableaux S'il y a exactement les mêmes données dans le tableau, fusionnez. les récursivement

array_combine et '+' : fusionne deux tableaux, et la valeur du premier sert de clé du nouveau tableau

2. Veuillez écrire une fonction pour vérifier si les données soumises par l'utilisateur sont un nombre entier (quel que soit le type de données, il peut s'agir de nombres binaires, octaux, décimaux ou hexadécimaux)

Réponse : En fait, le les principaux sont is_int et floor Cette méthode

if(!is_numeric($jp_total)||strpos($jp_total,".")!==false){  
    echo "不是整数";  
}else{  
    echo "是整数";  
}
Copier après la connexion

3. Les fonctions strtolower () et strtoupper () de PHP peuvent entraîner la conversion des caractères chinois en caractères tronqués sur les serveurs sur lesquels des systèmes non chinois sont installés. Veuillez écrire deux fonctions alternatives pour obtenir une conversion de casse de chaîne compatible avec le texte Unicode <🎜. >Réponse : La raison est la suivante : le chinois est composé de plusieurs octets et un seul caractère anglais dans le système anglais n'a qu'un seul octet, donc le système effectue un traitement strtolower () sur chaque octet de chinois après le changement des caractères chinois. deviennent tronqués lorsqu'ils sont assemblés (les caractères correspondant à la carte d'encodage nouvellement générée peuvent ne pas être chinois)

Solution manuelle : utilisez str_split (string string, intstring, intsplit_length = 1) pour appuyer sur chaque coupe d'octet, comme Le chinois peut être découpé en trois octets. Si les octets reconnus sont des lettres anglaises, ils seront convertis.

<?php  
function mystrtoupper($a){  
    $b = str_split($a, 1);  
    $r = &#39;&#39;;  
    foreach($b as $v){  
        $v = ord($v);  
        if($v >= 97 && $v<= 122){  
            $v -= 32;  
        }  
        $r .= chr($v);  
    }  
    return $r;  
}  
$a = &#39;a中你继续F@#$%^&*(BMDJFDoalsdkfjasl&#39;;  
echo &#39;origin string:&#39;.$a." ";  
echo &#39;result string:&#39;;  
$r = mystrtoupper($a);  
var_dump($r);
Copier après la connexion

4.

Il y a un bug dans la fonction is_writeable () de PHP, qui ne peut pas déterminer avec précision si un répertoire/fichier est accessible en écriture. Veuillez écrire une fonction pour déterminer si le répertoire/fichier est absolument accessible en écriture. Réponse : Il y en a. deux aspects du bug. ,

1. Dans Winddowns, lorsque le fichier n'a qu'un attribut en lecture seule, la fonction is_writeable () renvoie false Lorsque true est renvoyé, le fichier n'est pas nécessairement accessible en écriture.

S'il s'agit d'un répertoire, créez un nouveau fichier dans le répertoire et vérifiez en ouvrant le fichier

S'il s'agit d'un fichier, vous pouvez tester si le fichier est accessible en écriture en ouvrant le fichier ; (fouvert).

2. Sous Unix, lorsque safe_mode est activé dans le fichier de configuration php (safe_mode=on), is_writeable() est également indisponible.

Lisez le fichier de configuration pour voir si safe_mode est activé.

/**
* Tests for file writability
*
* is_writable() returns TRUE on Windows servers when you really can&#39;t write to
* the file, based on the read-only attribute. is_writable() is also unreliable
* on Unix servers if safe_mode is on.
*
* @access   private
* @return   void
*/
if ( ! function_exists(&#39;is_really_writable&#39;))
{
    function is_really_writable($file){
    // If we&#39;re on a Unix server with safe_mode off we call is_writable
    if (DIRECTORY_SEPARATOR == &#39;/&#39; AND @ini_get("safe_mode") == FALSE){
        return is_writable($file);
    }
    // For windows servers and safe_mode "on" installations we&#39;ll actually
    // write a file then read it. Bah...
    if (is_dir($file)){
        $file = rtrim($file, &#39;/&#39;).&#39;/&#39;.md5(mt_rand(1,100).mt_rand(1,100));
        if (($fp = @fopen($file, FOPEN_WRITE_CREATE)) === FALSE){
            return FALSE;
        }
        fclose($fp);
        @chmod($file, DIR_WRITE_MODE);
        @unlink($file);
        return TRUE;
    } elseif ( ! is_file($file) OR ($fp = @fopen($file, FOPEN_WRITE_CREATE)) === FALSE) {
        return FALSE;
    }
    fclose($fp);
    return TRUE;
    }
}
Copier après la connexion

5.

Il y a un bug dans la fonction chmod () de PHP, qui ne peut pas garantir un réglage réussi. Veuillez écrire une fonction pour créer un répertoire/fichier sous le chemin spécifié et vous assurer que le masque d'autorisation peut être défini correctement R : Je ne le trouve pas non plus. À la réponse

6.

PHP traite le type de fichier $_FILES ['type'] dans le tableau d'informations sur le fichier téléchargé. Il est fourni par le navigateur client. Il peut s'agir d'informations falsifiées par des pirates informatiques. Veuillez écrire une fonction pour vous assurer que le type de fichier image téléchargé. par l'utilisateur est authentique et fiableRéponse : Utiliser getimagesize pour déterminer le type d'images téléchargées est plus fiable que le type de la fonction $_FILES

Pour un même fichier, en utilisant différents navigateurs, le type renvoyé par php est différent, déterminé par le navigateur. Si le serveur fournit le type type,

peut être utilisé par des pirates pour soumettre un fichier exécutable au serveur déguisé en ayant un suffixe d'image.

Vous pouvez utiliser la fonction getimagesize () pour déterminer le type de fichier téléchargé. S'il s'agit d'un fichier avatar, un tableau comme celui-ci sera renvoyé

Array(
    [0] => 331
    [1] => 234
    [2] => 3
    [3] => width="331" height="234"
    [bits] => 8
    [mime] => image/png

);
Copier après la connexion

Si la fonction getimagesize () le fera. renvoie un tableau comme celui-ci. Ce qui est téléchargé est le fichier avatar. Le type de représentation avec l'index 2 est

1 = GIF, 2 = JPG, 3 = PNG, 4 = SWF, 5 = PSD, 6 = BMP, 7 = TIFF (ordre des octets Intel), 8 = TIFF ( ordre des octets motorola), 9 = JPC, 10 = JP2, 11 = JPX, 12 = JB2, 13 = SWC, 14 = IFF, 15 = WBMP, 16 = XBM,

Vous pouvez l'utiliser pour limiter les téléchargements type d'avatar

<?php
    $file=$_FILES[&#39;file&#39;];
    if(!empty($file))
    {
       var_dump($file);
       var_dump(getimagesize($file["tmp_name"]));
    }   
?>
Copier après la connexion

7.

PHP implémente l'interaction des données avec Javascript en codant l'URL des données. Cependant, les règles d'encodage et de décodage de certains caractères spéciaux sont différentes de celles de Javascript. Veuillez expliquer cette différence en détail et cibler les données en UTF-8. jeu de caractères. , écrivez les fonctions d'encodage et de décodage de PHP et les fonctions d'encodage et de décodage de Javascript pour garantir que les données codées en PHP peuvent être correctement décodées par Javascript et que les données codées en Javascript peuvent être correctement décodées par PHP Réponse :

<?php
 $str = &#39;思源博客siyuantlw/tlw/sy/俺只是一个打酱油的&#39;;
 $str = iconv("GB2312",&#39;UTF-8&#39;,$str);
 $str = urlencode($str); 
?>
Copier après la connexion

/ /js decodeURIComponent semble ne pas reconnaître le format d'encodage GB2312 et doit être converti en utf-8. Ensuite, s'il y a des espaces dans la chaîne, elle sera convertie en signe + <🎜. >

<html>
 <script>
  var ds = &#39;<?php echo $str;?>&#39;;
  var dddd= decodeURIComponent (ds);
  alert(dddd);
 </script>
</html>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:learnku.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!