目录规划意识的觉醒

    如上图所示,访问会看到代码片段,而不是正常的网页,这会给用户带来困惑。所以应该只允许访问index.phpadd_article.htmlget_article.php等文件,其他文件一律禁止访问,比如index.html这种模板文件。

    如何禁止访问呢?

    把允许访问的文件放在一个目录,修改HTTP Server的根目录指向这里即可。

    本来项目里没有目录,所有文件都放在一起,是这样的:

    改成下面的目录结构:

    1. htdocs/
    2. add_article_submit.php
    3. res/
    4. /layout/
    5. get_article.html
    6. 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的内容如下:

    1. port="3306"
    2. dbname="reader"
    3. charset="utf8"
    4. 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日早上收到的,优先码来源是自己购买的发布会门票。总体感觉是…美哭了…非常非常精致。… (分享自知乎)

    单引号实验保存1