目录规划意识的觉醒
如上图所示,访问会看到代码片段,而不是正常的网页,这会给用户带来困惑。所以应该只允许访问index.php
、add_article.html
、get_article.php
等文件,其他文件一律禁止访问,比如index.html
这种模板文件。
如何禁止访问呢?
把允许访问的文件放在一个目录,修改HTTP Server的根目录指向这里即可。
本来项目里没有目录,所有文件都放在一起,是这样的:
改成下面的目录结构:
htdocs/
add_article_submit.php
res/
/layout/
get_article.html
index.html
然后找到nginx的配置文件,在这里:
Windows:
C:\Wnmp\Conf\nginx.conf
Linux:
/etc/nginx/sites-enabled/default
修改其中的server->root,重启nginx即可。如图所示:
目录变了,包含就变了,记得index.php
等php文件中的代码要改。以前是:
要改成:
然后访问index.html
会出现404错误,即“不存在”。而访问index.php
是可以的,如图所示:
同一件事情,重复做很多次,浪费了时间,是编程的大忌,违反了DRY原则(don’t repeat yourself)。使用配置文件即可解决此问题。
配置文件用什么格式?打开PHP安装后的目录,会发现lib/php.ini文件,这是PHP的配置文件,由此可知PHP原生支持ini格式。本书也采用ini格式。配置文件当然也不应该让用户访问,所以单独建一个conf目录,现在项目目录结构如下:
db.ini的内容如下:
port="3306"
dbname="reader"
charset="utf8"
username="root"
然后每个php页面解析配置文件,连接数据库,执行SQL。代码如下:
如图所示:
可以看到,如果数据库地址、用户名、密码改了,只用改db.ini即可,很方便。
代码下载:https://github.com/sinkcup/php-ebook-online-reader/tree/0.5.0
访问index.php是正常网页,但访问index.html看到了什么?
用户看到了代码片段,这是不对的,目录规划隔离即可。
多个文件里都连了数据库,如果密码变了,每个地方都要改,怎么办?
谨记DRY,使用ini配置文件。当然还可以使用PHP array、PHP object、JSON,请自行了解。
【锤子手机 Smartisan T1 正式发售版的实际使用体验如何?】
喻梦萱:谢邀。。。 11日早上收到的,优先码来源是自己购买的发布会门票。总体感觉是…美哭了…非常非常精致。… (分享自知乎)