Php Curl ile Bot Yapımı Php Hava Durumu Botu Php curl fonksiyonu

Php Bot Erdinç Koç 7.295 Görüntüleme

Php ’de bot yapmak gayet basit ve eğlencelidir. Günümüzde en çok başka sitelerden içerik (ç)almak amacıyla kullanılan botlar bir çok işe yarar ve harika fonksiyonları vardır.

Örneğin meteoroloji sitesinden bir PHP botu yardımıyla hava durumu bilgilerini veya borsa sitelerinden döviz kurlarını çekip kendi sitenizde en güncel şekilde yayınlayabilirsiniz.

PHP ile site içeriklerine ulaşmak
Bu işi yapmak için en basitinden file_get_contents() fonksiyonuna sahibiz. İçerisine yazazacağımız ilk parametredeki adrese girip kaynağı bir değişkene yüklememizi ya da ekrana yazdırmamızı sağlar.

$site = “http://www.site.com”;
$icerik = file_get_contents($site);
echo $icerik;
Bu örneği çalıştırdığımızda file_get_contents() fonksiyonu sayesinde http://www.phpr.org adresine girip sitenin kaynağına ulaşıp o kaynağı ekrana yazdırdık.

Sitelere ulaşmanın bir başka yolu yolu ise curl fonksiyonlarıdır. Curl fonksiyonları sayesinde bir adrese girmekle kalmayıp aynı zamanda girilen adrese form verileri gönderebiliriz ve kullanıcı girişi yapabiliriz. Yani PHP’de curl sayesinde sitelere aynı bir gerçek kullanıcıymış gibi, bir browserda gezer gibi girebiliriz.

Benim hazırlamış olduğum curl fonksiyonu ile istediğiniz adrese POST metodunda veri gönderebilirsiniz:

function curl($url, $post=false)
{
$user_agent = ‘Mozilla/5.0 (Windows; U; Windows NT 5.1; tr; rv:1.9.0.6) Gecko/2009011913 Firefox/3.0.6’;
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, $post ? true : false);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post ? $post : false);
curl_setopt($ch, CURLOPT_USERAGENT, $user_agent);
$icerik = curl_exec($ch);
curl_close($ch);
return $icerik;
}
Bu fonksiyonu aynı file_get_contents fonksiyonu gibi kullanabilirsiniz. Eğer bir post verisi gönderecekseniz 2. parametreyi “kullanici=musa&sifre=123456″ şeklinde kullanmanız gerekecek.

echo curl(“http://www.phpr.org/wp-login.php”, “user_login=kullanici&user_pass=sifre”);
Bu örnek kullanımda kendi sitemizin paneline giriş yapmak için kullanıcı adı ve şifremizi postlamış olduk. Doğru bilgileri yazdığımızda curl fonksiyonu sayesinde PHP üzerinden panelimize de ulaşabiliriz.

PHP botu ile belirli içerikleri alma
Sitelerin içeriklerine direkt olarak ulaştıktan sonra istediğimiz kısımdaki değeri ve içeriği almak için öncelikle bir ara belirlemeliyiz. Sitenin kaynak kodunu inceleyip ayırt edici bir aralık bulmalıyız.

Ben örnek bir içerik sunacağım, ve bu örnek içerikten istediğimiz kısmı alacağız. Metereoloji sitesinin İstanbul için verdiği sonuçların bulunduğu kısmın kaynak kodu aşağıdaki gibi:

<tr>
<th id=”ctl00_mpBody_thmGun1″>20 Haziran Pazar</th>
<td id=”ctl00_mpBody_thmMin1″>21</td>
<td id=”ctl00_mpBody_thmMax1″>30</td>
<td><img id=”ctl00_mpBody_imgHadise1″ title=”PARÇALI BULUTLU” src=”../FILES/imgIcon/99/a1-25×25-gif/-25.gif” alt=”PARÇALI BULUTLU” style=”border-width:0px;” /></td>
<td id=”ctl00_mpBody_thmNemMin1″>59</td>
<td id=”ctl00_mpBody_thmNemMax1″>93</td>
<td id=”ctl00_mpBody_thmRuzgarYon1″><img src=”../FILES/imgIcon/ruzgar/1/1.gif” alt=”Kuzeydoğudan” title=”Kuzeydoğudan” /> </td>
<td id=”ctl00_mpBody_thmRuzgarHiz1″>18</td>
<td id=”ctl00_mpBody_gcmMin1″>11.4</td>
<td id=”ctl00_mpBody_gcmMax1″>32.2</td>
<td id=”ctl00_mpBody_gcmMinOrt1″>16.7</td>
<td id=”ctl00_mpBody_gcmMaxOrt1″>25.5</td>
</tr>
Çok karışık bir kaynak kodu gibi görünüyor ama aslında tam bizim aradığımız gibi bir sonuç. Farkettiyseniz tüm değerler ayırt edilebilecek belli bazı elementlerin arasında. Örneğin tarih class=”arkaTrh”> ile </td> arasında.

Bir içerikte istediğimiz aralığı almak için yine curl gibi hazır bir fonksiyon kullanacağız. Bu fonksiyonu kopyala-yapıştır yaparak sizde kullanabilirsiniz.

function ara($bas, $son, $yazi)
{
@preg_match_all(‘/’ . preg_quote($bas, ‘/’) .
‘(.*?)’. preg_quote($son, ‘/’).’/i’, $yazi, $m);
return @$m[1];
}
Bu ara fonksiyonuda basit bir şekilde aralık içerisindeki değeri bize verir. Kullanımı için 3 parametre vardır. İlk parametre aralığın başı, ikinci parametre aralığın sonu, üçüncü parametre ise araştırılacak içerik.

$icerik = file_get_contents(“http://www.phpr.org”);
$baslik = ara(“<title>”, “</title>”, $icerik);
echo $baslik[0];
Bu örnekte sitemizin kaynak kodlarına ulaşıp <title>…</title> arasını yani sitemizin başlığını almış olduk ve ekrana yazdırdık. Değerin yüklendiği değişkene [0] dememizin sebebi ilk yakalanan aralığı almamız. Eğer benzer aralıklardan daha fazla var ise onlarıda dizinin diğer elemanları olarak ekleyecektir. Örneğin birden fazla title aralığı olsaydı diğer sonuçlarda [1], [2] şeklinde diğer dizilere sıralanacaktı.

Gelelim bu fonksiyonu bahsettiğimiz meteroloji sitesinde uygulamaya:

$site = “http://www.meteor.gov.tr/tahmin/il-ve-ilceler.aspx?m=ISTANBUL”;
$icerik = file_get_contents($site);
$alt_sicaklik = ara(‘class=”minS”>’, ‘</td>’, $icerik);
$ust_sicaklik = ara(‘class=”maxS”>’, ‘</td>’, $icerik);
echo ‘İstanbul hava durumu: ‘ . $ust_sicaklik[0] . ‘/’ . $alt_sicaklik[0];
Sitede alt ve üst sıcaklıkların bulunduğu değerlerin aralığını bulup ara fonksiyonumuz sayesinde aralığı alıp ekrana yazdırdık. Sonuç olarak ekranda İstanbul hava durumu: 21/30 şeklinde bir çıktı alacağız.

Kısaca bot içerik alma mantığı sitelerdeki içeriklerin ayırt edici aralıklarını bulup o kısmı almaya dayanmaktadır. Bunların dışında hayal gücünüzü kullanarak daha bir çok mantık üretebilir ve her türlü içeriğe ulaşıp dilediğiniz botları kodlayabilirsiniz.

Bu gönderiye oy ver

Sosyal Ağlarda Paylaş

“Php Curl ile Bot Yapımı Php Hava Durumu Botu Php curl fonksiyonu” üzerine 4 yorum

  1. Avatar of Paylaşım Alemi Paylaşım Alemi dedi ki:

    Mükemmel paylaşım.Teşekkürler

  2. Avatar of erdinç erdinç dedi ki:

    bot denedim çalışmıyor hocam

    1. Avatar of Erdinç Erdinç dedi ki:

      Sunucununuzda Curl Çalışıyormu Curl Çalışmaz ise bot çalışmaz.

  3. Avatar of Kocaeli haberleri Kocaeli haberleri dedi ki:

    eline sağlık hocam teşekkürler

Bir yanıt yazın

E-posta adresiniz yayınlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir