【发布时间】:2011-10-23 21:39:54
【问题描述】:
我正在尝试制作一个脚本,用于搜索表单中给出的 url 列表以查找电子邮件地址。谁能建议我怎么做? cURL 有什么替代品吗? 我尝试使用 file_get_contents,但脚本仅分析表单中给出的最后一个 url:当我在表单中输入例如两个 url 时,第一个 "print_r("show current_url:".$current_url); 是空的并且第二个它显示页面(url)内容(没有图片)。
我在不同的论坛上问过,但没有得到答复。非常感谢您的帮助。
谢谢
$urls = explode("\n", $_POST['urls']);
$db = new mysqli('localhost', 'root', 'root', 'urls');
if (mysqli_connect_errno()) {
echo 'Błąd: ';
exit;
}
for ($i=0; $i<count($urls); $i++){
print_r("show link:". $urls[$i]."<br>");
$current_url = file_get_contents($urls[$i]);
print_r("show current_url:". $current_url);
preg_match( "/[\._a-zA-Z0-9-]+@[\._a-zA-Z0-9-]+/i", $current_url, $email);//email
print_r ("show email:".$email[0]);
$query = "INSERT INTO urle set adres = '$email[0]' ";
$result = $db->query($query);
}
if ($query) {
echo $db->affected_rows ."pozycji dodano.";
} else {
echo mysql_errno() . ":" . mysql_error() . "Wystąpił błąd przy dodawaniu urli ";
}
$db->close();
?>
编辑: 我试过卷曲。 var_dump($email);显示:数组(0){} 该脚本现在在浏览器中显示表单中给出的所有 url,但 preg_match 不起作用,因此它不会提取电子邮件地址。
<?php
$urls = explode("\n", $_POST['urls']);
$db = new mysqli('localhost', 'root', 'root', 'linki');
if (mysqli_connect_errno()) {
echo 'Błąd: ';
exit;
}
for ($i=0; $i<count($urls); $i++){
$url = $urls[$i];
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_URL, $url);
$output = curl_exec($ch);
preg_match( "/[\._a-zA-Z0-9-]+@[\._a-zA-Z0-9-]+/i", $output, $email);//email
var_dump($email);
$query = "INSERT INTO urle set adres = '$email[0]' ";
$result = $db->query($query);
curl_close($ch);
}//
if ($result) {
echo $db->affected_rows ."pozycji dodano.";
} else {
echo mysql_errno() . ":" . mysql_error() . "Wystąpił błąd przy dodawaniu urli ";
}
$db->close();
?>
【问题讨论】:
标签: php parsing curl file-get-contents