Maison  >  Article  >  développement back-end  >  Comment implémenter des méthodes d'appel asynchrones en PHP

Comment implémenter des méthodes d'appel asynchrones en PHP

小云云
小云云original
2018-03-22 11:45:378498parcourir

La connexion et la communication entre le navigateur et le serveur se font via le protocole HTTP. Il s’agit d’un protocole basé sur un modèle de requête et de réponse. Le navigateur lance une requête au serveur via l'URL. Le serveur Web reçoit la requête, exécute un programme, puis répond en envoyant le code HTML correspondant au client.

Il y a un problème. Lorsque le serveur Web exécute un programme, il peut être terminé en quelques millisecondes, ou il peut ne pas être terminé en quelques minutes. Si le programme s'exécute lentement, l'utilisateur n'aura peut-être plus la patience d'attendre plus longtemps et de fermer le navigateur.

Parfois, nous ne nous soucions même pas des résultats de retour de ces scripts chronophages, mais nous devons attendre qu'ils terminent leur exécution et reviennent avant de pouvoir passer à l'étape suivante. Existe-t-il donc un moyen de simplement déclencher l'appel de ces scripts chronophages, puis de passer à l'étape suivante, afin que ces scripts chronophages puissent être exécutés lentement côté serveur ?

Après tests, j'ai résumé plusieurs méthodes et je les partage avec vous : 1. Le moyen le plus simple consiste à intégrer un appel AJAX dans le code HTML renvoyé au client, ou à intégrer une balise img avec src pointant vers le script fastidieux à exécuter. Cette méthode est la plus simple et la plus rapide. Le serveur n'a pas besoin de passer d'appels. Mais l'inconvénient est que d'une manière générale, Ajax devrait être déclenché après onLoad. C'est-à-dire que si l'utilisateur clique sur la page puis la ferme, notre script en arrière-plan ne sera pas déclenché. Si vous utilisez la balise img, cette méthode ne peut pas être qualifiée d'exécution asynchrone au sens strict. Le navigateur de l'utilisateur attendra longtemps que l'exécution du script php soit terminée, c'est-à-dire que la barre d'état du navigateur de l'utilisateur indique toujours qu'il est toujours en cours de chargement. Bien entendu, d’autres méthodes ayant des principes similaires peuvent également être utilisées, telles que les balises de script, etc.

2. popen()

ressource popen ( commande chaîne, mode chaîne ); //Ouvre un canal vers le processus généré en forçant l'exécution de la commande donnée. Ouvre un canal vers le processus généré par l'exécution de la commande qui a généré la commande donnée.

Vous pouvez donc l'appeler mais ignorer sa sortie.

pclose(popen("/home/xinchen/backend.php &", 'r'));

Cette méthode évite les défauts de la première méthode et est également rapide. Mais le problème est que cette méthode ne peut pas demander un autre WebService via le protocole HTTP et ne peut exécuter que des fichiers de script locaux. Et il ne peut être ouvert que dans un seul sens et ne peut pas transmettre un grand nombre de paramètres au script appelé.
Et si le nombre de visites est élevé, un grand nombre de processus seront générés. Si vous faites appel à des ressources externes, vous devez réfléchir vous-même à la concurrence.

3. Utilisez la méthode CURL
et définissez CUROPT_TIMEOUT sur 1 (le minimum est 1, déprimant). Autrement dit, le client doit attendre au moins 1 seconde.

$ch = curl_init();
 
$curl_opt = array(CURLOPT_URL, 'http://www.example.com/backend.php',
                            CURLOPT_RETURNTRANSFER, 1,
                            CURLOPT_TIMEOUT, 1,);
 
curl_setopt_array($ch, $curl_opt);
 
curl_exec($ch);
 
curl_close($ch);

4. Utiliser fsockopen
Cette méthode devrait être la plus parfaite, mais l'inconvénient est que vous devez épeler vous-même la partie de l'en-tête HTTP.

$fp = fsockopen("www.example.com", 80, $errno, $errstr, 30);
if (!$fp) {
    echo "$errstr ($errno)<br />\n";
} else {
    $out = "GET /backend.php  / HTTP/1.1\r\n";
    $out .= "Host: www.example.com\r\n";
    $out .= "Connection: Close\r\n\r\n";
 
    fwrite($fp, $out);
    /*忽略执行结果
    while (!feof($fp)) {
        echo fgets($fp, 128);
    }*/
    fclose($fp);
}

Donc, dans l’ensemble, la méthode la meilleure et la plus simple est la première méthode.
Le plus parfait devrait être le dernier, mais c'est plus compliqué.

Recommandations associées :

Analyse d'exemples d'appels asynchrones JavaScript

Comment implémenter des appels multi-thread asynchrones en PHP

À propos de la méthode d'appel asynchrone JavaScript

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!

Déclaration:
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