thinkPHP5 est un excellent framework de développement PHP. Il fournit une méthode de développement rapide et des composants fonctionnels riches, parmi lesquels la fonction de routage d'URL est l'une de ses fonctionnalités importantes. Mais par défaut, accéder à la route nécessite d'ajouter index.php à l'URL. Par souci de beauté et de sécurité, cet article explique comment masquer le fichier d'entrée dans thinkPHP5.
1. Préparation de l'environnement
Avant le masquage d'URL, nous devons vérifier si l'environnement local prend en charge la fonction pseudo-statique et la fonction de réécriture d'URL, afin que l'opération de masquage d'URL puisse être effectuée en douceur. Tout d'abord, nous devons nous assurer qu'un serveur Web tel qu'Apache ou Nginx est installé, puis activer les fonctions pseudo-statiques et de réécriture d'URL dans le fichier de configuration, afin que le framework puisse reconnaître et générer des URL embellies.
2. Activez le masquage d'URL
Dans le fichier de configuration de thinkPHP5, recherchez le fichier app.php, recherchez l'élément de configuration url_html_suffix et définissez-le sur une chaîne vide, c'est-à-dire :
'url_html_suffix' = > ''
Cela autorise les URL sans suffixes.
Dans thinkphp5, en configurant les règles de routage, vous pouvez mapper l'URL d'accès au contrôleur ou à la méthode de fonctionnement. Nous devons définir les paramètres de routage correspondants pour chaque contrôleur ou méthode de fonctionnement, et mapper son URL correspondante à un contenu significatif, afin que l'effet caché puisse être exercé, par exemple :
Route::get('news /:id', 'index/index/news',[],['id'=>'d+']);
De cette façon, lors de l'accès à l'URL /news/1, le contrôleur d'index sera automatiquement appelé méthode d'opération news et définissez l'identifiant du paramètre de demande sur 1.
La configuration correspondante doit également être effectuée dans Apache ou Nginx. En prenant Apache comme exemple, ajoutez le contenu suivant dans .htaccess :
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php?s= / $1 [QSA,PT,L]
Dans ce code, RewriteEngine active la fonction de réécriture d'URL d'Apache ; RewriteCond %{REQUEST_FILENAME} !-d et RewriteCond %{REQUEST_FILENAME} !-f excluent l'accès aux fichiers et répertoires demandés à éviter. affectant l'accès aux ressources statiques ; enfin, RewriteRule est utilisé pour pointer l'URL vers le fichier d'entrée thinkPHP index.php et apporter des informations de routage.
4. Fonctions supplémentaires
Pour protéger davantage notre application, nous pouvons rendre notre application plus sécurisée en définissant le suffixe d'URL. Par exemple, vous pouvez définir tous les suffixes d'URL sur .shtml, .html, .shtml, etc., ce qui peut efficacement éviter les attaques contre nos applications.
Vous pouvez trouver l'option url_html_suffix dans le fichier de configuration et ajouter le suffixe correspondant, par exemple :
'url_html_suffix' => 'shtml|html|htm'
Nous pouvons utiliser Route Ajoutez une règle de routage à la méthode register dans la classe afin que le framework puisse identifier automatiquement l'URL. Par exemple :
if (is_file(APP_PATH . 'route.php')) {
Route::get('/', 'index/index');
Route::get('build', 'index/build ' );
include_once APP_PATH . 'route.php';
}
De cette façon, s'il existe une URL qui correspond aux règles, elle sera automatiquement transmise à son contrôleur ou à sa méthode d'action correspondante.
3. Résumé
Grâce aux étapes ci-dessus, nous pouvons facilement implémenter l'opération de masquage d'URL dans thinkPHP5, ce qui peut rendre notre application plus belle, plus sûre et plus facile à utiliser. Cependant, dans les applications réelles, une configuration et un débogage plus détaillés sont nécessaires pour obtenir la meilleure expérience de service.
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!