如何使用Laravel创建私人消息系统

时间:2016-12-11 13:46:19

标签: php mysql laravel

我正在实现没有任何软件包的简单私人消息传递应用程序。

消息表包含以下列 id,from_id,to_id,message,created_at

我希望用户能够显示以下示例中的消息 -

User1:嗨 User2:您好

用户1:你好吗? User1:怎么回事? User2:好的。

2 个答案:

答案 0 :(得分:0)

创建两个表 Conversations Messages 使用用户之间的session_id(如果存在),然后添加消息,并使用user_id将发送消息的人存储在messages表中。

class CreateMessagesTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('messages', function (Blueprint $table) {
            $table->increments('id');
            $table->text('message');
            $table->boolean('is_seen')->default(0);
            $table->boolean('deleted_from_sender')->default(0);
            $table->boolean('deleted_from_receiver')->default(0);
            $table->integer('user_id');
            $table->integer('conversation_id');
            $table->timestamps();
        });
    }


class CreateConversationsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('conversations', function (Blueprint $table) {
            $table->increments('id');
            $table->integer('user_one');
            $table->integer('user_two');
            $table->boolean('status')->default(1);
            $table->timestamps();
        });
    }

答案 1 :(得分:-1)

它的many to many关系。您应该创建数据透视表,其中两个键指向id表中的users

Schema::create('messages_pivot', function (Blueprint $table) {
    $table->increments('id');
    $table->integer('from_id')->unsigned();
    $table->integer('to_id')->unsigned();
    $table->string('message');
    $table->timestamps();
});

Schema::table('messages_pivot', function (Blueprint $table) {
    $table->foreign('from_id')->references('id')->on('users')->onDelete('cascade');
    $table->foreign('to_id')->references('id')->on('users')->onDelete('cascade');
});

您可以使用relations来使用此数据透视表,也可以为其创建模型。