1

我正在尝试从代理后面连接到外部 SMTP 服务器。我想出了如何让 fsockopen 从代理后面获取网站,但不知道如何连接到 SMTP 服务器。SMTP 服务器需要 TLS 连接以及用户名和密码身份验证。

我从代理后面获取网页的内容是以下代码。

<?
$proxy_fp = fsockopen('111.111.111.111', '80');

if (!$proxy_fp) {
    return false;
}

fputs($proxy_fp, "GET http://wwww.google.com HTTP/1.0\r\nHost: 111.111.111.111\r\n\r\n");
while (!feof($proxy_fp)) {
    $proxy_cont .= fread($proxy_fp, 4096);
}
fclose($proxy_fp);
$proxy_cont = substr($proxy_cont, strpos($proxy_cont, "\r\n\r\n") + 4);
return $proxy_cont;
?>

现在如何让代理连接到 SMTP 服务器?


- - 编辑 - -

<?
$s = "\r\n";

$proxy = '24.47.131.253';
$port = 8123;

$fp = fsockopen($proxy, $port);
socket_set_timeout($fp, 10, 0);

fputs($fp, "CONNECT smtp.domain.com:25 HTTP/1.0".$s.$s);

while(!feof($fp)){
    $line = fgets($fp, 4000);
    echo $line."\n";
}
fclose($fp);
?>

我现在有这个基于答案。问题是我没有从 SMTP 服务器得到响应,它只是打印空行。有人能指出我正确的方向吗?

4

1 回答 1

2

SMTP 和 HTTP 不是相互兼容的协议;事实上,它们彼此完全不同。

您可以尝试使用HTTP CONNECT方法中的漏洞:而不是 GET 或 POST,而是发送CONNECT yourserver:yourport HTTP/1.0- 您应该获得到请求的主机和端口的 TCP 连接(请参阅此以获得更完整的参考)。请注意,某些代理会将允许的目标端口限制为 443 (HTTPS) 或以其他方式检查 CONNECT 流量,以防止人们通过隧道访问任何服务(例如 SMTP)。

请注意,在大多数组织中,此类操作可能会被解释为“规避访问控制和/或安全策略”,因此请谨慎行事。

于 2011-02-01T12:58:49.567 回答