"And storing username/password inside class is not a very good idea for production code."
Good idea is to store database connection settings in *.ini files but you have to restrict access to them. For example this way:
my_setting.ini:
[database]
driver = mysql
host = localhost
;port = 3306
schema = db_schema
username = user
password = secret
Database connection:
<?php
class MyPDO extends PDO
{
public function __construct($file = 'my_setting.ini')
{
if (!$settings = parse_ini_file($file, TRUE)) throw new exception('Unable to open ' . $file . '.');
$dns = $settings['database']['driver'] .
':host=' . $settings['database']['host'] .
((!empty($settings['database']['port'])) ? (';port=' . $settings['database']['port']) : '') .
';dbname=' . $settings['database']['schema'];
parent::__construct($dns, $settings['database']['username'], $settings['database']['password']);
}
}
?>
Database connection parameters are accessible via human readable ini file for those who screams even if they see one PHP/HTML/any_other command.
PHP.mk документација
PDO
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
Патека
class.pdo.php
Локална патека за оваа страница.
Извор
php.net/manual/en
Оригиналниот HTML се реупотребува и локално се стилизира.
Режим
Прокси + превод во позадина
Кодовите, табелите и белешките остануваат читливи во истиот тек.
Референца
class.pdo.php
PDO
Референца за `class.pdo.php` со подобрена типографија и навигација.
PDO класа
(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.1.0)
Вовед
Претставува врска помеѓу PHP и сервер за бази на податоци.
Синопсис на класата
class PDO
{
/* Константи */
/* Методи */
public __construct(
string
?string
Иницијализира контекст за инкрементално хеширање ?string
?array
)
string
$dsn,?string
$username = null,Иницијализира контекст за инкрементално хеширање ?string
$password = null,?array
$options = null)
public static connect(
string
?string
Иницијализира контекст за инкрементално хеширање ?string
?array
): static
}string
$dsn,?string
$username = null,Иницијализира контекст за инкрементално хеширање ?string
$password = null,?array
$options = null): static
Дневник на промени
| Верзија | = NULL |
|---|---|
| 8.4.0 | Константите на класата сега се типизирани. |
Содржина
- PDO::beginTransaction — Започнува трансакција
- PDO::commit — Потврдува трансакција
- PDO::connect — Поврзете се со база на податоци и вратете PDO подкласа за драјвери што ја поддржуваат
- PDO::__construct — Креира PDO инстанца што претставува врска со база на податоци
- PDO::errorCode — Преземете го SQLSTATE поврзан со последната операција на рачката на базата на податоци
- PDO::errorInfo — Преземете проширени информации за грешки поврзани со последната операција на рачката на базата на податоци
- PDO::exec — Извршете SQL изјава и вратете го бројот на погодени редови
- PDO::getAttribute — Преземете атрибут за поврзување со база на податоци
- PDO::getAvailableDrivers — Вратете низа од достапни PDO драјвери
- PDO::inTransaction — Проверува дали е во трансакција
- PDO::lastInsertId — Враќа ID на последниот вметнат ред или вредност на секвенца
- PDO::prepare — Подготвува изјава за извршување и враќа објект за изјава
- PDO::query — Подготвува и извршува SQL изјава без заменски знаци
- PDO::quote — Цитира низа за употреба во прашалник
- PDO::rollBack — Враќа трансакција
- PDO::setAttribute — Постави атрибут
Белешки од корисници 6 белешки
(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.1.0) ¶
пред 17 години
Мегаломан ¶
пред 14 години
PDO and Dependency Injection
Dependency injection is good for testing. But for anyone wanting various data mapper objects to have a database connection, dependency injection can make other model code very messy because database objects have to be instantiated all over the place and given to the data mapper objects.
The code below is a good way to maintain dependency injection while keeping clean and minimal model code.
<?php
class DataMapper
{
public static $db;
public static function init($db)
{
self::$db = $db;
}
}
class VendorMapper extends DataMapper
{
public static function add($vendor)
{
$st = self::$db->prepare(
"insert into vendors set
first_name = :first_name,
last_name = :last_name"
);
$st->execute(array(
':first_name' => $vendor->first_name,
':last_name' => $vendor->last_name
));
}
}
// In your bootstrap
$db = new PDO(...);
DataMapper::init($db);
// In your model logic
$vendor = new Vendor('John', 'Doe');
VendorMapper::add($vendor);
?>
williambarry007 на gmail точка com ¶
пред 8 години
For some Database Environment, such as Aliyun DRDS (Distributed Relational Database Service), cannot process preparing for SQL.
For such cases, the option `\PDO::ATTR_EMULATE_PREPARES` should be set to true. If you always got reports about "Failed to prepare SQL" while this option were set to false, you might try to turn on this option to emulate prepares for SQL.
sinri на everstray точка com ¶
12 години пред
Starting with PHP 5.4 you are unable to use persistent connections when you have your own database class derived from the native PDO class. If your code uses this combination, you will encounter segmentation faults during the cleanup of the PHP process.
You can still use _either_ a derived PDO class _or_ persistent connections.
For more information, please see this bug report: https://bugs.php.net/bug.php?id=63176
anrdaemon на freemail точка ru ¶
пред 17 години
Keep in mind, you MUST NOT use 'root' user in your applications, unless your application designed to do a database maintenance.
And storing username/password inside class is not a very good idea for production code. You would need to edit the actual working code to change settings, which is bad.
Анонимен ¶
пред 8 години
I personnaly create a new instance of PDO like this :
$dbDatas = parse_ini_file( DB_FILE );
$dbOptions = [
\PDO::ATTR_DEFAULT_FECTH_MODE => \PDO::FETCH_OBJ,
\PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION
];
$dsn = sprintf( 'mysql:dbname=%s;host=%s', $dbDatas['dbname'],
$dbDatas['host'] );
$this->cn = new \PDO( $dsn, $dbDatas['user'], $dbDatas['password'],
$dbOptions );
$this->cn->exec( 'SET CHARACTER SET UTF8' );