這篇文章透過基礎的程式運作方式來探討記憶體管理機制,值得一讀。
傳送門:Rust 與記憶體
軟體開發、伺服器和生活瑣事
這篇文章透過基礎的程式運作方式來探討記憶體管理機制,值得一讀。
傳送門: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'
Laravel 和 Lumen 都有自己整理好的一套 unit test framework,因此若要加入 AspectMock 會需要對預設的 boostrap file 做一些調整。
整合時需要注意的事情:
/bootstrap/app.phpphpunit.xml 中的 bootstrap config,要改成自己新建立的 bootstrap filerequire 順序,不要讓 Laravel App 的資料被覆蓋掉 (另外也要注意 require 和 require_once 的差異)建立新的 bootstrap 設定檔 /tests/bootstrap.php:
<?php
// composer autoload
require_once __DIR__.'/../vendor/autoload.php';
// load Laravel bootstrap
$app = require_once __DIR__ . '/../bootstrap/app.php';
// create temporary folder for AspectMock
$tmpPath = '/tmp/aspectMock/';
if (!file_exists($tmpPath)) {
mkdir($tmpPath, 0777);
}
$kernel = \AspectMock\Kernel::getInstance();
$kernel->init([
'appDir' => __DIR__ . '/..',
'debug' => true,
'includePaths' => [
__DIR__ . '/../app',
__DIR__ . '/../vendor/laravel', // 如果需要 mock Model 則加上這行
],
'excludePaths' => __DIR__, // "/tests" 目錄不需要處理
'cacheDir' => $tmpPath,
]);
return $app; // 把 App 回傳給 createApplication()
接下來要調整原有的 phpunit.xml 設定檔,需要參考 AspectMock 的要求,來調整:
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="./vendor/phpunit/phpunit/phpunit.xsd"
bootstrap="tests/bootstrap.php"
backupGlobals="false">
注意最後面二行,bootstrap 要改成剛剛新建立的檔案,backupGlobals 則要關閉。
最後,去調整 BaseTest.php,在 tearDown() 加上 AspectMock 清理設定的指令:
protected function tearDown(): void
{
test::clean();
}
另外在 createApplication() 這邊,要改用上面建立的 bootstrap file:
public function createApplication()
{
return require __DIR__ . '/bootstrap.php';
}
以上全部改好的話,執行 vendor/bin/phpunit 應該可以正常運作。
注意 require 和 require_once 的差異,Laravel 會在每次開始 unit test 之前,重新建立 $app,所以用 require_once 的話,就的設定清不掉
-$app = require_once __DIR__ . '/../bootstrap/app.php'; // Laravel bootstrap +$app = require __DIR__ . '/../bootstrap/app.php';