作者:万幼南 | 来源:互联网 | 2023-06-07 13:23
后端开发|php教程php,apache,nginx,node.js,nosql后端开发-php教程求教怎么实现,比如全自动营销系统源码,ubuntu版本区分,适合爬虫的数据,ph
后端开发|php教程
php,apache,nginx,node.js,nosql
后端开发-php教程
求教 怎么实现 , 比如
全自动营销系统源码,ubuntu版本区分,适合爬虫的数据,php solr,seo 页面标题lzw
https://www.xxx.com/img/1015308c0ebce716.jpg
jeeplus 源码下载,vscode截屏快捷键,ubuntu 查看网桥,判断tomcat是否成功,吹气爬虫子,php see,铜山区seo哪家公司好lzw
其中
1015308c0ebce716.jpg 是个文件名
12的源码,怎么直接装Ubuntu,tomcat 下的虚拟目录,爬虫和清洗,php时时更新如何实现,传奇私服seolzw
简单点说就是 , 怎么实现 这个伪静态 . 只要 index.php 这个文件接收到 xx.xxx 这个参数就可以了
$_SERVER[ORIG_PATH_INFO]// 用这个吗 ?
考虑到很多文件 , 这样的片状存储肯定不好管理 .
于是想在上传的过程中 ,用唯一id当做文件名 . 以时间存储到不同文件夹里
回复内容:
求教 怎么实现 , 比如
https://www.xxx.com/img/1015308c0ebce716.jpg
其中 1015308c0ebce716.jpg 是个文件名
简单点说就是 , 怎么实现 这个伪静态 . 只要 index.php 这个文件接收到 xx.xxx 这个参数就可以了
$_SERVER[ORIG_PATH_INFO]// 用这个吗 ?
考虑到很多文件 , 这样的片状存储肯定不好管理 .
于是想在上传的过程中 ,用唯一id当做文件名 . 以时间存储到不同文件夹里
「伪静态」其实是一个伪概念,其实就是通过某种技术,让 client (通常是浏览器)认为其访问的是「静态」资源,如题主在描述中提到的 https://www.xxx.com/img/1015308c0ebce716.jpg
是由某个 PHP 脚本所返回的「动态」内容,而为了做到这一点,至少需要满足这么几个条件:
URL 看起来像是一个静态文件
Content-Type
告诉浏览器是一个静态文件,如提到的JPEG图片对应的便是 image/jpeg
那么一个一个来解决,这里我们假设采用了 PHP 与 nginx:
假如应用程序中 /img/1015308c0ebce716.jpg
本身是一个 PHP 文件,并且告诉 nginx 在处理这个文件的时候,交给 PHP 去处理,问题便解决了。显然,这并不是一个特别好的主意,这个设计不但让我们自己摸不着头脑,限制了应用程序本身的架构,并且参数传递显然成了硬伤。那么如果我们可以在访问 /img/1015308c0ebce716.jpg
的时候,把请求交给某个 PHP 脚本,并且可以取 URL 中的一部分作为参数,问题便优雅的解决了。事实上,nginx 的 ngx_http_rewrite_module 就可以做到这一点。( apache 可以使用 mod_rewrite ) 。例如,假设/img/1015308c0ebce716.jpg
对应的处理脚本是 /index.php?mod=image&id=1015308c0ebce716
,并且 id
作为参数存在,那么:
nginx
server { root /path/to/app; rewrite ^/img/([a-z\d]+)\.jpg$ /index.php?mod=image&id=$1 last; location /index.php { ... ... }}
解决了上一个问题,这个就很好处理,如果是 PHP 脚本的话,在这里直接用 header('Content-Type: image/jpeg')
就好。
最后,题主所提到的 $_SERVER[ORIG_PATH_INFO]
可以作为给 PHP 脚本传参的一个形式出现,甚至作为架构上一个对 URL 整体设计实现中的一环,这里可以参考一下 ThinkPHP 的实现 https://github.com/liu21st/thinkphp/blob/65dd170184db6109301b1d2e3cf3f…。