亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 PHP 中連接 MySQL 數據庫

在 PHP 中連接 MySQL 數據庫

PHP
守著一只汪 2023-09-22 14:51:56
我正在嘗試建立一個博客網站。它部署在 Heroku 上,并且應該連接到 MySQL 數據庫。登錄我的數據庫所需的信息存儲在 Heroku 上的環境變量中,如下所示(當然這些是假憑證):mysql://g46w916ds134b8:[email protected]/heroku_45fab1d19h35yetf?reconnect=true它包含數據庫名稱、用戶、密碼和主機。有沒有一種方法可以直接在我的 PHP 代碼中使用這個字符串來連接數據庫?我檢查了 MySQLi 和 PDO 文檔,似乎它們只接受 DSN/用戶/密碼或主機/用戶/密碼/DBname 格式。
查看完整描述

2 回答

?
慕虎7371278

TA貢獻1802條經驗 獲得超4個贊

畢竟這是一個url,所以你可以使用parse_url函數來提取數據。


// Connection string from environmental variable in heroku

$connectionStringHerokuEnv = 'mysql://g46w916ds134b8:[email protected]/heroku_45fab1d19h35yetf?reconnect=true';

$parsed = parse_url($connectionStringHerokuEnv);

$dbname = ltrim($parsed['path']. '/'); // PATH has prepended / at the beginning, it needs to be removed

// Connecting to the database

$conn = new PDO("{$parsed['scheme']}:host={$parsed};$dbname={$dbname};charset=utf8mb4", $parsed['user'], $parsed['pass'], [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);

對于數據庫連接,您應該始終使用 PDO 而不是 mysqli 驅動程序。PDO 允許您連接到幾乎任何數據庫,在 85% 的情況下無需重寫代碼。

不要忘記選項[PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION],這將使您能夠捕獲任何錯誤并根據應用程序的需要進行相應的處理。

PDO 接受此連接字符串driver: host=DATABASE_HOST;dbname=DATABASE_NAME; charset=DEFAULT_CHARSET(use utf8 whenever you can)

了解更多信息parse_url: https: //www.php.net/manual/en/function.parse-url

了解有關 PDO 的更多信息: https ://www.php.net/manual/en/class.pdo.php


查看完整回答
反對 回復 2023-09-22
?
梵蒂岡之花

TA貢獻1900條經驗 獲得超5個贊

<?php

$str = "mysql://g46w916ds134b8:[email protected]/heroku_45fab1d19h35yetf?reconnect=true";

// If I correctly understanded 'mysql://login:passwd@host/dbname?some_params'

// data parsing from input string

$sp = explode('/', $str);

$sp1 = explode('@', $sp[2]);

$first_part_sp = explode(':', $sp1[0]);

$login = $first_part_sp[0];

$passwd = $first_part_sp[1];

$host = $sp1[1];

$dbname = explode('?', $sp[3])[0];

$connect_str = "mysql:host=$host;dbname=$dbname";

echo $connect_str." ".$login." ".$passwd;

// database access

$pdo = new PDO($connect_str, $user, $passwd);

?>


查看完整回答
反對 回復 2023-09-22
  • 2 回答
  • 0 關注
  • 118 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號