Pubnub一对一聊天向所有用户发送消息

时间:2018-05-07 10:07:52

标签: javascript laravel-5 chat real-time pubnub

这是我的Pubnub聊天代码

 var pubnub = PUBNUB.init({
    publish_key   : 'my_key',
    subscribe_key : 'sub-key'
});

  pubnub.subscribe({

    channel : "{{$channel}}",

    message : function(m){

     $(".conversation-list").append(
        '<li class="clearfix '+ m.clearifix +' ">' +
        '<div class="chat-avatar">' +
        '<img src="' + m.image + '">'+
        '<i> {{date('h:i')}}  </i>' +
        '</div>' +
        '<div class="conversation-text">' +
        '<div class="ctext-wrap">' +
        '<i> '+ m.name + '</i>' +
        '<p>' + m.message + '</p>' +
        '</div>' +
        '</div>' +
        '</li>'
        ).animate({scrollTop: $(".conversation-list")[0].scrollHeight}, 0);
     $('.reply-text').val('');

 },
     //connect : publish
 });

  $('.send-reply-to-user').on('click', function (e) {
    e.preventDefault();

    if ($('.reply-text').val()== '')
        return false;
    else

        console.log(pubnub.publish);
   // console.log(this);

    var user_to_id = $(".send-reply-to-user").attr('user_to_id');
    var message = $('.reply-text').val();
    var name = $('#user_name').val();
    var image = document.getElementById("user_image").getAttribute("src");
    var clearifix = $('#user_clearifx').val();

    pubnub.publish({
        channel : "{{$channel}}",
        message: { name : name, message : message, image : image, clearifix : clearifix }
    });

    if ($.trim(message).length != 0) {
        $.ajax({
            url: '{{route('send:user:chat:message')}}',
            cache: false,
            method: 'POST',
            data: {user_to_id: user_to_id, message: message, _token: '{{csrf_token()}}'},
            beforeSend: function () {
            },
            success: function (result) {
            }

        })
    }

});

此代码完美运行只有问题是消息发送给所有用户,我想将消息发送给一对一用户。

Example: User one: John send a message to User two Deo, 
Example 2: John sends a message to Marry

等等。使用Pubnub JS API,Backend作为Laravel 5.6

2 个答案:

答案 0 :(得分:2)

我建议使用名为ChatEngine的PubNub自以为是的JavaScript框架。它消除了与PubNub聊天所涉及的大量繁重工作。以下是一些示例代码,可帮助您开始进行1:1私人聊天。请务必使用setup button为您的帐户准备后端。

<script src="https://cdn.jsdelivr.net/npm/chat-engine@0.9.5/dist/chat-engine.min.js" type="text/javascript"></script>
<script type="text/javascript">

// Init ChatEngine with PubNub
const publishKey = '__Your_PubNub_Publish_Key__';
const subscribeKey = '__Your_PubNub_Subscribe_Key__';

const ChatEngine = ChatEngineCore.create({
  publishKey,
  subscribeKey,
}, {
  globalChannel: 'global',
});

const user = {
    uuid: 'randomstringofchars',
    name: 'John Smith'
}

const chats = {};

ChatEngine.connect(user.uuid, user);

ChatEngine.on('$.ready', function(data) {

    // store my new user as `me`
    let me = data.me;

    // returns a ChatEngine chat object
    function makePrivateChat(theirUserId) {
        const chatKey = [theirUserId, me.uuid].sort().join('-');

        // Don't make the same 1:1 chat if it already exists
        if (chats[chatKey]) {
            return;
        }

        // true for private chat
        const chat = new ChatEngine.Chat(chatKey, true);

        chats[chatKey] = chat;
    }

    // Auto add a 1:1 chat to UI when invited by someone
    me.direct.on('$.invite', makePrivateChat);

    // Define a button for making new 1:1 chats in your UI
    newOneToOneChatButton.on('click', function (event, theirUserId) {
        someChatObject.invite(theirUserId);
    });
});
</script>

答案 1 :(得分:1)

最后修正我的问题,私人频道运作良好,实际问题是我的后端。它返回了我已修复的所有用户的数据,现在它正常工作。