1 回答
TA贡献1906条经验 获得超3个赞
我的标准做法是通过框架路由控制资源访问。一个示例实现(在 Lumen 中):
$router->get('/asset[/{path:.*}]', 'AssetController@load');
示例请求和响应如下所示:
GET /asset/js/app.js HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.100 Safari/537.36
Accept: */*
Referer: http://localhost:8080/spa/example
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.9
HTTP/1.1 200 OK
Server: nginx
Content-Type: application/javascript
Content-Length: 21056410
Connection: keep-alive
Last-Modified: Sun, 31 Jul 63 19:34:21 +0000
Cache-Control: private, must-revalidate
Date: Wed, 31 Jul 2019 19:34:21 GMT
Accept-Ranges: bytes
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
Content-Security-Policy: default-src 'self'; connect-src 'self'; img-src 'self'; style-src 'unsafe-inline' fonts.googleapis.com 'self'; font-src fonts.gstatic.com 'self'; script-src 'unsafe-inline' 'self' 'unsafe-eval'
您的控制器(例如,AssetController在我之前的示例中)会注意将 URL 路径转换为文件系统路径(注意..和其他技巧,使用realpath并将其与代码的安装基本路径进行比较),设置Content-Type和Content-Length标题,任何相关的缓存标头,然后流式传输文件。
虽然这确实增加了复杂性和一定数量的开销,但它提供了通过业务逻辑限制资源的灵活性。
如果性能是一个问题,您可以促进对 Web 服务器的访问或屏蔽 CDN 和代理内容后面的路由。
- 1 回答
- 0 关注
- 201 浏览
添加回答
举报