script yazımında bunlara dikkat edin ! - Google Fan Webmaster Forum
Google Fan Webmaster Forum  

Geri git   Google Fan Webmaster Forum > Server Side Programlama > PHP
Kayıt ol Articles Sosyal Gruplar Forumları Okundu Kabul Et

PHP R10.net Php sevenler klubü. Kodlama soru(n)ları & acil php yardım hattı.

Like Tree4Likes

Cevapla
 
LinkBack Seçenekler
  1  
Alt 01-10-2007, 17:11:50
 
Standart script yazımında bunlara dikkat edin !

script yazarken, mümkün olduğu kadar az hidden input kullanmaya çalışın. yani, sadece gerekli bilgileri hidden input ile gönderin. diğerleri için session kullanın ya da doğrudan sorgu üzerinde işlem yapın.

mesela, bir yazı scripti, yorumlama da var. eğer yaziid veya onay gibi bir veriyi input ile yolluyorsanız, uyanık birisi çıkıp bu veriyi değiştirebilir ve karışıklıklara yol açabilir. bunları sessionlarla ya da doğrudan sorgudan yollamaya özen gösterin.

bütün post verilerini filtreleyin, sql injection veya başka hack girişimlerine izin vermemiş olursunuz. benim her zaman kullandığım filtreleme fonsiyonu aşağıda, bununla filtreleseniz yeterli olur.
PHP- Kodu:
if (!function_exists("GetSQLValueString")) {
function 
GetSQLValueString($theValue$theType$theDefinedValue ""$theNotDefinedValue ""
{
  
$theValue get_magic_quotes_gpc() ? stripslashes($theValue) : $theValue;

  
$theValue function_exists("mysql_real_escape_string") ? mysql_real_escape_string($theValue) : mysql_escape_string($theValue);

  switch (
$theType) {
    case 
"text":
      
$theValue = ($theValue != "") ? "'" $theValue "'" "NULL";
      break;    
    case 
"long":
    case 
"int":
      
$theValue = ($theValue != "") ? intval($theValue) : "NULL";
      break;
    case 
"double":
      
$theValue = ($theValue != "") ? "'" doubleval($theValue) . "'" "NULL";
      break;
    case 
"date":
      
$theValue = ($theValue != "") ? "'" $theValue "'" "NULL";
      break;
    case 
"defined":
      
$theValue = ($theValue != "") ? $theDefinedValue $theNotDefinedValue;
      break;
  }
  return 
$theValue;
}

kullanımı:
$_POST['veri'] yerine, GetSQLValueString($_POST['veri'], "text")
"text" kısmını int olarak da değiştirebilirsiniz, sadece sayı girilecekse bu bölümde. bu fonksiyon aynı zamanda verinin başına ve sonuna ' ekler ve içindeki ' karakterlerini \' haline getirir. yani doğrudan sql'e giriş için hazırlar.

veritabanında bir session tablosu oluşturup bütün ip'leri tek tek buraya kaydettirmeniz, flood saldırılarına karşı etkili olmanızı sağlar. mesela, ip adresini ve aktivite zamanını kaydedersiniz tabloya. her hareketinde zamanı güncellersiniz. kişinin 1 sn içinde 1'den fazla sayfaya girmesini engelleyerek de kötü niyetli kişilerin verebileceği zararları azaltmış olursunuz.

mysql bağlantısı kurarken, sunucunuzun özelliklerine ve ayarlarına göre, mysql_connect veya mysql_pconnect arasında karar vermelisiniz. mysql_pconnect kullandığınızda mysql_close kullanmanıza gerek kalmayacaktır, çünkü mysql_pconnect ile kullanıcı başına bir bağlantı soketi açarsınız ve bu bağlantı soketi, timeout'a uğradığında kendisi kapanır, bu yüzden bu timeout süresi kısa tutulmalıdır. Yüksek hitli sitelerde bu tercih edilmelidir. mysql_connect kullanıldığında ise, bunu her seferinde mysql_close ile kapatmazsanız sunucuyu mahfedersiniz, load havalara uçar. çünkü mysql_connect, her kullanıcının her sorgusu için ayrı ayrı bağlantı soketi açmaktadır, mysql_close ile bunlar kapatılmadığında sunucu kendinden geçer.

mümkün olduğu kadar veritabanı sorgularınızı basit tutun. mesela, yazi tablosunda kaç satır olduğunu gösterecekseniz, select * from yazi yapacağınıza select id from yazi şeklinde oluşturun sorgunuzu. bu şekilde sunucunuzu daha az yormuş olursunuz.

aklıma gelen şeyler bunlar, aklıma geldikçe eklerim
Bu mesajınızı beğenenler: Bally
Alıntı ile Cevapla


Sponsored Links
  2  
Alt 02-10-2007, 22:20:42
 
Standart

TeşekkürLer Dost hoş oLmuş (:
Alıntı ile Cevapla


  3  
Alt 03-10-2007, 02:06:57
 
Standart

Post edilmiş veriyi gizleme olayı biraz üst düzey olmuş gibi geldi bana.Zira verdiğin kod bloğundaki syntaxları ilk kez görüyorum desem yeri var Ama connect olayını anlatman iyi olmuş , o konuda eksiğim vardı ,şimdi tamamlandı teşekkürler
Alıntı ile Cevapla


  4  
Alt 09-10-2007, 01:26:05
 
Standart

teşekkürler
Alıntı ile Cevapla


  5  
Alt 14-10-2007, 13:21:20
 
Standart

teşekkür ederim kapsamlı bir filtre gerekiyordu güzel oldu bu
__________________
Backlink Sivas Bıçakları
Alıntı ile Cevapla


  6  
Alt 15-11-2007, 12:07:07
 
Standart

evet güzel bir anlatım olmuş ellerine sağlık... bu konuda çoğu kişisinin eksiği var bende o kişilere dahildim
__________________
Anma Arkadaş!
Alıntı ile Cevapla


  7  
Alt 23-12-2007, 22:00:22
 
Standart

sağol Bartuc
__________________
__________________
Alıntı ile Cevapla


  8  
Alt 10-01-2008, 15:24:12
Gold üye
 
Standart

Alıntı:
Bartuc Nickli Üyeden Alıntı Mesajı göster
mümkün olduğu kadar veritabanı sorgularınızı basit tutun. mesela, yazi tablosunda kaç satır olduğunu gösterecekseniz, select * from yazi yapacağınıza select id from yazi şeklinde oluşturun sorgunuzu. bu şekilde sunucunuzu daha az yormuş olursunuz.
PHP- Kodu:
select count(idfrom tablo 
daha iyi olur sanırsam bütün veriyi alıp sonra mysql_num_rows la aldırmakta boşuna yorar makinayı

güzel makale teşekkür.
Alıntı ile Cevapla


  9  
Alt 10-01-2008, 18:44:39
 
Standart

teşekkürler bartuc
Alıntı ile Cevapla


  10  
Alt 19-01-2008, 15:52:32
 
Standart

Eyvallah güzel fonksiyon kütüphaneme kayıt ettim. Ek bi şey diyeyim. Diyelim ki çevrim içi ziyaretçi tablosunuz var. Çok giriş çıkış olan sitelerinizde bu tabloyu optimize ettirin.
__________________
resim
Alıntı ile Cevapla


Cevapla


Bookmarks
tesxc
Seçenekler

Yetkileriniz
Konu Acma Yetkiniz Yok
Cevap Yazma Yetkiniz Yok
Eklenti Yükleme Yetkiniz Yok
Mesajınızı Değiştirme Yetkiniz Yok

BB code is Açık
Smileler Açık
[IMG] Kodları Açık
HTML-Kodu Kapalı
Trackbacks are Kapalı
Pingbacks are Kapalı
Refbacks are Açık



Tüm Zamanlar GMT +3 Olarak Ayarlanmış. Şuanki Zaman: 04:44:43.


Powered by vBulletin® Version 3.8.4
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.

“İnsanların en hayırlısı, insanlara faydalı olandır”. H.Ş

Hosting by Radore Hosting

İçerik sağlayacı paylaşım sitelerinden biri olan R10.net WebMaster Forum Adresimizde 5651 Sayılı Kanun’un 8. Maddesine ve T.C.K’nın 125. Maddesine göre TÜM ÜYELERİMİZ yaptıkları paylaşımlardan sorumludur. R10.net hakkında yapılacak tüm hukuksal Şikayetler adresi ile iletişime geçilmesi halinde ilgili kanunlar ve yönetmelikler çerçevesinde en geç 1 (Bir) Hafta içerisinde R10.net yönetimi olarak tarafımızdan gereken işlemler yapılacak ve Avukatlarımız size dönüş yapacaktır.
ARGUS_OK