<?php//define server info begin$servername = "192.168.1.182"; $serverusername = "whh"; $serverpassword = "whh"; $database="whh";$usertable="user";$userfield="user_name";$passwordfield="password";//define server info end$fh = fopen("php://stdin", 'r');$stdout = fopen('php://stdout', 'w');$fs = fopen("auth-log.txt." . getmypid(), 'a');if(!$fh){ die("Cannot open STDIN\n");}do{ $lenBytes = fgets($fh, 3); $len = unpack('n', $lenBytes); $len = $len[1]; if($len<1) continue; $msg = fgets($fh, $len+1); $toks=explode(':',$msg); fwrite($fs, $msg . "\n"); $method = array_shift($toks); fwrite($fs, "$method\n"); $result = false; switch($method){ case 'auth': list($username, $server, $password) = $toks; $password = trim($password); fwrite($fs, "checking user: $username and password $password\n"); //check password begin $conn=mysql_connect($servername, $serverusername, $serverpassword); mysql_query("set names 'utf8'"); if(!$conn){ die("could not connect to the database"); } $db_select=mysql_select_db($database);//选择数据库 if(!$db_select) { die("could not to the database"); } $query="select * from $usertable where $userfield = '$username' and $passwordfield='$password'";//构建查询语句 $result=mysql_query($query);//执行查询 $count=mysql_numrows($result);//取得条数 mysql_close($conn); if($count > 0){ $result = true; }else{ $result = false; } //check password end break; case 'isuser': list($username, $server) = $toks; //check password begin $conn=mysql_connect($servername, $serverusername, $serverpassword); mysql_query("set names 'utf8'"); if(!$conn){ die("could not connect to the database"); } $db_select=mysql_select_db($database);//选择数据库 if(!$db_select) { die("could not to the database"); } $query="select * from $usertable where $userfield = '$username'";//构建查询语句 $result=mysql_query($query);//执行查询 $count=mysql_numrows($result);//取得条数 mysql_close($conn); if($count > 0){ $result = true; }else{ $result = false; } //check password end break; default: $result = false; } $message = @pack("nn", 2, $result); fwrite($stdout, $message); $dump = @unpack("nn", $message); $dump = $dump["n"]; fwrite($fs, $dump . "\n"); flush();} while(true);
最適化するものは何もありません
受信データには認証のみがある可能性もあれば、isuser のみの可能性もあり、おそらくどちらも存在しない可能性があります
データベースにアクセスする可能性がある状況では、これは完全に不要です必要ありません 次に、データベース接続を行います
プログラムの最適化はコードを減らすことではなく、パフォーマンスを向上させることです
受信パラメータが一貫している場合、$conn とその判断は do... の前に言及できます。 while
入力パラメータがすべて一致している場合、$conn とその判断を do...while の前に記述することができます。入力パラメータが一貫している場合、$conn とその判断は do...while で言及できます
質問があればフォローしてください ~~
受け取ったパラメータが一貫している場合、$conn とその判断は do ..while で言及できます
投稿してください。聞いてください、老徐にとってそれは難しいですが、多くの人にとっては簡単です
あなたが誰かのウェブゲームのプライベートチャットに返信したのを見ましたが、あなたはそうしますか?
ご質問があれば質問させていただきます~~
投稿を投稿してください。老徐が行動を起こすのは難しいですが、簡単です 多くの人が行動を起こしました
あなたが誰かのウェブゲームのプライベートチャットに返信したのを見ましたが、あなたもそうしますか?
いや、原理はわかっているだけです
入力パラメータが一貫している場合、$conn とその判断は do...while の前に記述できます
ご注意ください。ご不明な点がございましたら、お問い合わせください。 ~~
質問する投稿を投稿する まあ、Lao Xu が行動を起こすのは難しいですが、多くの人が行動を起こすのは簡単です
あなたがウェブ ゲームで誰かのプライベート チャットに返信したのを見ましたが、実行しますか?
いいえ、原理だけは知っています
ああ、わかりました、ありがとうございます。でも、この種の手順を実行できる人を知っていますか?
ああ、分かった、ありがとう、でもこの種の手続きができる人を知っていますか?
最近は PHP をほとんど書いていないので、仕方ありません
私たちのプロジェクトで使用されているチャットサーバーは ejabberd であるためです。現在、クライアントは smack 経由で接続されています。
同時ユーザー ログインの最大数は 5 人だけであることがわかりました。
A.smack クライアント。
B. ejabberd サーバー自体の構成
C. ejabberd が外部検証を実行する場合、php 経由で mysql に接続します。 (なのでphpで最適化できるものがないか見ていきます)
pdo, prepare() を使用します