# 路由器
[TOC]
http://localhost:8081/TestController/test
以上代码会先在/app/Controllers目录下寻找TestController控制器,如果没有再去/Server/Controllers目录下寻找,如果依旧没有找到将返回404界面。
test是方法名,默认前缀名为‘http_’,可以通过修改ports.php配置设置不同端口的前缀。
所以以上url会访问到/Server/Controllers下的TestController控制器的http_test方法并输出helloworld。
```php
<?php
class TestController extends Controller
{
/**
* http测试
*/
public function http_test()
{
$this->http_output->end('helloworld',false);
}
}
```
## 多级路由
默认的NormalRoute支持多级路由
http://localhost:8081/V1/TestController/test
可以在app/Controllers目录下添加V1目录,这样上面的URL将访问V1目录下的TestController类中的test方法。
可以添加更多级的文件夹。
## 自定义路由
自定义路由需要实现以下几个方法
```php
interface IRoute
{
function handleClientData($data);
function handleClientRequest($request);
function getControllerName();
function getMethodName();
function getParams();
function getPath();
function errorHandle(\Throwable $e, $fd);
function errorHttpHandle(\Throwable $e, $request, $response);
}
```
1.(仅仅TCP)handleClientData 设置反序列化后的数据 Object
2.(仅仅HTTP)handleClientRequest 处理http request
3.getControllerName 获取控制器名称
4.getMethodName 获取方法名称
5.(仅仅HTTP)getPath 获取url_path
6.(仅仅TCP)getParams 获取参数/扩展
解析错误的回调
```php
function errorHandle(\Throwable $fd)
```
注意getParams是作为一个扩展,如果这里被返回了参数,那么这个参数会被直接当做调用Controller方法的传入参数。
```php
class ProtoController extends Controller
{
public function makeMessageData(AbstractMessage $responseMessage)
{
//这里的$responseMessage就是getParams()获取到的对象
}
}
```
## 自定义协议配置 route 举例
和 Pack 中的例子对应, 将不同 `msg_type` 的消息分发到控制器中不同的方法下
```php
namespace Server\Route;
use Server\CoreBase\SwooleException;
class GameRoute implements IRoute
{
// 其他方法都可以保持不变
/**
* 获取控制器名称
* @return string
*/
public function getControllerName()
{
return 'GameController';
}
/**
* 获取方法名称
* @return string
*/
public function getMethodName()
{
$methodName = 'ping';
$msgType = $this->client_data->msg_type;
if ($msgType == 2) {
$methodName = 'pong';
}
return $methodName. 'Msg';
}
}
```
这样, 不同类型的消息就分发到 `GameController` 下的对应 `method`, 使用 `$this->client_data` 即可获取到 `unpack` 后的数据
- SD3.X简介
- 捐赠SD项目
- VIP服务
- 基础篇
- 搭建环境
- 使用Composer安装/更新SD框架
- 启动命令
- 开发注意事项
- 框架配置
- 配置文件夹
- server.php
- ports.php
- business.php
- mysql.php
- redis.php
- timerTask.php
- log.php
- consul.php
- catCache.php
- client.php
- 自定义配置
- 框架入口
- MVC架构
- 加载器-Loader
- 控制器-Controller
- 模型-Model
- 视图-View
- 同步任务-Task
- 封装器
- Swoole编程指南-EOF协议
- Swoole编程指南-固定包头协议
- 封装器-Pack
- 路由器
- TCP相关
- 绑定UID
- Send系列
- Sub/Pub
- 获取服务器信息
- Http相关
- HttpInput
- HttpOutput
- 默认路由规则
- WebSocket相关
- 使用SSL
- 公共函数
- 进阶篇
- 内核优化
- 封装器路由器原理剖析
- 对象池
- 上下文-Context
- 中间件
- 进程管理
- 创建自定义进程
- 进程间RPC
- 自定义进程如何使用连接池
- 异步连接池
- Redis
- Mysql
- Mqtt
- HttpClient
- Client
- AMQP
- RPC
- 日志工具-GrayLog
- 微服务-Consul
- Consul基础
- 搭建Consul服务器
- SD中Consul配置
- 微服务
- 选举-Leader
- Consul动态配置定时任务
- 熔断与降级
- 集群-Cluster
- 高速缓存-CatCache
- 万物-Actor
- Actor原型
- Actor的创建
- Actor间的通讯
- 消息派发-EventDispatcher
- 延迟队列-TimerCallBack
- 协程
- 订阅与发布
- MQTT简易服务器
- AMQP异步任务调度
- 自定义命令-Console
- 调试工具Channel
- 特别注意事项
- 日常问题总结
- 实践案例
- 物联网自定义协议
- Actor在游戏的应用
- Mongodb以及一些同步扩展的使用
- 自定义进程使用MQTT客户端
- 开发者工具
- SDHelper