五、解析生成路由标识的快捷访问
从路由处理规则之后还有一步操作就是生成路由标识的快捷访问。
路由规则中的变量
但是在前边我们需要对路由规则中的变量做一点简单的说明。
下图圈出来的地方就是将要解析的内容。
来到parseVar这个方法,这个方法是在thinkphp/library/think/route/Rule.php这个类里,因为本类继承的rule类。
那么接下来就是要对这一整块的内容作出详细的说明了。
首先要先明白preg_match_all的三个参数是什么。
参数一:需要搜索的字符串
参数二:输入的字符串
参数三:多维数组,作为输出参数输出所有匹配结果, 数组排序通过flags指定。
所以说最终的匹配结果会存放在变量$matches中。
那么先来打印一下$matches这个变量。
这里需要先说明一个关于PHP版本的问题。
此次使用的路由案例为下图
在打印这个值的时候,咔咔遇到了一点点问题,在PHP7.3.4中使用dump是无法显示数据的,但是在dubug调试下会显示。
在PHP版本7.2.9下dump是显示的。
关于这个问题,咔咔就先绕过了,如果有大佬知道情况的可以给咔咔简单的那么唠一唠,这里咔咔就使用PHP7.2.9来进行讲解了。
后期咔咔在针对这个问题进行简单的说明一下,遇到问题就需要去解决嘛!
那么你知道在上图的打印结果中<name?>这个是怎么来的吗?不知道的赶紧看下图,在上文已经说过了。
在到这里说一次哈!
就是下图为路由规则预处理的地方进行正则处理的,看到这里关于上面的那个问题,咔咔初步认为在不同版本中要木preg_replace这个方法进行了改动,要木就是关于正则方面进行了改动。
所以说把这块搞定后,其余的代码就是毛毛雨啦!
这里就是在根据?第一次出现的问题进行判断。
在上文中咔咔给出的路由案例中相信大家也看到了另外一个跟案例很相似的路由。
这俩组路由参数分别为参数必有,和可选参数。
在打印截图中咔咔只是说明了一种情况,另一种情况就需要大家去进行测试了。
最终会把结果返回给$var,接下来我们就光打印一下俩种情况的返回值就可以了。
情况一:Route::get(‘hello/[:name]’, ‘index/index/hello’);
情况二:Route::get(‘hello/:name’, ‘index/index/hello’);
从而可以得出结论就是,当参数可选时为2,必选时为1。
截止到这里关于路由规则中的变量一些处理就简单说到这里。
这块的代码没什么难的,只要会preg_match_all和strpos、substr就可以了。
解析生成路由标识的快捷访问
接下来就继续来看这块内容。
咔咔下图圈出来的就暂时先不用看,在下文中会单独提出来来说这一块。
那么接着就需要看一个$value这个值是什么了。
下图就是打印结果,可以看到都包含了路由规则,参数是否可选,请求域名,请求方式。
最后又来到我们最熟悉的容器模块了Container::get('rule_name')->set($name, $value, $first);,也就是这行代码。
参数就是rule_name。
然后执行make方法,因为在容器类里边已经把rule_name进行了绑定。
最终通过反射将object(think\route\RuleName)返回回来,并且存放在容器里边。
此时就相当于是$this->instances['think\route\RuleName'] = object(think\route\RuleName);
最后一步就是设置路由规则。
截止到这里就把路由标识的快捷访问就解析完了。
由于路由这块的内容还有将近一半的内容,一文写完篇幅有点太长
本文就到这里,下一文接着路由在来谈其它内容。
六、总结
在这一文中主要针对路由的执行流程、通过定义路由的方式在一次对门面进行深究。
同时对rule方法中的group进行了特别详细的讲解,这块的内容必须要好好的研究一下,类与类之间的继承一定要注意。
在就是关于路由规则的预处理,就是对于路由的前半部分进行处理。
主要就是以下的三句话。
把带有:符号的参数转化。
例如::name 转化为 。
放在代码中就是$this->rule = <name>。
紧接着就是对生生路由标识的快捷访问进行了源码的阅读,在这一节最重要的就是对变量的处理。
判断参数是可选的还是不可选的,可选为2,不可选为1,作为标识。
以下是咔咔画出来的脑图。
这个脑图还没有写完整,后边还有内容,在下文会进行详细的补充。
最后就是在给大家把这个图给大家放出来,这个图是最详细的一个执行流程。
关于类与类之间的执行关系,都在图中有详细的描述。