Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP]PDO i Access denied for user.
casperii
post 28.03.2016, 11:07:31
Post #1





Grupa: Zarejestrowani
Postów: 681
Pomógł: 28
Dołączył: 14.08.2014

Ostrzeżenie: (0%)
-----


Panowie mam pytanie odnośnie PDO. Otóż opiera swoją stronę o system smarty.
Podstrony wczytują się poprzez $_GET.
W index.tpl mam includowany plik do slides.php (slides.tpl)

W pliku slides.php robię tak:

  1. require_once("./polaczenie.php");
  2. try {
  3.  
  4. $baza = new PDO('mysql:host='.$dbhost.';dbname='.$dbname.';charset=utf8', $dbuser, $dbpass,
  5. // wyłączenie zbędnego emulate prepares
  6. PDO::ATTR_EMULATE_PREPARES => false,
  7. // ustalenie sposobu raportowania błędów
  8. PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
  9. // dodajemy kodowanie utf8
  10. PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"
  11. ));
  12.  
  13.  
  14. // kod php
  15.  
  16. } catch(PDOException $err) {
  17. exit('Błąd połączenia z baza danych: '.$err->getMessage());
  18. }


Na chwilę obecną jest ok. Ale jeśli wstawie w index.php:

  1. require_once("./polaczenie.php");


To wywala mi błąd:
Błąd połączenia z baza danych: SQLSTATE[28000] [1045] Access denied for user

Nie rozumiem, dlaczego, kolejne pytanie jakie mi się nasuwa czy za każdym razem gdy mam tworzyć zapytanie do bazy to mam robić try {} i catch {} ?
Czy może wystarczy jak zrobię to w głównym pliku index.php a tam gdzie chce wyciągnąć zapytanie to po prostu robię:

  1. $zapytanie = $baza->query("SELECT * FROM `tabela` ");
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 9)
Star
post 28.03.2016, 11:20:18
Post #2





Grupa: Zarejestrowani
Postów: 294
Pomógł: 34
Dołączył: 16.02.2015

Ostrzeżenie: (0%)
-----


nie jestem specjalista od PDO ale mozesz utworzyc klase do polaczenia z BD i potem tylko ja wczytywac poprzez require()

  1. class db_connect {
  2.  
  3. private $pdo;
  4.  
  5. public function __construct(){
  6.  
  7. try{
  8.  
  9. $this->pdo = new PDO("mysql:host=localhost;dbname=dbname", "dbuser", "dbpass", array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));
  10.  
  11. }catch(PDOException $e){
  12.  
  13. exit('Połączenie nie mogło zostać utworzone: ' . $e->getMessage());
  14.  
  15. }
  16.  
  17. }
  18.  
  19.  
  20. public function query($query){
  21.  
  22. $stmt = $this->pdo->query($query);
  23.  
  24. return $stmt;
  25. }
  26. }
  27. $db = new db_connect();


i potem

  1. require("nazwaklasy.php");
  2. $zapytanie = $db->query("SELECT * FROM `tabela` ");
Go to the top of the page
+Quote Post
casperii
post 28.03.2016, 11:59:28
Post #3





Grupa: Zarejestrowani
Postów: 681
Pomógł: 28
Dołączył: 14.08.2014

Ostrzeżenie: (0%)
-----


@Star dzięki za kod, troszkę musiałem go przerobić, ale jest problem ponieważ nie wczytuje mi wartości:

  1. $dbhost = 'localhost';
  2. $dbname='name';
  3. $dbuser ='user';
  4. $dbpass='pass';
  5.  
  6. $this->pdo = new PDO('mysql:host='.$dbhost.';dbname='.$dbname.';charset=utf8', $dbuser, $dbpass,
  7. array());


Jeżeli wpiszę te dane to połączy mnie , jeżeli implementuje je z powyższych zmiennych to ni hu hu nie chce się mi połączyć. O co kaman z tym PDO.

Ten post edytował casperii 28.03.2016, 12:46:24
Go to the top of the page
+Quote Post
Star
post 28.03.2016, 13:07:28
Post #4





Grupa: Zarejestrowani
Postów: 294
Pomógł: 34
Dołączył: 16.02.2015

Ostrzeżenie: (0%)
-----


o ile mi wiadomo to polaczenie z PDO wyglada inaczej niz tak:
  1. $this->pdo = new PDO('mysql:host='.$dbhost.';dbname='.$dbname.';charset=utf8', $dbuser, $dbpass,
  2. array());
Go to the top of the page
+Quote Post
casperii
post 28.03.2016, 13:18:12
Post #5





Grupa: Zarejestrowani
Postów: 681
Pomógł: 28
Dołączył: 14.08.2014

Ostrzeżenie: (0%)
-----


@Star z tego co udało mi się wygooglować to PDO może mieć formę:

  1. $this->pdo = new PDO('mysql:host='.$dbhost.';dbname='.$dbname.';charset=utf8', $dbuser, $dbpass,
  2. array(PDO::ATTR_EMULATE_PREPARES => false,
  3. PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
  4. PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));


a może mieć też formę:

  1. $pdo = new PDO('mysql:host='.$dbhost.';dbname='.$dbname.'', $dbuser, $dbpass);
  2. $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);


Grunt że działa, tylko że w twoim kodzie musiałem zrobić:

  1. class db_connect {
  2.  
  3. private $pdo;
  4.  
  5. public function __construct(){
  6. require("db.php");
  7. try{
  8. ...


Nie wiem czy dobrze, czy źle (czy poprawnie stylistycznie/programistycznie:) )
Go to the top of the page
+Quote Post
com
post 29.03.2016, 14:18:59
Post #6





Grupa: Zarejestrowani
Postów: 3 034
Pomógł: 366
Dołączył: 24.05.2012

Ostrzeżenie: (0%)
-----


Panowie specjaliści powie mi ktoś poco wam 2 klasa która robi dokładnie to samo co klasa pdo?

Cytat
SQLSTATE[28000] [1045] Access denied for user

Dostałeś odpowiedź, dla tego usera nie ma dostepu do bazy bo nie ma uprawnień, a wy kombinujecie nie wiadomo co..
Go to the top of the page
+Quote Post
casperii
post 2.04.2016, 08:01:18
Post #7





Grupa: Zarejestrowani
Postów: 681
Pomógł: 28
Dołączył: 14.08.2014

Ostrzeżenie: (0%)
-----


@com to wskaż poprawność, bym Ja i wielu innych nie powielało błędów programowania.
Go to the top of the page
+Quote Post
com
post 3.04.2016, 13:03:44
Post #8





Grupa: Zarejestrowani
Postów: 3 034
Pomógł: 366
Dołączył: 24.05.2012

Ostrzeżenie: (0%)
-----


No po pierwsze to obiekt pdo się przekazuje, a nie tworzy wewnątrz klasy, teraz się stosuje IoC, nie singletony i inne takie.
Po drugie przykład Star Jest kompletnie bez sensu bo tam tylko PDO, zmienia nazwę na twoją własną, a klasa robi dokładnie to samo.
U ciebie jeszcze gorzej require("db.php"); w konstruktorze?
Go to the top of the page
+Quote Post
casperii
post 8.04.2016, 08:00:03
Post #9





Grupa: Zarejestrowani
Postów: 681
Pomógł: 28
Dołączył: 14.08.2014

Ostrzeżenie: (0%)
-----


@com może podać przykład ? bo nie wiem jak powinno wyglądać poprawnie. A jak już pisałem wcześniej nie chciałbym popełniać błędów.
db.php musiałem tam wstawić bo inaczej nie łączyło mnie z bazą, dopiero z chwilą wstawienia zaczęło łączyć.

czy nikt nie zna odpowiedzi jak prawidłowo powinno wyglądać nawiązanie połączenia PDO?
Wiem, że można wygooglować, ale skoro na forum ludzie wprowadzają innych w błąd - to skąd mam pewność, że to co człowiek wygoogluje będzie poprawnie napisane?
Go to the top of the page
+Quote Post
com
post 8.04.2016, 16:55:40
Post #10





Grupa: Zarejestrowani
Postów: 3 034
Pomógł: 366
Dołączył: 24.05.2012

Ostrzeżenie: (0%)
-----


Wykorzystaj jakiegoś ORM np Doctrine, lub zbuduj sobie prosta abstrakcje w oparciu o ten pattern https://github.com/domnikl/DesignPatternsPH...ural/DataMapper
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 02:48