Hunt framework 2.0.0 釋出,簡單且高效能的 Web 服務框架
HuntLabs 很高興的趕在大年三十之前宣佈:通過 Hunt framework 1.0.0 後面的一些版本( 1.1.x / 1.5.x)迭代終於迎來 2.0.0,這個版本對我們來說很重要,對整個框架的完整性和易用性再一次得到了提升。
Hunt framework 是一個使用 Dlang 語言開發的全棧 web 框架,易用性和完整性都貼近於 Laravel / Django / Spring boot 等主流框架的設計,優勢主要體現在部署方面,不需要搭建執行環境就可開啟 web 服務。而且 D 語言自身是一個性能極高的編譯型語言,我們可以基於 hunt framework 非常簡單的開發出高效能的 web 服務。
版本主要更新特性
-
更多 HTTP 標準 API 進行支援
-
完成 HTTP 2.0 支援,包含 H2 和 H2C
-
I/O 模組效能改進
-
Collie 庫使用新的 hunt-http 庫進行替代
-
資料庫相關模組的增強,包含分頁器和連線池修復
-
新的模板引擎解析器,更好的相容 twig 和 jinja2 語法
-
表單校驗器的實現
-
麵包屑模組設計與實現
-
I18N 多語言模組完整的實現
-
基於 STOMP 協議的 WebSocket 模組實現
-
移植了 java 的大部分容器物件方便開發者使用
-
加強了單元測試模組和更多的示例程式碼
依賴的庫進行升級
Name | Version |
---|---|
hunt | 1.0.0 |
hunt-cache | 0.2.2 |
hunt-database | 1.1.0 |
hunt-entity | 2.2.0 |
hunt-http | 0.1.1 |
hunt-imf | 0.0.4 |
hunt-net | 0.1.0 |
hunt-security | 0.0.6 |
hunt-sql | 1.0.5 |
hunt-stomp | 0.0.3 |
hunt-trace | 0.1.7 |
hunt-validation | 0.0.2 |
boringssl | 0.0.1 |
dredis | 0.0.9 |
libmemcached | 1.1.1 |
openssl | 1.1.6+1.0.1g |
protobuf | 0.4.0 |
rocksdb | 0.0.7 |
I18N 多語言示例程式碼
定義語言包在 resources/translations/en-us/messages.ini
WELCOME=Welcome to the world of hunt framework. VERSION_TITLE=Hunt framework version %s
在配置檔案設定預設語言 config/application.conf
hunt.application.defaultLanguage = en-us hunt.application.languages = zh-cn,en-us
在模板中使用語言詞條
<title>{{ trans("VERSION_TITLE", huntVersion) }}</title>
在控制器中使用語言詞條
string s = trans("VERSION_TITLE", "2.0.0");
麵包屑使用
初始化麵包屑配置
app.onBreadcrumbsInitializing((BreadcrumbsManager breadcrumbs) { breadcrumbs.register("home", (Breadcrumbs trail, Object[] params...) { trail.push("Home", "/home"); }); breadcrumbs.register("index.show", (Breadcrumbs trail, Object[] params...) { trail.parent("home"); trail.push("About", url("index.show")); }); }
頁面的麵包屑進行賦值
view.assign("breadcrumbs", breadcrumbsManager.generate("home"));
檢視檔案程式碼
{% if breadcrumbs.defined and breadcrumbs.length>0 %} <div class="row"> <div class="col"> <ol class="breadcrumb"> {% for item in breadcrumbs %} {% if item.link and not loop.last %} <li class="breadcrumb-item"><a href="{{ item.link }}">{{ item.title }}</a></li> {% else %} <li class="breadcrumb-item active">{{ item.title }}</li> {% endif %} {% endfor %} </ol> </div> </div> {% endif %}
HTTP 方面一些改進
-
HTTP client
-
HTTP server
-
WebSocket client
-
WebSocket server
-
HTTP2
See: https://github.com/huntlabs/hunt-http/tree/master/examples
檔案上傳支援改進
@Action string upload() { string message; if (request.hasFile("file1")) { auto file = request.file("file1"); if (file.isValid()) { // File save path: file.path() // Origin name: file.originalName() // File extension: file.extension() // File mimetype: file.mimeType() if (file.store("uploads/myfile.zip")) { message = "upload is successed"; } else { message = "save as error"; } } else { message = "file is not valid"; } } else { message = "not get this file"; } return message; }
表單驗證示例程式碼
定義表單物件
module app.form.LoginForm; import hunt; class LoginForm : Form { mixin MakeForm; @Length(6,20) string username; @Length(8,16) string password; }
驗證
@Action string login(LoginForm loginForm) { string message; auto result = loginForm.valid(); // TODO if(!result.isValid()) { message ="Valid error message : " ~ result.messages(); } else { message = "OK"; } return message; }
檔案資源 Response 簡化改進
@Action Response download() { return new FileResponse("/tmp/orders-20190122.zip"); }
資料庫方面改進
加強 Entity & EQL 的分頁支援:
https://github.com/huntlabs/hunt-entity/wiki/Pagination
EQL 增強
https://github.com/huntlabs/hunt-entity/wiki/EQL
Validation
https://github.com/huntlabs/hunt-entity/wiki/Validation
內建的鏈路跟蹤初步支援
New modules used to tracing the requests in microservice architectures.
I/O 效能測試結果
The core I/O library is refactored, and is called Hunt.

See: https://github.com/huntlabs/hunt-minihttp
更多示例程式碼
hunt-skeleton: https://github.com/huntlabs/hunt-skeleton
hunt-examples: https://github.com/huntlabs/hunt-examples
hunt-minihttp: https://github.com/huntlabs/hunt-minihttp
hunt-http: https://github.com/huntlabs/hunt-http/tree/master/examples
HuntLabs 官網
Github 程式碼倉庫
https://github.com/huntlabs/hunt-framework