백엔드 개발 PHP 튜토리얼 PHP와 Node.js를 사용하여 WebRTC 오디오 및 비디오 통신 시스템 개발

PHP와 Node.js를 사용하여 WebRTC 오디오 및 비디오 통신 시스템 개발

Jun 27, 2023 pm 04:53 PM
php nodejs webrtc

WebRTC는 브라우저 간 오디오 및 비디오 통신을 위한 표준 프로토콜과 API를 제공하는 오픈 소스 프로젝트입니다. WebRTC를 사용하면 플러그인이나 애플리케이션을 설치하지 않고도 브라우저 간에 실시간 오디오 및 비디오 통신이 가능합니다. WebRTC는 화상 회의, 온라인 고객 서비스, 모니터링 시스템, 게임 라이브 방송과 같은 시나리오에서 사용할 수 있습니다.

이 글에서는 PHP와 Node.js를 사용하여 WebRTC 기반 오디오 및 비디오 통신 시스템을 개발하는 방법을 설명합니다.

  1. WebRTC의 기본

WebRTC에는 세 가지 주요 API가 포함되어 있습니다.

  • MediaStream: 카메라 및 마이크와 같은 오디오 및 비디오 장치에 액세스하는 데 사용됩니다.
  • RTCPeerConnection: 오디오 및 비디오 데이터 전송을 실현하기 위해 지점 간 연결을 설정하는 데 사용됩니다.
  • RTCDataChannel: 텍스트, 파일 등과 같은 비오디오 및 비디오 데이터의 지점 간 전송에 사용됩니다.

WebRTC는 STUN, TURN 및 ICE와 같은 프로토콜을 사용하여 네트워크 침투를 달성하고 NAT 및 방화벽과 같은 네트워크 제한을 극복하며 지점 간 연결을 달성합니다. 연결을 설정하는 과정에서 먼저 STUN 서버를 통해 IP 주소와 포트 번호를 얻은 후 상대방에게 데이터 전송을 시도해야 합니다. 실패하면 TURN 서버를 사용하여 데이터를 전송합니다.

  1. PHP 개발 환경 구축

PHP 프레임워크 Laravel을 사용하여 강력한 데이터베이스, RESTful API 및 WebSocket 지원을 제공하는 WebRTC 서버를 구축할 수 있습니다.

먼저 Composer와 PHP를 설치한 다음 Composer를 사용하여 Laravel을 설치하세요.

composer global require "laravel/installer"
로그인 후 복사

Laravel을 사용하여 새 프로젝트 만들기:

laravel new webrtc-server
로그인 후 복사

Laravel의 내장 웹 서버 실행:

php artisan serve
로그인 후 복사

브라우저에서 http://localhost:8000을 방문하세요. , Laravel의 기본 환영 페이지를 볼 수 있습니다.

  1. Node.js 개발 환경 설정

WebRTC, Socket.IO 등의 종속성을 설치하려면 Node.js와 npm을 사용해야 합니다. Node.js 및 npm을 설치한 후 다음 명령을 실행하여 종속성을 설치합니다.

npm install webrtc
npm install socket.io
로그인 후 복사

Node.js 서버를 생성하고 시작 시 WebSocket 연결 요청을 수신합니다.

const socketIo = require('socket.io')
const http = require('http')

const server = http.createServer((request, response) => {
  response.writeHead(200)
  response.end('WebRTC signaling server
')
})

const io = socketIo(server)
io.on('connection', (socket) => {
  console.log(`Client ${socket.id} connected`)
  socket.on('message', (data) => {
    console.log(`Client ${socket.id} sent message: ${JSON.stringify(data)}`)
    socket.broadcast.emit('message', data)
  })
})

server.listen(3000, () => {
  console.log('Server started on port 3000')
})
로그인 후 복사
  1. WebRTC 오디오 및 비디오 통신 구현

WebRTC 오디오 및 비디오 통신을 구현하려면 클라이언트 측에서 MediaStream 및 RTCPeerConnection API를 사용해야 합니다.

먼저 로컬 카메라와 마이크의 MediaStream을 가져옵니다:

navigator.mediaDevices.getUserMedia({
  audio: true,
  video: true
}).then(stream => {
  // 本地摄像头和麦克风MediaStream
})
로그인 후 복사

그런 다음 상대방의 WebSocket 주소를 기반으로 RTCPeerConnection 개체를 만들고 로컬 MediaStream을 전송 채널에 추가합니다.

const peer = new RTCPeerConnection({
  iceServers: [{
    urls: 'stun:stun.l.google.com:19302'
  }]
})

peer.addStream(localStream)
...
로그인 후 복사

다음으로 설정을 시작합니다. point-to-point 연결이 성공적으로 이루어졌을 때 상대방의 미디어 스트림을 재생 채널에 추가하면:

peer.createOffer().then(offer => {
  peer.setLocalDescription(offer).then(() => {
    socket.emit('message', { type: 'offer', sdp: offer })
  })
})

socket.on('message', (data) => {
  if (data.type === 'offer') {
    peer.setRemoteDescription(new RTCSessionDescription(data)).then(() => {
      peer.createAnswer().then(answer => {
        peer.setLocalDescription(answer).then(() => {
          socket.emit('message', { type: 'answer', sdp: answer })
        })
      })
    })
  } else if (data.type === 'answer') {
    peer.setRemoteDescription(new RTCSessionDescription(data))
  } else if (data.type === 'candidate') {
    peer.addIceCandidate(new RTCIceCandidate(data.candidate))
  }
})

peer.onaddstream = (event) => {
  remoteVideo.srcObject = event.stream
}
로그인 후 복사

마지막으로 상대방에게 ICE 후보 주소를 보냅니다:

peer.onicecandidate = (event) => {
  if (event.candidate) {
    socket.emit('message', { type: 'candidate', candidate: event.candidate })
  }
}
로그인 후 복사
  1. 결론

사용 WebRTC 기반 오디오 및 비디오 통신 시스템을 개발하기 위한 PHP와 Node.js는 복잡하지 않으며 WebRTC 및 관련 API에 대한 기본 지식만 마스터하면 전체 시스템을 빠르게 구축할 수 있습니다. 동시에 Laravel 및 Socket.IO와 같은 강력한 프레임워크와 라이브러리는 개발 효율성을 빠르게 향상시키고 보다 안정적인 고품질 오디오 및 비디오 통신 애플리케이션을 달성할 수 있습니다.

위 내용은 PHP와 Node.js를 사용하여 WebRTC 오디오 및 비디오 통신 시스템 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

cakephp4에서 날짜와 시간을 다루기 위해 사용 가능한 FrozenTime 클래스를 활용하겠습니다.

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

파일 업로드 작업을 위해 양식 도우미를 사용할 것입니다. 다음은 파일 업로드의 예입니다.

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

이번 장에서는 라우팅과 관련된 다음과 같은 주제를 학습하겠습니다.

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP 유효성 검사기 만들기 CakePHP 유효성 검사기 만들기 Sep 10, 2024 pm 05:26 PM

컨트롤러에 다음 두 줄을 추가하면 유효성 검사기를 만들 수 있습니다.

See all articles