使用Laravel来展示MongoDB的数据

我参考了下一页。
2018年02月09日在Laravel5.5中使用MongoDB创建网站。
MongoDB 数据的状态
$ mongosh
(省略)
test> use testDB;
switched to db testDB
testDB> db.post.find()
[
{
_id: ObjectId("609ef895eb0964e1af2f650c"),
body: 'おはよう',
date: '2018-1-10'
},
{
_id: ObjectId("609ef89deb0964e1af2f650d"),
body: 'こんにちは',
date: '2018-2-20'
},
{
_id: ObjectId("609ef8a4eb0964e1af2f650e"),
body: '今日は雨が降ってます。',
date: '2018-3-15'
}
]
testDB>
使用mongosh创建上述数据的方法
use testDB;
db.post.insertOne({"body": "おはよう","date": "2018-1-10"});
db.post.insertOne({"body": "こんにちは","date": "2018-2-20"});
db.post.insertOne({"body": "今日は雨が降ってます。","date": "2018-3-15"});
1) 创建项目
laravel new proj01
cd proj01
composer require "jenssegers/mongodb"
2) 编辑 config/app.php
'providers' => [
// 略
Jenssegers\Mongodb\MongodbServiceProvider::class,
],
'aliases' => [
// 略
'Moloquent' => Jenssegers\Mongodb\Eloquent\Model::class,
],
3)编辑 config/database.php
'default' => env('DB_CONNECTION', 'mongodb'),
// 略
'connections' => [
'mongodb' => [
'driver' => 'mongodb',
'host' => env('DB_HOST', 'localhost'),
'port' => env('DB_PORT', 27017),
'database' => env('DB_DATABASE', 'testDB'),
],
],
如果存在认证,则添加以下内容:
‘username’ => env(‘DB_USERNAME’,’scott’),
‘password’ => env(‘DB_PASSWORD’,’tiger123′),
4) 编辑 .env 文件
#DB_CONNECTION=mysql
#DB_HOST=127.0.0.1
#DB_PORT=3306
#DB_DATABASE=homestead
#DB_USERNAME=homestead
#DB_PASSWORD=secret
DB_CONNECTION=mongodb
DB_HOST=127.0.0.1
DB_PORT=27017
DB_DATABASE=testDB
5) 清除缓存
php artisan cache:clear
6) 编辑 routes/web.php
<?php
Route::get('/', 'App\Http\Controllers\TestController@index');
7) 创建 app/Http/Controllers/TestController.php
php artisan make:controller TestController
编辑 app/Http/Controllers/TestController.php。
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Post;
class TestController extends Controller
{
static function index() {
$posts = Post::orderBy('_id', 'desc')->get();
return view('index', ['posts' => $posts]);
}
}
8)创建 app/Post.php。
数据库testDB中的集合是post
<?php
namespace App;
class Post extends \Moloquent
{
protected $collection = 'post';
}
9) 创建 resources/views/index.blade.php
<div>全部で{{ count($posts) }}件です。</div>
<ul>
@foreach($posts as $post)
<li>{{ $post['date'] . ' | ' . $post['body'] }}</li>
@endforeach
</ul>
10) 服务器启动 (Shì fú wù qǐ
php artisan serve
11) 从客户端访问
http://本地主机:8000
我在以下环境下进行了确认。
$ uname -a
Linux iwata 5.13.0-27-generic #29-Ubuntu SMP Wed Jan 12 17:36:47 UTC 2022 x86_64 x86_64 x86_64 GNU/Linux
$ php --version
PHP 8.0.8 (cli) (built: Oct 26 2021 11:42:42) ( NTS )
Copyright (c) The PHP Group
Zend Engine v4.0.8, Copyright (c) Zend Technologies
with Zend OPcache v8.0.8, Copyright (c), by Zend Technologies
$ php artisan --version
Laravel Framework 8.82.0