Easily using environment variables with Laravel
This blog post was originally published a little while ago. Please consider that it may no longer be relevant or even accurate.
One of the good Git lessons isn't always taught very early on and that is being very careful to never commit sensitive data to your repository, and that includes configuration details like usernames and passwords. When you do this the data committed should always be considered compromised and regenerated and the data should be removed from the repository as well, though this can often be very painful.
One mistake I see often is people commiting their database credentials straight into the repo simply because it is easy to deploy and because they haven't looked into setting up environment variables in their server (or local) environment. Admittedly, this can be annoying and a pain especially when switching between server types, but Laravel makes it really easy to inject these variables (if, of course, you're not using a tool like Laravel Forge or ServerPilot which let you make these changes through their interface). However, Laravel makes this really simple.
Let's take a look at the database configuration for an app I'm working on at the moment.
Of course, I'm going to use different database credentials for production, local development and testing. I could go through and duplicate the app/config/database.php
file and pop it into app/config/local/database.php
and app/config/testing/database.php
with the correct credentials, but let's do it the right way.
For your production environment, create a file called .env.php
in the root of your project, and have it simply return an associative array.
Now you can just place that file on your server and you're good to go in production. What about other environments though? Just as simple - a file called .env.$environment.php
. For example, here's my .env.local.php
for my local development environment (using Homestead):
Now you can configure your application credentials from just one place for each environment and keep them secure from source control (and anyone that might gain access to your code) really easily!