<?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 問題が解決したのかと思いましたが、そうではありません。現在のポート 25 は引き続き使用できます。