Lysine介绍(三)MVC - Application

本文介绍了 Lysine 框架的 MVC 实现原理,包括 Application 的职责、类的自动加载机制、URL 路由配置及控制器中的重定向操作。展示了如何通过简单配置实现类的自动加载,并提供了自定义 Router 和 autoloader 的方法。

上一篇:Lysine介绍(二)载入及配置

 

太阳底下没有新鲜事,MVC也不是

Lysine的MVC灵感来自webpy ,即使说是模仿也没错

源代码 目录里面的demo/helloworld下有一个简单的实例

要运行Lysine的MVC,需要url rewrite支持,可以在demo的config目录下参考nginx.conf文件

 

这个MVC实现包含了Application、Router、Controller,这里先说Application

 

分配给Application职责是:

  1. 初始化运行环境
  2. 自动载入web app的类
  3. 调用Router分发请求
  4. 重定向或重新分发请求

初始化环境非常简单,只是告知app需要从哪些路径下搜索类对应的文件

<?php
$app = \Lysine\Application::instance();
// or
$app = app();

$app->includePath(array('/path1', '/path2'));
 

知道了路径,Application自带的autoloader就可以在这些路径下搜索并载入类,

文件名解析规则很简单,例如

\Controller\User               ->  controller/user.php

\Controller\User\Login      ->  controller/user/login

\Controller\User_Login      ->  controller/user.php

\Model\User                     ->  model/user.php

 

namespace会被转换为目录名,class名字中"_"后的内容被忽略

如果搜索的路径有/path1和/path2

先找/path1/controller/user.php

再找/path2/controller/user.php

找到哪个包含哪个

 

规则只有这么一条,无论是controller类、model类还是其它类都一视同仁

所以项目的文件目录结构没有任何强制要求,你可以按照自己的想法组织目录

 

你可以采用

<?php
/*
/project/path
|-- app
|   |-- controller
|   `-- view
|   `-- model
|-- config
|-- lib
`-- public
    `-- index.php
*/
app()->include('/project/path/app');
 

也可以

<?php
/*
/project/path
|-- config
|-- controller
|-- lib
|-- model
|-- public
|   `-- index.php
`-- view
*/
app()->include('/project/path');

 

如果你想自己定义一套autoloader,可以

<?php
function my_autoloader() {
    /* ... */
}
app()->setAutoLoader('my_autoloader');

一旦应用了新的autoloader,Application自带的autoloader就会被注销掉

 

Lysine自带了webpy风格的Router,但是也是可以被替换的,你可以用

<?php
// 自定义的Router必须继承自\Lysine\Router_Abstract
class MyRouter extends \Lysine\Router_Abstract {
    public function dispatch($url, array $params = array()) {
        /* ... */
    }
}

app()->setRouter(new MyRouter());

 还是那句话,尽量实现机制而不是策略,如果实现了策略,那么应该可以被替换

 

在Controller里面:

<?php
class \Controller\Example {
    public function get() {
        return app()->redirect($new_url);
    }
}

 即可重定向到新url上

 

下一篇:Lysine介绍(四)MVC - Controller

Delphi 12.3 作为一款面向 Windows 平台的集成开发环境,由 Embarcadero Technologies 负责其持续演进。该环境以 Object Pascal 语言为核心,并依托 Visual Component Library(VCL)框架,广泛应用于各类桌面软件、数据库系统及企业级解决方案的开发。在此生态中,Excel4Delphi 作为一个重要的社区开源项目,致力于搭建 Delphi 与 Microsoft Excel 之间的高效桥梁,使开发者能够在自研程序中直接调用 Excel 的文档处理、工作表管理、单元格操作及宏执行等功能。 该项目以库文件与组件包的形式提供,开发者将其集成至 Delphi 工程后,即可通过封装良好的接口实现对 Excel 的编程控制。具体功能涵盖创建与编辑工作簿、格式化单元格、批量导入导出数据,乃至执行内置公式与宏指令等高级操作。这一机制显著降低了在财务分析、报表自动生成、数据整理等场景中实现 Excel 功能集成的技术门槛,使开发者无需深入掌握 COM 编程或 Excel 底层 API 即可完成复杂任务。 使用 Excel4Delphi 需具备基础的 Delphi 编程知识,并对 Excel 对象模型有一定理解。实践中需注意不同 Excel 版本间的兼容性,并严格遵循项目文档进行环境配置与依赖部署。此外,操作过程中应遵循文件访问的最佳实践,例如确保目标文件未被独占锁定,并实施完整的异常处理机制,以防数据损毁或程序意外中断。 该项目的持续维护依赖于 Delphi 开发者社区的集体贡献,通过定期更新以适配新版开发环境与 Office 套件,并修复已发现的问题。对于需要深度融合 Excel 功能的 Delphi 应用而言,Excel4Delphi 提供了经过充分测试的可靠代码基础,使开发团队能更专注于业务逻辑与用户体验的优化,从而提升整体开发效率与软件质量。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值