lavaral 5 ERROR{ (SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES)}

时间:2015-06-30 13:28:39

标签: mysql laravel

  'default' => env('DB_CONNECTION', 'mysql'),


    'connections' => [

    'sqlite' => [
        'driver'   => 'sqlite',
        'database' => storage_path('database.sqlite'),
        'prefix'   => '',
    ],

**JUST CHANGED THE CODE FOR LOCALHOST AND CHANNGED THE NAME TO ROOT AND SET THE PASSWORD OF PHPMYADMIN . **

**WHEN WRITTING THE COMMAND IN XAMPP SHELL ((Php artisan migrate:install)) **

        'mysql' => [
        'driver'    => 'mysql',
        'host'      => env('DB_HOST', 'localhost'),
        'database'  => env('DB_DATABASE', 'laravel'),
        'username'  => env('DB_USERNAME', 'root'),
        'password'  => env('DB_PASSWORD', 'password'),
        'charset'   => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix'    => '',
        'strict'    => false,
    ],

    'pgsql' => [
        'driver'   => 'pgsql',
        'host'     => env('DB_HOST', 'localhost'),
        'database' => env('DB_DATABASE', 'forge'),
        'username' => env('DB_USERNAME', 'password'),
        'password' => env('DB_PASSWORD', ''),
        'charset'  => 'utf8',
        'prefix'   => '',
        'schema'   => 'public',
    ],

    'sqlsrv' => [
        'driver'   => 'sqlsrv',
        'host'     => env('DB_HOST', 'localhost'),
        'database' => env('DB_DATABASE', 'forge'),
        'username' => env('DB_USERNAME', 'password'),
        'password' => env('DB_PASSWORD', ''),
        'charset'  => 'utf8',
        'prefix'   => '',
    ],

],

/*
|--------------------------------------------------------------------------
| Migration Repository Table
|--------------------------------------------------------------------------
|
| This table keeps track of all the migrations that have already run for
| your application. Using this information, we can determine which of
| the migrations on disk haven't actually been run in the database.
|
*/

'migrations' => 'migrations',

/*
|--------------------------------------------------------------------------
| Redis Databases
|--------------------------------------------------------------------------
|
| Redis is an open source, fast, and advanced key-value store that also
| provides a richer set of commands than a typical key-value systems
| such as APC or Memcached. Laravel makes it easy to dig right in.
|
*/

'redis' => [

    'cluster' => false,

    'default' => [
        'host'     => '127.0.0.1',
        'port'     => 6379,
        'database' => 0,
    ],

],

it is showing error SQLSTATE[HY000] [1045] Access denied for user 'root'@'localhost' (using password: YES)

2 个答案:

答案 0 :(得分:1)

默认情况下,laravel假定您希望为不同的环境配置不同的配置。例如。在测试环境中,您可能希望使用不同的用户名和密码,并且在生产环境中使用不同的用户名和密码。由于laravel有如此多的配置文件,因此很快就会成为管理所有这些文件的噩梦。因此laravel使用PHP的环境变量。

See the docs here.

基本上说,如果你想使用laravel默认使用的“环境”变量,你必须将所有配置放在env()方法中,如上所述。

如果您不希望这样做,例如对于简单的项目,只需从代码中删除env,就像这样。

'mysql' => [
        'driver'    => 'mysql',
        'host'      => 'localhost',
        'database'  => 'laravel',
        'username'  => 'root',
        'password'  => 'password',
        'charset'   => 'utf8',
        'collation' => 'utf8_unicode_ci',
        'prefix'    => '',
        'strict'    => false,
    ],

请注意,您可以混合搭配。即你可以在env和一些独立的变量中使用一些变量。

那么为什么要使用env

让我们说你的应用程序有100个测试人员都放在不同的位置。在laravel中,您必须编写大约8-10个配置文件。您还需要version-control这些文件。所以你手头有两个问题:

  1. 您不希望向所有100个用户发送相同的凭据。他们也可能使用不同的数据库,缓存服务器等,这意味着它们将具有不同的配置。因此,每个用户都必须手动维护这些8-10个配置文件。
  2. 您不希望将这些配置文件发送到版本控制。因为如果你这样做,全世界都会知道你的API秘密,并可能会利用它(就像密码一样)。另外,如果你看一下laravel conf文件,你会注意到还有其他信息,如时区,调试属性等也在conf文件中,你确实需要对它们进行版本控制。那么如何对这些配置文件进行版本控制并仍然隐藏您的敏感信息。
  3. 答案是env个变量。 Laravel使用dotenv .env。基本上这些变量存在于键值对中名为APP_DEBUG=false APP_KEY=ABCDEFGH ... 的文件中。 E.g。

    .env文件的示例内容

    env('APP_DEBUG')

    将.env文件定义为此后,您可以使用密钥.env获取值。

    因此,这可以通过以下方式解决上述问题:

    1. 您将.env.example文件保留给自己。并且您还声明了另一个名为env('APP_KEY')的文件,它是原始文件的精确副本,除了它包含样本值,而不是敏感值。然后将这个新的示例文件传递给每个人。他们将用自己的敏感信息替换样本数据。
    2. 由于您是版本控制示例文件,因此您可以对所有conf文件进行版本控制,因为它们不包含该秘密。秘密在.env文件中。所有这些conf文件都包含这些{{1}}之类的值,并且在运行时使用.env文件替换实际值。

答案 1 :(得分:0)

确保必须在Laravel项目的.env文件中设置正确的服务器凭据:

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=myapp_db
DB_USERNAME=root
DB_PASSWORD=pass

尝试清理工匠缓存并重新启动工匠,

php artisan config:clear 
restart php artisan