How to handle DB connection errors |
Hello all,
I have developed a superadmin system that manages an admin interface for a lot of users, each with his own database. It is working well, but there's one situation that I'm not able to handle yet. When logging in, the superadmin supplies the ID of the database he will access. There are three alternatives as for the outcome:
PHP Code: $config['hostname'] = $row->server; // from the superadmin DB However, in situation #2 the "conn_id" error is not reached. CodeIgniter steps in with the "Unable to connect to your database server using the provided settings." error and that's it. Is there a way to handle this kind of connection error, so I can redirect to the previous page and inform the user? I don't want the CI error page to show. Thank you very much for your help.
You can check for an error using:
PHP Code: $error = $this->db->error(); You can check the connection using this: PHP Code: $connected = $this->conn_id; You can always view the CodeIgniter source files to learn a lot of hidden gems also... What did you Try? What did you Get? What did you Expect?
Joined CodeIgniter Community 2009. ( Skype: insitfx )
Unfortunately, it does not work, because when I use $this->load->database($db_config) CodeIgniter already attempts the connection and the error occurs. I can't test for the error before the connection is successful. This is what's bothering me. However, I think that I will have to find another way to do this.
If you need to test it first, you can connect using pure MySQLi code then use CI.
What did you Try? What did you Get? What did you Expect?
Joined CodeIgniter Community 2009. ( Skype: insitfx )
I've just had a quick read through the CodeIgniter source code that triggers the error message you're running into.
In the config/database.php file there is the following setting: Code: $db['default'] = array( and in system/database/DB_driver.php the following code seems to be triggering the error message you're seeing: Code: public function initialize() After a quick test setting db_debug to FALSE in the database.php config does prevent CodeIgniter from hijacking the request to display the error message, and execution will continue, the initialize method should return FALSE if the connection fails. Try changing the following code in your application: Code: $config['db_debug'] = (ENVIRONMENT !== 'production'); to: Code: $config['db_debug'] = FALSE; and check the value that's returned by: Code: $this->load->database($config, TRUE); in your test case, this may help you to detect a failed connection attempt without the error message hijacking the request. I am testing this on the latest version of CodeIgniter (currently v3.1.4), if you are running an older version this may or may not work for you. |
Welcome Guest, Not a member yet? Register Sign In |