MySQL凭证/托管变量最佳实践

时间:2011-10-18 23:37:59

标签: mysql variables mysql-connect

我想知道在为MySQL凭证/主机创建变量时,最佳做法是什么或建议做什么。

    define('HOST', 'localhost');
    // etc..
   mysql_connect(HOST, // etc...

VS

    $host = 'localhost';
    // etc..
   mysql_connect($host, // etc...

对于这两者,您可以轻松检查声明的变量或常量是什么,并且可以轻松找到值。我有多个用户可以共享和使用的代码。

保护这些变量的最佳方法是什么?

2 个答案:

答案 0 :(得分:31)

这里有一些解决方案

1)您为每个用户提供一个用户和密码,每个用户在数据库中拥有自己的权限(仅选择或插入ect ..)。因此,在您的代码中,您只需包含一个db.config.php,以便设置所有变量。用户回应变量并不重要,因为他们使用自己的变量。

2)你可以为数据库提供一个通用的用户名/密码然后对文件进行编码(使用custom encoding,zend optimizer或ioncube并取消设置变量。这是一个示例代码:

// file mysql_connect.php

$link = mysql_connect("localhost", "mysql_user", "mysql_password")
    or die("cannot connect to database : " . mysql_error());

// then this file is encoded so nobody can view it.

3)在某些时候,有人会以某种方式找到这些信息。我只是建议信任您的用户(假设这些是开发人员)

答案 1 :(得分:1)

在您的代码中的某些时候,您将不得不对此类信息进行硬编码,重要的是将其保留在一个位置以促进可维护性。 但是,由于您担心安全性,我建议您检查一下:Convert PHP file to binary