• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Błąd przy użyciu userdata w Codeigniter

VPS Starter Arubacloud
0 głosów
188 wizyt
pytanie zadane 14 listopada 2017 w PHP przez Ambroz Obywatel (1,840 p.)

Witam szanowne forum.

Ponownie zwracam się do was z prośbą o pomoc. Napotkałem problem z userdata.

Kod:

public function check_user($email, $password){

    $query = $this->db->select('user_login, user_password, status, user_group')
                      ->from('users')
                      ->join('user_group', 'user_group_id=user_group')
                      ->where('user_login', $email)
                      ->where('user_password', $password)
                      ->get();

    if($query -> num_rows() == 1)
    {
      $r = $query->row();
      $login = $r->user_group;
      $name = $r->user_login;

      $this->session->userdata('user') = $name; //<- tu problem
      
      //$this->session->user = $name;
      //$this->session->user_log_in = $login;
      //echo "<pre>";
      //var_dump($this->session->user);die;

      // return $query->result();
    }
    else
    {
      echo "nic nie ma";die;
      return false;
    }

 No i oczywiście komunikat jaki dostaje:

Can't use method return value in write contex

P.S w tym kodzie to jest linia 16-sta

Z góry dziękuje za pomoc.

1 odpowiedź

+1 głos
odpowiedź 14 listopada 2017 przez HaKIM Szeryf (87,590 p.)
wybrane 14 listopada 2017 przez Ambroz
 
Najlepsza

(W pracy brak polskiej klawiatury; brak ogonkow)

Polecam zapoznac sie z dokumentacja.

To, co probujesz zrobic:

https://3v4l.org/9ieMD

Rozwiazanie:

$this->session->set_userdata($name);

Ps. Codeigniter jest przestarzalym frameworkiem.

komentarz 14 listopada 2017 przez Ambroz Obywatel (1,840 p.)
Nie jest to rozwiązanie, gdyż później dostaje null jak próbuje zrobić var_dump( $this->session->userdata($name)). Chyba, ze ja coś źle rozumiem.
komentarz 14 listopada 2017 przez HaKIM Szeryf (87,590 p.)

Cos zle zrobiles. ;)

Tak to nie dziala. Musisz po nazwie wyciagac.

Czyli, jezeli $name = 'Krzysztof';

To: $this->session->userdata('Krzysztof');

Tzn. jak jestes na innej stronie. W tym samym pliczku, gdzie $name jeszcze istnieje, powinno dzialac. Oh, czekaj! A sprobuj var_dump($this->session->userdata()) i sprawdz czy jest tam nasz Krzysztof, czy co tam dales. :D

Mozesz rowniez sprobowac z czyms takim:

$this->session->set_userdata('name', $name);

Jeszcze raz zachecam; odwiedz dokumentacje. Sam calej nie przeczytalem, tylko zerkam; choc, Ty mozesz, a nawet powinienes, przeczytac caly ten rozdzial; nie musialbys wtedy pytac mnie. :D

komentarz 14 listopada 2017 przez Tomek Sochacki Ekspert (227,510 p.)

Ps. Codeigniter jest przestarzalym frameworkiem.

Nie przesadzałbym tak... sam kiedyś z niego korzystałem w prostych stronkach i sprawdzał się bardzo fajnie. Jest teraz wersja 4, chyba już stabilna, ale tego nie jestem pewien bo już jakiś czas nie siedzę w PHP.

Myślę, że to ciekawy framework na początek, żeby zrozumieć MVC. Do bardziej zaawansowanych apek to faktycznie są lepsze frameworki ale na proste rzeczy w zupełności może być.

1
komentarz 14 listopada 2017 przez HaKIM Szeryf (87,590 p.)

Nie przesadzałbym tak... sam kiedyś z niego korzystałem w prostych stronkach i sprawdzał się bardzo fajnie. Jest teraz wersja 4, chyba już stabilna, ale tego nie jestem pewien bo już jakiś czas nie siedzę w PHP.

Myślę, że to ciekawy framework na początek, żeby zrozumieć MVC. Do bardziej zaawansowanych apek to faktycznie są lepsze frameworki ale na proste rzeczy w zupełności może być.

Well, na obecne standardy PHP CI jest przestarzaly.

Polecam Slim albo, jak wyjdzie, Symfony 4. ^^ 

komentarz 14 listopada 2017 przez Ambroz Obywatel (1,840 p.)
Pozwolę sobie zmienić pewne dane, ale to dostałem po sprawdzeniu samego userdata.
array(5) {
  ["__ci_last_regenerate"]=>
  int(1510650447)
  ["user_log_in"]=>
  string(1) "1"
  ["user"]=>
  string(25) "texttestowt"
  ["texttestowy"]=>
  NULL
  ["name"]=>
  NULL
}

To co ma w user i user_log_in zapewne pochodzi z tego:

      $this->session->user = $name;
      $this->session->user_log_in = $login;

 

komentarz 14 listopada 2017 przez HaKIM Szeryf (87,590 p.)

Coz, wszystko sie zgadza, o ile $name jest rowny null. ^^

Sprobuj, zamiast zmiennej $name wpisac na sztywno tekst.

Mozliwe, ze:

      $name = $r->user_login;

nie zawiera zadnych danych. wink

komentarz 14 listopada 2017 przez Ambroz Obywatel (1,840 p.)

Zawiera, gdyż sprawdzałem.

var_dump($name);die;
string(25) "texttestowy"

 

1
komentarz 14 listopada 2017 przez HaKIM Szeryf (87,590 p.)

Haha, no dobra. :D

W takim wypadku:

Machnij raz:

$this->session->unset_userdata('texttestowy');
$this->session->unset_userdata('name');

Nastepnie:

$this->session->set_userdata('name', $name);

Nie zapomnij usunac unser_userdata!

Mozesz sprawdzic czy smiga poprzez:

$this... albo inaczej: https://www.codeigniter.com/user_guide/libraries/sessions.html#adding-session-data

Nie przepadasz za czytaniem dokumentacji, co? Nawet, o dziwo, tak dobrej jak CodeIgniter'a. Chyba najlepsza dokumentacja z jaka sie spotkalem jesli chodzi o frameworki; przyjemnie sie czyta. :)

komentarz 14 listopada 2017 przez Ambroz Obywatel (1,840 p.)

Wiesz, nie chodzi o to, że nie lubię, tylko nawet nie mam jak ktoś non stop mi przychodzi i zawraca gitarę.

Z tego co widzę to zrobił mi się kisiel przez to:

$this->session->user = $name;
$this->session->user_log_in = $login;

Musze zrobić przycisk, albo coś innego, co zniszczy mi sesje i wtedy zobaczyć co i jak z tym wszystkim.

Dzięki wielkie za pomoc.

Podobne pytania

0 głosów
1 odpowiedź 186 wizyt
pytanie zadane 6 kwietnia 2019 w PHP przez Matinowsky Nowicjusz (120 p.)
0 głosów
2 odpowiedzi 204 wizyt
pytanie zadane 7 lutego 2018 w SQL, bazy danych przez Hardwell Dyskutant (8,960 p.)
0 głosów
1 odpowiedź 509 wizyt

92,454 zapytań

141,263 odpowiedzi

319,099 komentarzy

61,854 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...