MongoDB и CodeIgniter [закрыто]
-
20-09-2019 - |
Вопрос
Может ли кто-нибудь помочь мне указать учебник, библиотеку и т. д.это позволит мне работать с MongoDB из CodeIgniter?
Решение
Я не уверен, что это «способ CodeIgniter», но я создал библиотеку CodeIgniter, которая расширяет класс Mongo дополнительным свойством для хранения текущего соединения с базой данных.
Вот соответствующие файлы кода из моего проекта.
конфигурация/монго.php
$config['mongo_server'] = null;
$config['mongo_dbname'] = 'mydb';
библиотеки/Mongo.php
class CI_Mongo extends Mongo
{
var $db;
function CI_Mongo()
{
// Fetch CodeIgniter instance
$ci = get_instance();
// Load Mongo configuration file
$ci->load->config('mongo');
// Fetch Mongo server and database configuration
$server = $ci->config->item('mongo_server');
$dbname = $ci->config->item('mongo_dbname');
// Initialise Mongo
if ($server)
{
parent::__construct($server);
}
else
{
parent::__construct();
}
$this->db = $this->$dbname;
}
}
И образец контроллера
контроллеры/posts.php
class Posts extends Controller
{
function Posts()
{
parent::Controller();
}
function index()
{
$posts = $this->mongo->db->posts->find();
foreach ($posts as $id => $post)
{
var_dump($id);
var_dump($post);
}
}
function create()
{
$post = array('title' => 'Test post');
$this->mongo->db->posts->insert($post);
var_dump($post);
}
}
Другие советы
MongoDB очень хорошо поддерживается сообществом CodeIgniter, найдите время и погрузитесь в него :p
Мне нравится пример Стивена Каррана, поскольку он прост и позволяет создать интерфейс для Mongo без слишком большого количества функций, написанных в Php. Иногда я склонен находить огромные классы абстракции для того, что мне нужно.
Я расширил его пример, включив в него аутентификацию базы данных.Иди сюда: http://www.mongodb.org/display/DOCS/Security+and+Authentication Чтобы прочитать об аутентификации mongo, не забудьте включить аутентификацию для сервера Mongo, к которому вы подключаетесь.
Я также изменил функцию конструктора старого стиля на __construct и обрабатываю исключения подключения Mongo, поскольку они могут раскрыть ваше имя пользователя и пароль.
конфигурация/монго.php
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
$config['mongo_server'] = 'localhost';
$config['mongo_dbname'] = 'my_mongo_db';
$config['mongo_username'] = 'mongo_user';
$config['mongo_password'] = 'password1234';
/* End of file mongo.php */
библиотеки/Mongo.php
<?php
class CI_Mongo extends Mongo{
protected $db;
function __construct()
{
// Fetch CodeIgniter instance
$ci = get_instance();
// Load Mongo configuration file
$ci->load->config('mongo');
// Fetch Mongo server and database configuration
$server = $ci->config->item('mongo_server');
$username = $ci->config->item('mongo_username');
$password = $ci->config->item('mongo_password');
$dbname = $ci->config->item('mongo_dbname');
// Initialise Mongo - Authentication required
try{
parent::__construct("mongodb://$username:$password@$server/$dbname");
$this->db = $this->$dbname;
}catch(MongoConnectionException $e){
//Don't show Mongo Exceptions as they can contain authentication info
$_error =& load_class('Exceptions', 'core');
exit($_error->show_error('MongoDB Connection Error', 'A MongoDB error occured while trying to connect to the database!', 'error_db'));
}catch(Exception $e){
$_error =& load_class('Exceptions', 'core');
exit($_error->show_error('MongoDB Error',$e->getMessage(), 'error_db'));
}
}
}
Работа с MongoDB в CodeIgniter не будет сильно отличаться от работы с ним где-либо еще.
Вы можете собрать библиотеку MongoDB, которая будет подключаться в конструкторе и хранить $this->conn для дальнейшего использования в методах.
затем либо работайте напрямую со свойством conn в своих контроллерах, либо создайте несколько методов в своей библиотеке MongoDB, чтобы сделать это за вас.
Взглянем здесь чтобы увидеть простое руководство по PHP для работы с MongoDB.
Я бы с радостью создал для вас библиотеку, но за это придется заплатить.:-п
Я использую MongoDB с CI и получил следующее.У меня это работает, но я уверен, что это можно немного подправить.Позже я побеспокоюсь о его настройке, но сейчас он делает то, что я хочу.
Я создал модель под названием «database_conn.php».
class Database_Conn extends Model {
function _connect() {
$m = new Mongo();
$db = $m->selectDB( "YOUR DATABASE NAME" );
return $db;
}
}
Потом, если мне нужно подключиться к коллекции из моих моделей.
$collection = Database_Conn::_connect()->selectCollection( "COLLECTION NAME" );