前一次看到 StackOverflow 故障,是用 BrainFuck 語言寫了一個 error message。而這次呢?

就算不用 BrainFuck,照樣讓你 BrainFucked …. XD
軟體開發、伺服器和生活瑣事
前一次看到 StackOverflow 故障,是用 BrainFuck 語言寫了一個 error message。而這次呢?
就算不用 BrainFuck,照樣讓你 BrainFucked …. XD
這篇文章透過基礎的程式運作方式來探討記憶體管理機制,值得一讀。
傳送門:Rust 與記憶體
網路上多數都說需要 unique ID 的話用 uniqid()
產生即可,不過事實上這個方法產生的亂度不夠亂,特殊情空下是可以用猜的猜到:
foreach(range(1,10) as $n) { echo uniqid() . "\n"; }
$ php uid.php 62283582750d2 62283582750de 62283582750df 62283582750e0 62283582750e1 62283582750e2 62283582750e3 62283582750e4 62283582750e5 62283582750e6
如果需要亂度夠大的 ID,官方建議使用 random_bytes()
等函式來實作:
foreach(range(1,10) as $n) { echo bin2hex(random_bytes(8)) . "\n"; }
$ php uid.php 8deaa97f2cc4709d f2c556361d316f8d bcf97aa28e6b5a02 7453b298b1f748e5 6478265fb8da5c01 4981729191162649 80a7a2824818addf 622009f43ec32836 3b4d757e1894702c 4a254e226179e3b5
遠端連線到 PostgreSQL 時,遇到錯誤訊息:
SCRAM authentication requires libpq version 10 or above
這個問題主要是新舊版本儲存使用者密碼的方法不同所導致的,只要讓 PostgreSQL 支援 MD5 儲存密碼即可。
開啟 postgresql.conf
修改 password_encryption
參數:
password_encryption = md5
再來修改 pg_hba.conf
,讓使用者驗證的時候使用 MD5 方式驗證:
# IPv4 local connections: host all all 127.0.0.1/32 scram-sha-256 host all zeroplex 0.0.0.0/0 md5
設定檔修改後記得重新啟動 PostgreSQL。
設定檔改好、啟動也沒問題,就來更新使用者密碼,這樣一來,PostgreSQL 的密碼儲存方式就會改用 MD5:
ALTER USER zeroplex WITH PASSWORD 'your-password'