• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 Node.js, Express 게시판 유저간 채팅기능 만들기 1. 채팅방 만들기

유저간 채팅기능 만들기 1. 채팅방 만들기

4 글 보임 - 1 에서 4 까지 (총 4 중에서)
  • 글쓴이
  • #31474

    서영석
    참가자

    server.js

    const express = require('express');
    const app = express();
    const bodyParser = require('body-parser');
    const MongoClient = require('mongodb').MongoClient;

    app.use(express.urlencoded({ extended: true }));
    app.use(express.json()); // parse json

    app.use('/public', express.static('public'));

    app.set('view engine', 'ejs');
    app.set('views','./views');

    var db;
    MongoClient.connect('mongodb+srv://scott:scott@cluster0.eeagm.mongodb.net/perfumeapp?retryWrites=true&w=majority', function(에러, client){
        if (에러) return console.log(에러);
        db = client.db('perfumeapp');
        app.listen('8080', function(){
          console.log('listening on 8080')
        });
      })

      app.get('/sub', function(요청, 응답){
        응답.render('sub.ejs')
      });

      app.get('/write',function(요청, 응답){
        응답.render('write.ejs')
      });
     
      app.get('/', function(요청, 응답){
        응답.render('index.ejs')
      });

      app.get('/chat', function(요청, 응답){
        응답.render('chat.ejs')
      });

      app.get('/mypage', function(요청, 응답){
        응답.render('mypage.ejs')
      });

      app.get('/logout', function(요청, 응답){
        응답.render('logout.ejs')
      });

      app.get('/join', function(요청, 응답){
        응답.render('join.ejs')
      });

      app.post('/add', function(요청, 응답){
        응답.send('전송완료');
        db.collection('notecounter').findOne({name : '작성물갯수'}, function(에러, 결과){
          console.log(결과.totalNote)
          var 총작성물갯수 = 결과.totalNote;
     
          db.collection('note').insertOne( { _id : 총작성물갯수 + 1,제목: 요청.body.title, 금액:요청.body.problem} , function(에러,결과){
            console.log('저장완료');
           
            db.collection('notecounter').updateOne({name:'작성물갯수'},{ $inc :{totalNote:1}},function(에러,결과){
              // db.collection('accounter').updateOne({name:'상품갯수'},{$inc :{AllProduct:1}})
              if(에러){return console.log(에러)}
            })
           
          });
        });
       
      });
      app.get('/list',function(요청,응답){
          db.collection('note').find().toArray(function(에러,결과){
          console.log(결과)
          응답.render('list.ejs',{notes:결과});    
        });
         
      });

      const passport = require('passport');
      const LocalStrategy = require('passport-local').Strategy;
      const session = require('express-session');
     
      app.use(session({secret : '비밀코드', resave : true, saveUninitialized: false}));
      app.use(passport.initialize());
      app.use(passport.session());

      app.get('/login', function(요청, 응답){
        응답.render('login.ejs')
      });

      app.post('/logout',function(요청, 응답){
        요청.logout();
        응답.redirect('/');
      });

      app.post('/login', passport.authenticate('local', {failureRedirect : '/fail'}), function(요청,응답){
        응답.redirect('/sub')
      });
     
      app.get('/pen',로그인했니,function(요청,응답){
        응답.render('pen.ejs');
      });

      function 로그인했니(요청,응답,next){
        if(요청.user){
          next()
        } else {
          응답.send('로그인안하셨는데요')
        }
      }

      const { ObjectId } = require('mongodb');

      app.post('/room',로그인했니,function(요청,응답){

        var 저장할거 = {
          title : '제목',
          problem : '금액',
          member : [ObjectId(요청.body.당한사람id), 요청.user._id],
          date : new Date()
        }
        db.collection('buyroom').insertOne(저장할거).then((결과)=>{
          응답.send('성공')
        })
      })

      app.get('/chat', 로그인했니, function(요청, 응답){

        db.collection('buyroom').find({ member : 요청.user._id }).toArray().then((결과)=>{
          console.log(결과);
          응답.render('chat.ejs', {data : 결과})
        })
     
      });

      app.get('/board',로그인해야지,function(요청,응답){
        응답.render('board.ejs');
      });

      function 로그인해야지(요청,응답,next){
        if(요청.user){
          next()
        } else {
          응답.send('로그인아직인가요')
        }
      }

     

      passport.use(new LocalStrategy({
        usernameField: 'uid',
        passwordField: 'pw1',
        session: true,
        passReqToCallback: false,
      }, function (입력한아이디, 입력한비번, done) {
        //console.log(입력한아이디, 입력한비번);
        db.collection('user').findOne({ uid: 입력한아이디 }, function (에러, 결과) {
          if (에러) return done(에러)
     
          if (!결과) return done(null, false, { message: '존재하지않는 아이디요' })
          if (입력한비번 == 결과.pw1) {
            return done(null, 결과)
          } else {
            return done(null, false, { message: '비번틀렸어요' })
          }
        })
      }));

      passport.serializeUser(function (user, done) {
        done(null, user.uid)
      });
     
      passport.deserializeUser(function (아이디, done) {
        db.collection('user').findOne({uid : 아이디}, function(에러, 결과){
          done(null, 결과)    
        })    
      });

        app.post('/register', function (요청, 응답) {
        db.collection('user').insertOne({ uid: 요청.body.uid, pw1: 요청.body.pw1, pw2: 요청.body.pw2, 이름: 요청.body.name,  성별: 요청.body.gender, 휴대폰번호:요청.body.ph,주소:요청.body.addr}, function (에러, 결과) {
          응답.redirect('/')
        })
      })

     

    list.ejs

    <!doctype html>
    <html>
    <head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">
    <link rel="stylesheet" href="/public/main.css">
    <title>블루밍 상세페이지</title>
    </head>
    <body>
    <%- include('nav2.html') %>
    <h4 class="ml-2 my-3 text-center">상품 목록</h4>

    <div class="container">
      <ul class="list-group">
        <% for (var i=0;i<notes.length; i++){ %>
        <li class="list-group-item">
            <p>
            글번호 : <%= notes[i]._id%>
            </p>
             <p>
              제목 : <%= notes[i].제목 %>
            </p>
            <h3> 금액 : <%= notes[i].금액 %></h3>
            <button class="btn btn-secondary chat" data-id="<%= notes[i].작성자 %>">이 유저와 채팅하기</button>
          </li>
        <% } %>
      </ul>
    </div>

    <script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
    <script>
     $('.chat').click(function(e){
          var _id = e.target.dataset.id;
          $.post('/room', {당한사람id : _id})
          .then(()=>{
            console.log('채팅방 게시물 생성완료')
          })
        });
    </script>
    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>
    </body>
    </html>

    buyroom이라는 컬렉션에 
     

    var 저장할거 = {
          title : '제목',
          problem : '금액',
          member : [ObjectId(요청.body.당한사람id), 요청.user._id],
          date : new Date()
        }

    이것을 저장하려고 하는데 db로 전달이 안되는 이유를 파악이 안되서 게시글 작성을 하게되었습니다.

    #31483

    codingapple
    키 마스터

    post요청시 서버에서 {당한사람id : _id} 이건 잘 출력되고 있나요 

    var 저장할거 이것도 출력잘되나요

    이런거 하나하나 출력해보면 됩니다 

    #31487

    서영석
    참가자

    크롬 개발자도구에서 이렇게 안나오다가 나오고 있습니다

    http://localhost:8080/chatroom 404 (Not Found)

     

    vscode는 BSONTypeError: Argument passed in must be a string of 12 bytes or a string of 24 hex characters or an integer

     

    현재  server.js

    const express = require('express');
    const app = express();
    const bodyParser = require('body-parser');
    const MongoClient = require('mongodb').MongoClient;

    app.use(express.urlencoded({ extended: true }));
    app.use(express.json()); // parse json

    app.use('/public', express.static('public'));

    app.set('view engine', 'ejs');
    app.set('views','./views');

    var db;
    MongoClient.connect('mongodb+srv://scott:scott@cluster0.eeagm.mongodb.net/perfumeapp?retryWrites=true&w=majority', function(에러, client){
        if (에러) return console.log(에러);
        db = client.db('perfumeapp');
        app.listen('8080', function(){
          console.log('listening on 8080')
        });
      })

      app.get('/sub', function(요청, 응답){
        응답.render('sub.ejs')
      });

      app.get('/write',function(요청, 응답){
        응답.render('write.ejs')
      });
     
      app.get('/', function(요청, 응답){
        응답.render('index.ejs')
      });

      app.get('/chat', function(요청, 응답){
        응답.render('chat.ejs')
      });

      app.get('/mypage', function(요청, 응답){
        응답.render('mypage.ejs')
      });

      app.get('/logout', function(요청, 응답){
        응답.render('logout.ejs')
      });

      app.get('/join', function(요청, 응답){
        응답.render('join.ejs')
      });

      app.post('/add', function(요청, 응답){
        응답.send('전송완료');
        db.collection('notecounter').findOne({name : '작성물갯수'}, function(에러, 결과){
          console.log(결과.totalNote)
          var 총작성물갯수 = 결과.totalNote;
     
          db.collection('note').insertOne( { _id : 총작성물갯수 + 1,제목: 요청.body.title, 금액:요청.body.problem} , function(에러,결과){
            console.log('저장완료');
           
            db.collection('notecounter').updateOne({name:'작성물갯수'},{ $inc :{totalNote:1}},function(에러,결과){
              // db.collection('accounter').updateOne({name:'상품갯수'},{$inc :{AllProduct:1}})
              if(에러){return console.log(에러)}
            })
           
          });
        });
       
      });
      app.get('/list',function(요청,응답){
          db.collection('note').find().toArray(function(에러,결과){
          console.log(결과)
          응답.render('list.ejs',{notes:결과});    
        });
         
      });

      const passport = require('passport');
      const LocalStrategy = require('passport-local').Strategy;
      const session = require('express-session');
     
      app.use(session({secret : '비밀코드', resave : true, saveUninitialized: false}));
      app.use(passport.initialize());
      app.use(passport.session());

      app.get('/login', function(요청, 응답){
        응답.render('login.ejs')
      });

      app.post('/logout',function(요청, 응답){
        요청.logout();
        응답.redirect('/');
      });

      app.post('/login', passport.authenticate('local', {failureRedirect : '/fail'}), function(요청,응답){
        응답.redirect('/sub')
      });
     
      app.get('/pen',로그인했니,function(요청,응답){
        응답.render('pen.ejs');
      });

      function 로그인했니(요청,응답,next){
        if(요청.user){
          next()
        } else {
          응답.send('로그인안하셨는데요')
        }
      }

      app.get('/chat', 로그인했니, function(요청, 응답){

        db.collection('buyroom').find({ member : 요청.user._id }).toArray().then((결과)=>{
          console.log(결과);
          응답.render('chat.ejs', {data : 결과})
        })
     
      });

      app.get('/board',로그인해야지,function(요청,응답){
        응답.render('board.ejs');
      });

      function 로그인해야지(요청,응답,next){
        if(요청.user){
          next()
        } else {
          응답.send('로그인아직인가요')
        }
      }

     

      passport.use(new LocalStrategy({
        usernameField: 'uid',
        passwordField: 'pw1',
        session: true,
        passReqToCallback: false,
      }, function (입력한아이디, 입력한비번, done) {
        //console.log(입력한아이디, 입력한비번);
        db.collection('user').findOne({ uid: 입력한아이디 }, function (에러, 결과) {
          if (에러) return done(에러)
     
          if (!결과) return done(null, false, { message: '존재하지않는 아이디요' })
          if (입력한비번 == 결과.pw1) {
            return done(null, 결과)
          } else {
            return done(null, false, { message: '비번틀렸어요' })
          }
        })
      }));

      passport.serializeUser(function (user, done) {
        done(null, user.uid)
      });
     
      passport.deserializeUser(function (아이디, done) {
        db.collection('user').findOne({uid : 아이디}, function(에러, 결과){
          done(null, 결과)    
        })    
      });

        app.post('/register', function (요청, 응답) {
        db.collection('user').insertOne({ uid: 요청.body.uid, pw1: 요청.body.pw1, pw2: 요청.body.pw2, 이름: 요청.body.name,  성별: 요청.body.gender, 휴대폰번호:요청.body.ph,주소:요청.body.addr}, function (에러, 결과) {
          응답.redirect('/')
        })
      })

     

    list.ejs

    <!doctype html>
    <html>
    <head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">
    <link rel="stylesheet" href="/public/main.css">
    <title>블루밍 상세페이지</title>
    </head>
    <body>
    <%- include('nav2.html') %>
    <h4 class="ml-2 my-3 text-center">상품 목록</h4>

    <div class="container">
      <ul class="list-group">
        <% for (var i=0;i<notes.length; i++){ %>
        <li class="list-group-item">
            <p>
            글번호 : <%= notes[i]._id%>
            </p>
             <p>
              제목 : <%= notes[i].제목 %>
            </p>
            <h3> 금액 : <%= notes[i].금액 %></h3>
            <button class="btn btn-secondary chat" data-id="<%= notes[i].작성자 %>">이 유저와 채팅하기</button>
          </li>
        <% } %>
      </ul>
    </div>

    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
    <script>
      $('.chat').click(function(e){
        var _id = e.target.dataset.id;
        $.post('/chatroom',{당한사람id : _id})
        .then(()=>{
          console.log('게시물 생성완료')
        })
      })
    </script>
    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>
    </body>
    </html>

     

    <!doctype html>
    <html>
    <head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">
    <link rel="stylesheet" href="/public/chat.css">
    <title>블루밍 상세페이지</title>
    </head>
    <body>
    <%- include('nav2.html') %>
    <h4 class="ml-2 my-3 text-center">상품 목록</h4>

    <ul class="list-group chat-list">

      <% for (var i=0; i < data.length ; i++){ %>
        <li class="list-group-item" data-id="<%= data[i]._id %>">
          <h6> <%= data[i].title %> </h6>
          <h6> <%= data[i].problem %> </h6>      
          <h6 class="text-small"> <%= data[i].member[0] %> </h6>
        </li>
      <% } %>
       
      <li class="list-group-item">
        <h6>채팅방1</h6>
        <h6 class="text-small">채팅방아이디</h6>
      </li>

    </ul>
    <script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
    </script>
    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>
    </body>
    </html>

     

    /chat 으로 하면 분명 data:결과라고 정의했는데 인식을 하지 않습니다.

    #31511

    codingapple
    키 마스터

    http://localhost:8080/chatroom 404 (Not Found) 이거는 서버에 /chatroom 기능개발한곳이 없다는소리입니다

     app.get('/chat' 이건 2개나 있는 것 같군요 

4 글 보임 - 1 에서 4 까지 (총 4 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠