[]

Session değişkenini alamıyorum - PHP

Uzunca bir kod olucak ama; sorun da kısaca şöyle, her sayfanın başında session_start() kullanmama rağmen login olduktan sonra aktarılan sayfada username'i $author = $_SESSION['username'] olarak kullanamıyorum.


login.php
---------
<?php

require 'blogclass.php';

session_start();


if( isset($_SESSION[$username]) )
{
header("location: blogposts.php");
}


if(isset($_POST['username'])){$username= strip_tags($_POST['username']);}
if(isset($_POST['password'])){$password= strip_tags($_POST['password']);}
if(isset($_POST['login'])){$submit= $_POST['login'];}

if(isset($_POST['login']) && $submit)
{
if($username && $password)
{
$Valid = blogclass::UserLogin($username, $password);
if( $Valid )
{
echo "Success";
@$_SESSION['username'] = $username;
header("location: blogposts.php");
}
}
else
die("Wrong!");
}

?>

----*


class'daki login fonksiyonu
-------

public static function UserLogin($username,$password)
{
self::init();
if(!$username || !$password){
return FALSE;
}

$password = md5($password);

$result = self::$conn->query("SELECT first_name FROM user WHERE username = '$username' AND password = '$password'");

if (self::$conn->affected_rows == -1 || self::$conn->affected_rows == 0) {
return FALSE;
}


return TRUE;
}


------*

 
@$_SESSION['username'] = $username;
satirindaki @ isaretini kaldirir misin, hata verirse diye onu baskiliyor.

bir de tam bilmiyorum ama:
if( isset($_SESSION[$username]) )
satirinda $_SESSION[$username] yerine $_SESSION["username"] seklinde kontrol etmesi gerek miyor mu
  • jedilance  (05.06.15 00:43:35) 
evet "username" olmalıydı, ama onla da çalışmıyor.


  • ikincihesap  (05.06.15 01:07:23) 
session_start()'i requirein uzerine almayi denedin mi?


  • ay nov kung fu  (05.06.15 01:14:13) 
evet denedim ama o da olmadı.


  • ikincihesap  (05.06.15 01:22:20) 
Ya simdi fonksiyonun true donuyor yani aldigin valid degeri true, if kosuluna yalnizca valid yerine valid=true koymayi denedin mi? Aklima gelen diger ihtimaller: hata almadigina gore ya inputlari alamiyorsun ya da db baglantisi/query sonuc dondurmuyor.
Bir de benim arada ne hikmetse require yerine include kullaninca butun problemlerimin hallolmasi var ki cok sacma, o yuzden bosver. Bi' de yukaridaki if isset session olan header neden? Login olunca session baslayacak $username i kullanacaksin zaten o sayfanin basindaki ne icin?

  • ay nov kung fu  (05.06.15 01:43:17) 
onları şey diye düşündüm, eğer kullanıcı daha önce login olmuşsa login sayfasına gelmesin başka yere gitsin gibi. ya da şu işe de yarar sanıyorum, username session olduktan sonra başka sayfaya yönlendirme gibi..


  • ikincihesap  (05.06.15 02:09:52) 
tüm kodu pastebin'e falan düzgün şekilde paste et de bakalım, onun haricinde tahmin ediyorum ki php.ini deki ayarların düzgün değil, işletim sisteminin tmp dizinine yada php.ini dosyasındaki session'ların kaydedildiği dizine bir bak, her istekte yeni bir dosya mı oluşturuyor? eğer öyle ise session id'nin hangi yol ile gönderileceğini belirleyen php.ini dosyasındaki session.* ları kontrol et.


  • selam  (05.06.15 03:25:29) 
1
buraya yazılanların hakları Sir Anthony Hopkins'e aittir.
yazan eden compumaster, ilgilenen eden fader
modere edenler basond, compumaster, fraise, kibritsuyu, rakicandir
bu sitede yazılanların hiçbiri doğru değildir. site içeriği küçükler için sakıncalı olabilir. yazılardan yazarları sorumludur. kaynak göstermeden alıntılanamaz. devlet tarafından atanmış bir kurumun internet üzerinde kimin hangi bilgiye ulaşıp ulaşamayacağına karar vermesi insan haklarına aykırıdır. web siteleri kullanıcıların istekleri doğrultusunda bağlandıkları yerlerdir. kullanıcılar isterlerse bir web sitesine bağlanmayabilirler. bu güçleri ve imkanları mevcuttur. bir kullanıcı bir siteye bağlanmak istiyorsa bu onun tercihi ve hakkıdır. bağlanmak istemiyorsa bu yine onun tercihi ve hakkıdır. halkın kendisine hizmet etmesi için görevlendirdiği kurumlar hadlerini aşıp halka neye ulaşıp ulaşmayacağını bilmeyen cahil cühela muamelesi edemezler. ebeveynlerin çocuklarını sakıncalı içeriklerden koruması için çok sayıda bedava ve ücretli yazılım mevcuttur. bu yazılımlar bir web tarayıcısını kullanmaktan daha karmaşık teknik bilgi gerektirmemektedir. devletin milletini küçük düşürmesi ve ebleh yerine koyması yasaktır. Skimlinks ile linkler üzerinden yönlendirme payı alınmaktadır.