
18-03-2010, 16:02:39
|
| |
PHP-Fusion Facebook Connect Entegrasyonu [BETA] | | Arkadaşlar, birkaç gündür bununla uğraşıyorum, şu an bende çalışıyor ama sizin de denemeniz lazım Alıntı:
PHP-Fusion Facebook Entegrasyonu 1.01
PHP-Fusion 7.x içindir.
Kodlama: Arda Kılıçdağı (SoulSmasher)
Web: www.soulsmasher.net , www.phpfusionturkiye.com
Bu kodlama barattalo.it in güzel makalesi üzerine hazırlanmıştır
This program is released as free software under the
Affero GPL license. You can redistribute it and/or
modify it under the terms of this license which you
can read by viewing the included agpl.txt or online
at www.gnu.org/licenses/agpl.html. Removal of this
copyright header is strictly prohibited without
written permission from the original author(s).
ÖZELLİKLER
--------------
Bu modifikasyon Facebook hesabınız ile PHP-Fusion üzerinden giriş olanağı sağlar.
Giriş sonrasında sistem önceden giriş yaptığınıza bakar, eğer girmemişseniz otomatik olarak sizin için yeni bir kullanıcı oluşturur.
Bağlantı sonunda oluşturulan hesap ad soyadınızı, profil resminizi (avatar), halka açık halde gösteriliyorsa direkt e-posta adresinizi, gösterilmiyorsa facebook korumalı posta adresinizi barındırmaktadır.
MEVCUT DİL DOSYALARI
---------------
-İngilizce
-Türkçe
KURULUM
--------------
-files kısmındaki her şeyi PHP-fusion kök klasörünüze yükleyin
-Yönetici paneli->Sistem Yönetimi->Bloklar kısmına gidip facebook_login_panel i ekleyip aktifleştirin.
-Şimdi http://developers.facebook.com/setup.php adresine girip Web sitesi adresiniz ile (başında http:// olarak) kendi programınızı (application) oluşturun. Bundan sonra size xd_receiver.htm diye bir dosya verecek, onu sitenizin kök klasörüne yükleyin ve de sitenizi o dosya yardımı ile doğrulayın.
-Doğrulama sonrasında, Facebook Developers page (Facebook geliştiriciler sayfası)'na yönlendirileceksiniz, orada API ve SECRET KEY adlı 2 anahtar şifre var. facebook_system.php yi açıp şu 2 satırı o değerlerle doldurun: Kod: define("FB_API_KEY","facebookapikeyhere");
define("FB_SECRET","facebooksecretkeyhere"); -Şimdi şunu özel sayfalarda bir kez önizletin: Kod: <?php
$soul=dbquery("ALTER TABLE ".DB_USERS." ADD user_fb_userid BIGINT(16) UNSIGNED NOT NULL DEFAULT '0'");
$soul=dbquery("ALTER TABLE ".DB_USERS." ADD user_fb_hash VARCHAR(32) NOT NULL DEFAULT ''");
$soul=dbquery("ALTER TABLE ".DB_SETTINGS." ADD facebook_salt VARCHAR(32) NOT NULL DEFAULT ''");
$soul=dbquery("UPDATE ".DB_SETTINGS." SET facebook_salt='".md5(rand(0,9999999))."'");
?> Bu aşamadan sonrasında ister düzenlenmiş dosyaları kullanın, ister aşağıdaki metotla kendiniz düzenleyin, size kalmış.
-Şimdi maincore.php'yi açın, bulun: Kod: $user_pass = md5($_POST['user_pass']); Değiştirin: Kod: if (isset($_POST['user_fb_hash'])) { $user_pass = $_POST['user_fb_hash']; } else if (isset($_POST['user_pass'])) { $user_pass = md5($_POST['user_pass']); } -Bulun: Kod: $cookie_value = $data['user_id'].".".$user_pass;
Üzerine Ekleyin:
//update facebook hash if not done yet
if ($data['user_fb_hash']=="") { $result2=dbquery("UPDATE ".DB_USERS." SET user_fb_hash='".md5($data['user_password'])."' WHERE user_id='".$data['user_id']."'"); }
//update facebook hash -Bulun: Kod: if (isset($_POST['login']) && isset($_POST['user_name']) && isset($_POST['user_pass'])) { Değiştirin: Kod: if (isset($_POST['login']) && isset($_POST['user_name']) && (isset($_POST['user_pass']) || isset($_POST['user_fb_hash']))) { -Bulun: Kod: $result = dbquery("SELECT * FROM ".DB_USERS." WHERE user_name='".$user_name."' AND user_password='".md5($user_pass)."' LIMIT 1"); Şöyle Değiştirin: Kod: if (isset($_POST['user_fb_hash'])) {
$result = dbquery("SELECT * FROM ".DB_USERS." WHERE user_name='".$user_name."' AND user_fb_hash='".facebook_crypt($_POST['user_fb_hash'])."' LIMIT 1");
} else {
$result = dbquery("SELECT * FROM ".DB_USERS." WHERE user_name='".$user_name."' AND user_password='".md5($user_pass)."' LIMIT 1");
} -Bulun: Kod: $result = dbquery("SELECT * FROM ".DB_USERS." WHERE user_id='$cookie_1' AND user_password='".md5($cookie_2)."' LIMIT 1"); Değiştirin: Kod: $result = dbquery("SELECT * FROM ".DB_USERS." WHERE user_id='$cookie_1' AND (user_password='".md5($cookie_2)."' OR user_fb_hash='".facebook_crypt($cookie_2)."') LIMIT 1"); -Bulun: Kod: // Initialise the $locale array
$locale = array();
Üzerine Ekleyin:
//this function is to inprove security of user_fb_hash column.
function facebook_crypt($string) {
global $settings;
return md5($string.$settings['facebook_salt']);
}
//function end -includes/update_profile_include.php yi açıp şu kodu bulun: Kod: $new_pass = " user_password='".md5(md5($user_new_password))."', "; Şöyle değiştirin: Kod: $new_pass = " user_password='".md5(md5($user_new_password))."', user_fb_hash='".facebook_crypt(md5(md5($user_new_password)))."'"; -administration/updateuser.php yi açıp bulun: Kod: if ($user_new_password) { $new_pass = " user_password='".md5(md5($user_new_password))."', "; } else { $new_pass = " "; } Şöyle değiştirin: Kod: if ($user_new_password) { $new_pass = " user_password='".md5(md5($user_new_password))."', user_fb_hash='".facebook_crypt(md5(md5($user_new_password)))."'"; } else { $new_pass = " "; } Biliyorum, biraz zahmetli, ama sizce de sonucuna değmez mi 
BİLİNEN HATALAR
--------------
-Bazen şunun gibi birkaç hata çıkabilir:
Fatal error: Uncaught exception 'FacebookRestClientException' with message 'Session key invalid or no longer valid' in..
Bunun sebebi Facebook API den dolayı, session timeout yapmakta anlamsızca. Bu olursa düzeltmek için önce facebookdan çıkış yapıp yeniden deneyin, devam ederse cookielerinizi temizleyin.
İPUÇLARI
-------------
Facebook hızlı popup yerine direkt facebook.com a yönlendirilip oradan giriş yapmak isterseniz facebook_system.php de şu kodu bulun, ve başındaki // işarerini kaldırın:
//$fb->require_login();//uncomment this if you want to want to redirect to facebook.com to login the user.
SÜRÜM GEÇMİŞİ
-------------
1.01 - Düzenlenmiş dosyalar eklendi
Düzenlemedeki ufak bir sorun giderildi
Blok resmi linklendi.
1.0 - İlk Sürüm
| Buyrun: http://www.phpfusionturkiye.com/infu...ad.php?did=225
Konu SoulSmasher tarafından (18-03-2010 Saat 17:10:50 ) değiştirilmiştir..
|