处理静态文件

webman支持静态文件访问,静态文件都放置于public目录下,例如访问 http://127.0.0.8787/upload/avatar.png实际上是访问{主项目目录}/public/upload/avatar.php

注意 webman 从1.4开始支持应用插件,以/app/xx/文件名开头的静态文件访问实际是访问应用插件的public目录,也就是说 webman >=1.4.0 时不支持 {主项目目录}/public/app/下的目录访问。 更多请参考应用插件

关闭静态文件支持

如果不需要静态文件支持,打开config/static.phpenable选项改成false。关闭后所有静态文件的访问会返回404。

更改静态文件目录

webman默认使用public目录为静态文件目录。如需修改请更改support/helpers.php的中的public_path()助手函数。

静态文件中间件

webman自带一个静态文件中间件,位置app/middleware/StaticFile.php。 有时我们需要对静态文件做一些处理,例如给静态文件增加跨域http头,禁止访问以点(.)开头的文件可以使用这个中间件

app/middleware/StaticFile.php 内容类似如下:

  1. <?php
  2. namespace support\middleware;
  3. use Webman\MiddlewareInterface;
  4. use Webman\Http\Response;
  5. use Webman\Http\Request;
  6. class StaticFile implements MiddlewareInterface
  7. {
  8. public function process(Request $request, callable $next) : Response
  9. {
  10. // 禁止访问.开头的隐藏文件
  11. if (strpos($request->path(), '/.') !== false) {
  12. return response('<h1>403 forbidden</h1>', 403);
  13. }
  14. /** @var Response $response */
  15. $response = $next($request);
  16. // 增加跨域http头
  17. /*$response->withHeaders([
  18. 'Access-Control-Allow-Origin' => '*',
  19. 'Access-Control-Allow-Credentials' => 'true',
  20. ]);*/
  21. return $response;
  22. }
  23. }

如果需要此中间件时,需要到config/static.phpmiddleware选项中开启。