php が fsockopen を使用する場合、fwrite の rn および n ターミネータにより、smtp.qq.com 応答で問題が発生します
<?php$t= time();$sk = fsockopen('tcp://smtp.qq.com',25, $errno, $errstr, 5); echo "sockect ok:".(time()-$t)."\n"; if ( ! is_resource($sk) ) exit('connect error:'. $errno." ".$errstr);//设置成阻塞模式 stream_set_blocking ($sk,1);//获取初次链接信息var_dump( fgets($sk,512) );//设置读超时stream_set_timeout( $sk, 3 );var_dump( stream_get_meta_data( $sk ) );fwrite($sk,"EHLO qidizi.com\n");//这个会导致超时,个人判断应该是qq在等待一行的输入结束符,但是\n却不是,应该是\r\n才是,就会卡在这里不输出提示,这个问题,在以前的版本,及当前测试时,的163.com上面都没有发现有这个问题//fwrite($sk,"EHLO qidizi.com\r\n");//正确的一行结束符\r\n,立刻会得到响应var_dump( fgets($sk,512).':'.(time()-$t) );//上面的不会超时echo "4:".(time()-$t)."\n<br />";var_dump( stream_get_meta_data( $sk ) );fclose($sk);
テスト コード
最近の変更で qq サーバーが変更された可能性があります。以前は n を行末として使用できた、つまり fwrite($sk, "kkkn" ) して応答を取得できたことを思い出してください。 、fgets はすぐに成功します。163 をテストしたところ、n には問題がありませんでした。最近、qq の n に問題があることがわかりました。結果として、fgets はバッファーにコンテンツがないため、例外が発生します。しかし、qq は rn に変更すると正常になりました。
したがって、smtp.qq.com と smtp.exmail.qq.com の両方でこの問題が発生します。
SSL の問題ではないかと言う人もいましたが、そうではありませんでした。