php零基礎到就業直播視訊課:進入學習
程式設計師必備介面測試偵錯工具:
TOML 是一個設定格式化語言,特色是簡潔易讀。 全稱為 "Tom's Obvious, Minimal Language" 其中的 Tom 為建立者 —— Tom Preston-Werner (譯者注:Github CEO)。
來自其 Github Reopo,TOML 的目的如下:
TOML 是一門簡潔易用的設定資訊格式化語言,高可讀性來自於其優雅的語法。 TOML 為雜湊表資料結構量身客製化的,在各種程式語言裡皆可以輕鬆地將 TOML 解析為各自的資料結構。
各種語言的 TOML 解析器可以 在其專案 WIKI 中找到。
我們將利用 yosymfony/toml: 一個 PHP 的 TOML 解析器 來嘗試下 TOML 語言,在你的 PHP 7.1+ 專案裡使用 Composer:
composer require yosymfony/toml
TOML 的專案 Readme 裡有一個範例設定資訊,我們可以試著用起來:
## This is a TOML document. title = "TOML Example" [owner] name = "Tom Preston-Werner" dob = 1979-05-27T07:32:00-08:00 # First class dates [database] server = "192.168.1.1" ports = [ 8001, 8001, 8002 ] connection_max = 5000 enabled = true [servers] # Indentation (tabs and/or spaces) is allowed but not required [servers.alpha] ip = "10.0.0.1" dc = "eqdc10" [servers.beta] ip = "10.0.0.2" dc = "eqdc10" [clients] data = [ ["gamma", "delta"], [1, 2] ] # Line breaks are OK when inside arrays hosts = [ "alpha", "omega" ]
下面是 PHP 的解析和輸出:
<?php use Yosymfony\Toml\Toml; require __DIR__ . '/vendor/autoload.php'; $data = Toml::ParseFile(__DIR__.'/example.toml'); var_dump($data); // output php index.php string(10) "1979-05-27" toml-demo|⇒ php index.php array(5) { ["title"]=> string(12) "TOML Example" ["owner"]=> array(2) { ["name"]=> string(18) "Tom Preston-Werner" ["dob"]=> object(DateTime)#243 (3) { ["date"]=> string(26) "1979-05-27 07:32:00.000000" ["timezone_type"]=> int(1) ["timezone"]=> string(6) "-08:00" } } ["database"]=> array(4) { ["server"]=> string(11) "192.168.1.1" ["ports"]=> array(3) { [0]=> int(8001) [1]=> int(8001) [2]=> int(8002) } ["connection_max"]=> int(5000) ["enabled"]=> bool(true) } ["servers"]=> array(2) { ["alpha"]=> array(2) { ["ip"]=> string(8) "10.0.0.1" ["dc"]=> string(6) "eqdc10" } ["beta"]=> array(2) { ["ip"]=> string(8) "10.0.0.2" ["dc"]=> string(6) "eqdc10" } } ["clients"]=> array(2) { ["data"]=> array(2) { [0]=> array(2) { [0]=> string(5) "gamma" [1]=> string(5) "delta" } [1]=> array(2) { [0]=> int(1) [1]=> int(2) } } ["hosts"]=> array(2) { [0]=> string(5) "alpha" [1]=> string(5) "omega" } } }
接下來我們試著將 Laravel 的設定資訊 config/database.php
解析為 TOML ,做個對比。
需要注意的是,這只是一個示範,Laravel 的設定系統要比 TOML 高階很多,這裡這樣做的目的只是想在我們熟悉的設定資訊裡去理解 TOML:
[database] default = "mysql" migrations = "migrations" [database.connections.sqlite] driver = "sqlite" database = "path/to/database.sqlite" prefix = "" [database.connections.mysql] driver = "mysql" host = "127.0.0.1" port = "3306" database = "forge" username = "forge" password = "" unix_socket = "" charset = "utf8mb4" collation = "utf8mb4_unicode_ci" prefix = "" strict = true [database.redis] client = "predis" [database.redis.default] host = "127.0.0.1" password = "" port = 6379 database = 0
目前來講,TOML 並不允許 nil
和 null
值,這在一些使用 null 作為預設值的場景下會變得很不方便。
縮排是允許的,但是不強求,上面的檔案使用以下寫法也不會有問題:
[database] default = "mysql" migrations = "migrations" [database.connections.sqlite] driver = "sqlite" database = "path/to/database.sqlite" prefix = "" # ...
擴充套件包 yosymfony/toml
除了提供解析 TOML 檔案和字串外,還提供了一個 TomlBuilder
類,用來實時構建 TOML 設定資訊,接下來我們還是使用 Laravel 的 config/services.php
來作為例子講解:
<?php use Yosymfony\Toml\TomlBuilder; require __DIR__.'/vendor/autoload.php'; $builder = new TomlBuilder(); $services = $builder ->addComment('Third Party Services') ->addComment('Mailgun') ->addTable('services.mailgun') ->addValue('domain', 'mg.example.com') ->addValue('secret', 'mailgun-secret') ->addComment('Stripe') ->addTable('services.stripe') ->addValue('model', 'App\User') ->addValue('key', 'stripe-key') ->addValue('secret', 'stripe-secret') ; file_put_contents(__DIR__.'/services.toml', $services->getTomlString());
生成的內容如下:
#Third Party Services #Mailgun [services.mailgun] domain = "mg.example.com" secret = "mailgun-secret" #Stripe [services.stripe] model = "App\\User" key = "stripe-key" secret = "stripe-secret"
TOML 支援 RFC 3339 制定的日期格式:
# Offset Date-Time odt1 = 1979-05-27T07:32:00Z odt2 = 1979-05-27T00:32:00-07:00 odt3 = 1979-05-27T00:32:00.999999-07:00 # space permitted per the RFC 3339 spec odt4 = 1979-05-27 07:32:00Z # Local Date-Time ldt1 = 1979-05-27T07:32:00 # Local Date ld1 = 1979-05-27 # Local Time lt1 = 07:32:00 lt2 = 00:32:00.999999
在此篇文章編寫時,上面大部分的格式都出現了錯誤,除了下面這一行:
dob = 1979-05-27T07:32:00-08:00
PHP 解析器會將解析成功輸出為 DateTime 範例:
array(1) { ["dob"]=> object(DateTime)#128 (3) { ["date"]=> string(26) "1979-05-27 07:32:00.000000" ["timezone_type"]=> int(1) ["timezone"]=> string(6) "-08:00" } }
前往官方計畫頁瞭解更多資訊 —— GitHub -- toml-lang/toml: Tom's Obvious, Minimal Language。
專案 Wiki 裡可以找到各種語言的解析器: toml-lang/toml Wiki 。
英文原文地址:https://laravel-news.com/toml-configuration-in-php
推薦學習:《》
以上就是什麼是TOML?PHP中怎麼設定使用TOML的詳細內容,更多請關注TW511.COM其它相關文章!