쪽지발송 성공
Click here
재능넷 이용방법
재능넷 이용방법 동영상편
가입인사 이벤트
판매 수수료 안내
안전거래 TIP
재능인 인증서 발급안내

🌲 지식인의 숲 🌲

🌳 디자인
🌳 음악/영상
🌳 문서작성
🌳 번역/외국어
🌳 프로그램개발
🌳 마케팅/비즈니스
🌳 생활서비스
🌳 철학
🌳 과학
🌳 수학
🌳 역사
해당 지식과 관련있는 인기재능

개인용도의 프로그램이나 소규모 프로그램을 합리적인 가격으로 제작해드립니다.개발 아이디어가 있으시다면 부담 갖지 마시고 문의해주세요. ...

AS규정기본적으로 A/S 는 평생 가능합니다. *. 구매자의 요청으로 수정 및 보완이 필요한 경우 일정 금액의 수고비를 상호 협의하에 요청 할수 있...

30년간 직장 생활을 하고 정년 퇴직을 하였습니다.퇴직 후 재능넷 수행 내용은 쇼핑몰/학원/판매점 등 관리 프로그램 및 데이터 ...

프로그래밍 15년이상 개발자입니다.(이학사, 공학 석사) ※ 판매자와 상담 후에 구매해주세요. 학습을 위한 코드, 게임, 엑셀 자동화, 업...

PHP 웹소켓 프로그래밍 입문

2024-09-26 23:36:43

재능넷
조회수 424 댓글수 0

PHP 웹소켓 프로그래밍 입문: 실시간 통신의 세계로 뛰어들기 🚀

 

 

안녕하세요, 여러분! 오늘은 정말 흥미진진한 주제로 여러분을 찾아왔어요. 바로 'PHP 웹소켓 프로그래밍'에 대해 알아볼 거예요. 🎉 웹 개발의 세계에서 실시간 통신이 얼마나 중요한지 아시나요? 그렇다면 웹소켓이 얼마나 강력한 도구인지 곧 알게 되실 거예요!

PHP는 웹 개발에서 정말 인기 있는 언어죠. 그런데 웹소켓과 함께 사용하면 그 가능성이 무한대로 확장된답니다. 실시간 채팅, 라이브 알림, 실시간 데이터 업데이트 등 다양한 기능을 구현할 수 있어요. 이런 기술은 요즘 많은 플랫폼에서 사용되고 있어요. 예를 들어, 재능 공유 플랫폼인 재능넷 같은 곳에서도 실시간 메시징 기능을 위해 이런 기술을 활용할 수 있죠.

자, 그럼 이제 본격적으로 PHP 웹소켓 프로그래밍의 세계로 들어가볼까요? 준비되셨나요? Let's go! 🏃‍♂️💨

1. 웹소켓이란 무엇인가요? 🤔

웹소켓에 대해 이야기하기 전에, 먼저 전통적인 웹 통신 방식에 대해 간단히 살펴볼까요?

전통적인 HTTP 통신: 클라이언트가 요청을 보내면 서버가 응답하는 방식이에요. 매번 새로운 연결을 열고 닫아야 해서 실시간 통신에는 적합하지 않죠.

그런데 웹소켓은 어떨까요? 🌟

웹소켓 통신: 클라이언트와 서버 사이에 지속적인 연결을 유지해요. 한 번 연결되면 양방향으로 자유롭게 데이터를 주고받을 수 있어요.

웹소켓의 장점은 정말 많아요:

  • 실시간 양방향 통신이 가능해요. 📡
  • 서버에서 클라이언트로 데이터를 푸시할 수 있어요. 🔔
  • 연결 유지 비용이 HTTP에 비해 낮아요. 💰
  • 지연 시간이 줄어들어 빠른 데이터 전송이 가능해요. ⚡

이런 특징 때문에 웹소켓은 실시간 애플리케이션 개발에 딱이에요. 채팅 앱, 실시간 게임, 주식 거래 플랫폼 등 다양한 분야에서 활용되고 있죠.

웹소켓 vs HTTP 통신 웹소켓 vs HTTP 통신 웹소켓 지속적인 연결 HTTP 요청-응답 방식

자, 이제 웹소켓이 뭔지 대충 감이 오시나요? 그럼 이제 PHP에서 어떻게 웹소켓을 사용하는지 알아볼까요? 🕵️‍♀️

2. PHP에서 웹소켓 사용하기: Ratchet 라이브러리 소개 📚

PHP에서 웹소켓을 사용하려면 어떻게 해야 할까요? 다행히도 우리에겐 강력한 도구가 있어요. 바로 'Ratchet' 이라는 라이브러리예요! 🛠️

Ratchet: PHP로 작성된 웹소켓 서버를 쉽게 만들 수 있게 해주는 라이브러리예요. 실시간, 양방향, 전이중 통신 애플리케이션을 만들 수 있어요.

Ratchet을 사용하면 정말 다양한 것들을 할 수 있어요:

  • 실시간 채팅 애플리케이션 만들기 💬
  • 실시간 알림 시스템 구축하기 🔔
  • 실시간 협업 도구 개발하기 🤝
  • 실시간 게임 서버 만들기 🎮

자, 그럼 Ratchet을 어떻게 설치하고 사용하는지 알아볼까요?

Ratchet 설치하기

Ratchet은 Composer를 통해 쉽게 설치할 수 있어요. Composer가 설치되어 있다면, 터미널에서 다음 명령어를 실행하면 돼요:

composer require cboden/ratchet

이 명령어를 실행하면 Ratchet과 그 의존성들이 자동으로 설치됩니다.

간단한 웹소켓 서버 만들기

자, 이제 Ratchet을 사용해서 간단한 웹소켓 서버를 만들어볼까요? 다음 코드를 보세요:


<?php
use Ratchet\Server\IoServer;
use Ratchet\Http\HttpServer;
use Ratchet\WebSocket\WsServer;
use MyApp\Chat;

require dirname(__DIR__) . '/vendor/autoload.php';

$server = IoServer::factory(
    new HttpServer(
        new WsServer(
            new Chat()
        )
    ),
    8080
);

$server->run();

이 코드는 정말 간단한 웹소켓 서버를 만드는 예제예요. 8080 포트에서 실행되는 서버를 만들고, Chat 클래스를 통해 메시지를 처리해요.

Chat 클래스는 다음과 같이 구현할 수 있어요:


<?php
namespace MyApp;
use Ratchet\MessageComponentInterface;
use Ratchet\ConnectionInterface;

class Chat implements MessageComponentInterface {
    protected $clients;

    public function __construct() {
        $this->clients = new \SplObjectStorage;
    }

    public function onOpen(ConnectionInterface $conn) {
        $this->clients->attach($conn);
        echo "New connection! ({$conn->resourceId})\n";
    }

    public function onMessage(ConnectionInterface $from, $msg) {
        foreach ($this->clients as $client) {
            if ($from !== $client) {
                $client->send($msg);
            }
        }
    }

    public function onClose(ConnectionInterface $conn) {
        $this->clients->detach($conn);
        echo "Connection {$conn->resourceId} has disconnected\n";
    }

    public function onError(ConnectionInterface $conn, \Exception $e) {
        echo "An error has occurred: {$e->getMessage()}\n";
        $conn->close();
    }
}

이 Chat 클래스는 새로운 연결이 생기면 관리하고, 메시지를 받으면 다른 모든 클라이언트에게 전달하는 역할을 해요. 연결이 끊어지면 클라이언트 목록에서 제거하고, 에러가 발생하면 연결을 닫아요.

Ratchet 웹소켓 서버 구조 Ratchet 웹소켓 서버 구조 IoServer HttpServer WsServer Chat 클래스

이렇게 만든 서버는 터미널에서 다음 명령어로 실행할 수 있어요:

php server.php

와! 이제 우리만의 웹소켓 서버가 실행되고 있어요. 🎉 클라이언트에서 이 서버에 연결하면 실시간으로 메시지를 주고받을 수 있게 되었죠.

물론 이건 정말 기본적인 예제일 뿐이에요. 실제 애플리케이션에서는 더 복잡한 로직이 필요할 거예요. 하지만 이 예제를 통해 PHP에서 웹소켓을 어떻게 다루는지 기본적인 개념을 이해하셨길 바라요.

다음 섹션에서는 이 서버에 실제로 연결하는 클라이언트 코드를 작성해볼 거예요. 준비되셨나요? 계속 가보죠! 🚀

3. 웹소켓 클라이언트 만들기: JavaScript로 연결하기 🌐

서버 쪽 코드를 작성했으니, 이제 클라이언트 쪽 코드를 만들어볼 차례예요. 웹 브라우저에서 웹소켓을 사용하려면 JavaScript를 사용해야 해요. 다행히도 JavaScript에는 WebSocket API가 내장되어 있어서 아주 쉽게 사용할 수 있답니다. 😊

기본적인 웹소켓 클라이언트 코드

다음은 기본적인 웹소켓 클라이언트 코드예요:


<!DOCTYPE html>
<html>
<head>
    <title>WebSocket 채팅</title>
</head>
<body>
    <h1>WebSocket 채팅</h1>
    <div id="chat"></div>
    <input type="text" id="message" placeholder="메시지를 입력하세요">
    <button onclick="sendMessage()">전송</button>

    <script>
        var ws = new WebSocket('ws://localhost:8080');
        
        ws.onopen = function() {
            console.log('웹소켓 연결 성공!');
        };
        
        ws.onmessage = function(event) {
            var chatDiv = document.getElementById('chat');
            chatDiv.innerHTML += '<p>' + event.data + '</p>';
        };
        
        function sendMessage() {
            var messageInput = document.getElementById('message');
            var message = messageInput.value;
            ws.send(message);
            messageInput.value = '';
        }
    </script>
</body>
</html>

이 코드는 아주 간단한 채팅 인터페이스를 만들어요. 사용자가 메시지를 입력하고 '전송' 버튼을 클릭하면 서버로 메시지가 전송되죠. 서버에서 메시지를 받으면 화면에 표시됩니다.

주의사항: 실제 프로덕션 환경에서는 보안을 위해 'wss://' (WebSocket Secure) 프로토콜을 사용해야 해요. 'ws://'는 로컬 개발 환경에서만 사용하세요!

웹소켓 연결 상태 처리하기

실제 애플리케이션에서는 연결 상태를 더 자세히 처리해야 할 필요가 있어요. 다음은 연결 상태를 처리하는 더 자세한 예제입니다:


var ws;

function connect() {
    ws = new WebSocket('ws://localhost:8080');

    ws.onopen = function() {
        console.log('웹소켓 연결 성공!');
        document.getElementById('status').textContent = '연결됨';
    };

    ws.onclose = function() {
        console.log('웹소켓 연결 끊김. 재연결 시도...');
        document.getElementById('status').textContent = '연결 끊김';
        setTimeout(connect, 3000);  // 3초 후 재연결 시도
    };

    ws.onerror = function(error) {
        console.log('웹소켓 에러:', error);
        document.getElementById('status').textContent = '에러 발생';
    };

    ws.onmessage = function(event) {
        var chatDiv = document.getElementById('chat');
        chatDiv.innerHTML += '<p>' + event.data + '</p>';
    };
}

connect();  // 초기 연결 시도

function sendMessage() {
    if (ws.readyState === WebSocket.OPEN) {
        var messageInput = document.getElementById('message');
        var message = messageInput.value;
        ws.send(message);
        messageInput.value = '';
    } else {
        alert('웹소켓이 연결되어 있지 않습니다.');
    }
}

이 코드는 연결이 끊어졌을 때 자동으로 재연결을 시도하고, 연결 상태를 사용자에게 보여줍니다. 또한 메시지를 보내기 전에 연결 상태를 확인하죠.

웹소켓 클라이언트 상태 다이어그램 웹소켓 클라이언트 상태 다이어그램 연결 중 연결됨 에러 onopen onerror onclose (재연결 시도)

보안 고려사항

웹소켓을 사용할 때는 보안에 특히 신경 써야 해요. 몇 가지 중요한 포인트를 살펴볼까요?

  • 항상 wss:// 프로토콜 사용하기: 프로덕션 환경에서는 반드시 암호화된 연결을 사용해야 해요.
  • 입력 검증: 서버에서 받은 모든 데이터를 신뢰하지 마세요. 항상 검증을 거쳐야 해요.
  • 인증과 권한 부여: 웹소켓 연결에도 적절한 인증 메커니즘을 구현해야 해요.
  • Rate Limiting: 클라이언트가 너무 많은 메시지를 보내지 못하도록 제한해야 해요.

이렇게 하면 기본적인 웹소켓 클라이언트를 만들 수 있어요. 물론 실제 애플리케이션에서는 더 많은 기능과 더 복잡한 로직이 필요하겠지만, 이 예제를 통해 기본적인 개념을 이해하셨길 바라요.

자, 이제 서버와 클라이언트 모두 준비가 되었네요! 🎉 다음 섹션에서는 이 둘을 합쳐서 실제로 동작하는 간단한 채팅 애플리케이션을 만들어볼 거예요. 기대되지 않나요? 😃

4. 실전 예제: 간단한 채팅 애플리케이션 만들기 💬

자, 이제 우리가 배운 내용을 토대로 간단한 실시간 채팅 애플리케이션을 만들어볼까요? 이 예제를 통해 PHP 웹소켓 서버와 JavaScript 클라이언트가 어떻게 상호작용하는지 더 잘 이해할 수 있을 거예요. 😊

1. 서버 측 코드 (PHP)

먼저 서버 측 코드를 작성해볼게요. 이 코드는 'server.php'라는 파일에 저장하세요:


<?php
use Ratchet\Server\IoServer;
use Ratchet\Http\HttpServer;
use Ratchet\WebSocket\WsServer;
use Ratchet\MessageComponentInterface;
use Ratchet\ConnectionInterface;

require dirname(__DIR__) . '/vendor/autoload.php';

class Chat implements MessageComponentInterface {
    protected $clients;

    public function __construct() {
        $this->clients = new \SplObjectStorage;
    }

    public function onOpen(ConnectionInterface $conn) {
        $this->clients->attach($conn);
        echo "새로운 연결! ({$conn->resourceId})\n";
    }

    public function onMessage(ConnectionInterface $from, $msg) {
        $numRecv = count($this->clients) - 1;
        echo sprintf('연결 %d에서 "%s"라는 메시지를 받았습니다. %d명의 다른 연결에 전송합니다.' . "\n"
            , $from->resourceId, $msg, $numRecv);

        foreach ($this->clients as $client) {
            if ($from !== $client) {
                $client->send($msg);
            }
        }
    }

    public function onClose(ConnectionInterface $conn) {
        $this->clients->detach($conn);
        echo "연결 {$conn->resourceId} 이(가) 종료되었습니다.\n";
    }

    public function onError(ConnectionInterface $conn, \Exception $e) {
        echo "에러 발생: {$e->getMessage()}\n";
        $conn->close();
    }
}

$server = IoServer::factory(
    new HttpServer(
        new WsServer(
            new Chat()
        )
    ),
    8080
);

echo "채팅 서버가 시작되었습니다. (포트 8080)\n";

$server->run();

이 서버는 새로운 연결을 관리하고, 메시지를 받으면 연결된 모든 다른 클라이언트에게 전달하는 역할을 해요.

2. 클라이언트 측 코드 (HTML/JavaScript)

이제 클라이언트 측 코드를 작성해볼게요. 이 코드는 'index.html'이라는 파일에 저장하세요:


<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>실시간 채팅</title>
    <style>
        body { font-family: Arial, sans-serif; max-width: 800px; margin: 0 auto; padding: 20px; }
        #chat { height: 300px; overflow-y: scroll; border: 1px solid #ddd; padding: 10px; margin-bottom: 20px; }
        #message { width: 70%; padding: 5px; }
        button { padding: 5px 10px; }
    </style>
</head>
<body>
    <h1>실시간 채팅</h1>
    <div id="status">연결 중...</div>
    <div id="chat"></div>
    <input type="text" id="message" placeholder="메시지를 입력하세요">
    <button onclick="sendMessage()">전송</button>

    <script>
        var ws;

        function connect() {
            ws = new WebSocket('ws://localhost:8080');

            ws.onopen = function() {
                console.log('웹소켓 연결 성공!');
                document.getElementById('status').textContent = '연결됨';
            };

            ws.onclose = function() {
                console.log('웹소켓 연결 끊김. 재연결 시도...');
                document.getElementById('status').textContent = '연결 끊김';
                setTimeout(connect, 3000);
            };

            ws.onerror = function(error) {
                console.log('웹소켓 에러:', error);
                document.getElementById('status').textContent = '에러 발생';
            };

            ws.onmessage = function(event) {
                var chatDiv = document.getElementById('chat');
                chatDiv.innerHTML += '<p>' + event.data + '</p>';
                chatDiv.scrollTop = chatDiv.scrollHeight;
            };
        }

        connect();

        function sendMessage() {
            if (ws.readyState === WebSocket.OPEN) {
                var messageInput = document.getElementById('message');
                var message = messageInput.value;
                ws.send(message);
                var chatDiv = document.getElementById('chat');
                chatDiv.innerHTML += '<p><strong>나:</strong> ' + message + '</p>  ';
                chatDiv.scrollTop = chatDiv.scrollHeight;
                messageInput.value = '';
            } else {
                alert('웹소켓이 연결되어 있지 않습니다.');
            }
        }

        document.getElementById('message').addEventListener('keypress', function(e) {
            if (e.key === 'Enter') {
                sendMessage();
            }
        });
    </script>
</body>
</html>

이 클라이언트 코드는 사용자 인터페이스를 제공하고, 웹소켓을 통해 서버와 통신해요. 메시지를 보내고 받을 수 있으며, 연결 상태도 표시합니다.

3. 애플리케이션 실행하기

자, 이제 우리의 채팅 애플리케이션을 실행해볼까요? 다음 단계를 따라해보세요:

  1. 터미널에서 서버를 실행하세요:
    php server.php
  2. 웹 브라우저에서 'index.html' 파일을 열어주세요.
  3. 여러 브라우저 창을 열어 여러 사용자를 시뮬레이션해보세요.
  4. 메시지를 입력하고 전송해보세요. 다른 창에서 메시지가 실시간으로 나타나는 것을 확인할 수 있을 거예요!

와! 우리가 만든 실시간 채팅 애플리케이션이 동작하고 있어요. 🎉

실시간 채팅 애플리케이션 구조 실시간 채팅 애플리케이션 구조 PHP 웹소켓 서버 클라이언트 1 클라이언트 2 WebSocket WebSocket

4. 개선 아이디어

이 기본적인 채팅 애플리케이션을 더 발전시킬 수 있는 방법들이 많이 있어요. 몇 가지 아이디어를 제안해볼게요:

  • 사용자 이름 추가: 각 메시지에 사용자 이름을 표시해보세요.
  • 메시지 시간 표시: 각 메시지가 언제 전송되었는지 시간을 표시해보세요.
  • 온라인 사용자 목록: 현재 채팅방에 접속해 있는 사용자 목록을 표시해보세요.
  • 개인 메시지 기능: 특정 사용자에게만 메시지를 보낼 수 있는 기능을 추가해보세요.
  • 이모지 지원: 채팅에 이모지를 사용할 수 있게 해보세요.
  • 파일 공유: 사용자들이 파일을 주고받을 수 있는 기능을 추가해보세요.

이런 기능들을 추가하면 더욱 풍부하고 실용적인 채팅 애플리케이션을 만들 수 있을 거예요.

5. 마무리

축하합니다! 🎊 여러분은 이제 PHP와 웹소켓을 사용하여 실시간 채팅 애플리케이션을 만드는 방법을 배웠어요. 이 지식을 바탕으로 더 복잡하고 흥미로운 실시간 애플리케이션을 만들 수 있을 거예요.

웹소켓의 강력함을 직접 경험해보셨나요? 실시간 통신이 얼마나 매끄럽고 효율적인지 느껴지셨을 거예요. 이 기술은 채팅뿐만 아니라 실시간 협업 도구, 게임, 라이브 스트리밍 등 다양한 분야에서 활용될 수 있어요.

계속해서 실험하고 새로운 기능을 추가해보세요. 코딩의 즐거움은 바로 여기에 있답니다! 여러분의 상상력이 이 애플리케이션의 한계를 정할 거예요. 화이팅! 💪😊

5. 결론 및 다음 단계 🚀

여러분, 정말 대단해요! PHP 웹소켓 프로그래밍의 기본을 마스터하셨어요. 👏 이제 여러분은 실시간 웹 애플리케이션의 세계로 첫 발을 내딛었습니다. 하지만 이건 시작에 불과해요. 더 많은 것들이 여러분을 기다리고 있답니다!

배운 내용 정리

지금까지 우리가 배운 내용을 간단히 정리해볼까요?

  • 웹소켓의 기본 개념과 장점
  • PHP에서 Ratchet 라이브러리를 사용한 웹소켓 서버 구현
  • JavaScript를 이용한 웹소켓 클라이언트 구현
  • 실시간 채팅 애플리케이션 제작

다음 단계

여기서 멈추지 마세요! 더 깊이 파고들 수 있는 주제들이 많이 있어요:

  1. 보안 강화: SSL/TLS를 이용한 암호화, 사용자 인증 등을 학습해보세요.
  2. 확장성: 대규모 사용자를 처리할 수 있는 아키텍처에 대해 알아보세요.
  3. 다양한 프로토콜: WAMP(WebSocket Application Messaging Protocol)같은 고급 프로토콜을 살펴보세요.
  4. 프레임워크 통합: Laravel, Symfony 등의 PHP 프레임워크와 웹소켓을 통합해보세요.
  5. 테스트와 디버깅: 웹소켓 애플리케이션의 효과적인 테스트와 디버깅 방법을 익혀보세요.

실전 프로젝트 아이디어

배운 내용을 활용할 수 있는 몇 가지 프로젝트 아이디어를 제안해볼게요:

  • 🎮 실시간 멀티플레이어 게임
  • 📊 실시간 데이터 시각화 대시보드
  • 🖥️ 협업 코드 에디터
  • 🛒 실시간 경매 시스템
  • 🎵 실시간 음악 스트리밍 서비스

마지막으로...

PHP 웹소켓 프로그래밍은 정말 흥미진진한 분야예요. 여러분이 이 기술을 마스터하면, 웹 개발의 새로운 차원을 경험하게 될 거예요. 실시간 기능은 현대 웹 애플리케이션의 핵심이에요. 여러분이 만드는 서비스에 생동감을 불어넣을 수 있죠.

계속해서 학습하고, 실험하고, 창조하세요. 코딩의 세계는 무한해요. 여러분의 상상력이 한계랍니다. 언제나 호기심을 갖고 새로운 것을 탐구하세요. 그리고 가장 중요한 건, 코딩을 즐기는 거예요! 😄

여러분의 멋진 프로젝트를 기대하고 있을게요. 화이팅! 🚀💻

관련 키워드

  • 웹소켓
  • PHP
  • Ratchet
  • 실시간 통신
  • JavaScript
  • 채팅 애플리케이션
  • 클라이언트-서버 모델
  • 양방향 통신
  • 이벤트 기반 프로그래밍
  • 비동기 통신

지식의 가치와 지적 재산권 보호

자유 결제 서비스

'지식인의 숲'은 "이용자 자유 결제 서비스"를 통해 지식의 가치를 공유합니다. 콘텐츠를 경험하신 후, 아래 안내에 따라 자유롭게 결제해 주세요.

자유 결제 : 국민은행 420401-04-167940 (주)재능넷
결제금액: 귀하가 받은 가치만큼 자유롭게 결정해 주세요
결제기간: 기한 없이 언제든 편한 시기에 결제 가능합니다

지적 재산권 보호 고지

  1. 저작권 및 소유권: 본 컨텐츠는 재능넷의 독점 AI 기술로 생성되었으며, 대한민국 저작권법 및 국제 저작권 협약에 의해 보호됩니다.
  2. AI 생성 컨텐츠의 법적 지위: 본 AI 생성 컨텐츠는 재능넷의 지적 창작물로 인정되며, 관련 법규에 따라 저작권 보호를 받습니다.
  3. 사용 제한: 재능넷의 명시적 서면 동의 없이 본 컨텐츠를 복제, 수정, 배포, 또는 상업적으로 활용하는 행위는 엄격히 금지됩니다.
  4. 데이터 수집 금지: 본 컨텐츠에 대한 무단 스크래핑, 크롤링, 및 자동화된 데이터 수집은 법적 제재의 대상이 됩니다.
  5. AI 학습 제한: 재능넷의 AI 생성 컨텐츠를 타 AI 모델 학습에 무단 사용하는 행위는 금지되며, 이는 지적 재산권 침해로 간주됩니다.

재능넷은 최신 AI 기술과 법률에 기반하여 자사의 지적 재산권을 적극적으로 보호하며,
무단 사용 및 침해 행위에 대해 법적 대응을 할 권리를 보유합니다.

© 2024 재능넷 | All rights reserved.

댓글 작성
0/2000

댓글 0개

해당 지식과 관련있는 인기재능

안녕하세요!!!고객님이 상상하시는 작업물 그 이상을 작업해 드리려 노력합니다.저는 작업물을 완성하여 고객님에게 보내드리는 것으로 거래 완료...

* 간단한 VBA 구현, 함수구현 10,000원 진행 됩니다!* 추구하는 엑셀 프로그램 *1. 프로그램 전체 엑셀 고유의 직관적입 입력! (키보드로 빠르게 ...

📚 생성된 총 지식 8,472 개

  • (주)재능넷 | 대표 : 강정수 | 경기도 수원시 영통구 봉영로 1612, 7층 710-09 호 (영통동) | 사업자등록번호 : 131-86-65451
    통신판매업신고 : 2018-수원영통-0307 | 직업정보제공사업 신고번호 : 중부청 2013-4호 | jaenung@jaenung.net

    (주)재능넷의 사전 서면 동의 없이 재능넷사이트의 일체의 정보, 콘텐츠 및 UI등을 상업적 목적으로 전재, 전송, 스크래핑 등 무단 사용할 수 없습니다.
    (주)재능넷은 통신판매중개자로서 재능넷의 거래당사자가 아니며, 판매자가 등록한 상품정보 및 거래에 대해 재능넷은 일체 책임을 지지 않습니다.

    Copyright © 2024 재능넷 Inc. All rights reserved.
ICT Innovation 대상
미래창조과학부장관 표창
서울특별시
공유기업 지정
한국데이터베이스진흥원
콘텐츠 제공서비스 품질인증
대한민국 중소 중견기업
혁신대상 중소기업청장상
인터넷에코어워드
일자리창출 분야 대상
웹어워드코리아
인터넷 서비스분야 우수상
정보통신산업진흥원장
정부유공 표창장
미래창조과학부
ICT지원사업 선정
기술혁신
벤처기업 확인
기술개발
기업부설 연구소 인정
마이크로소프트
BizsPark 스타트업
대한민국 미래경영대상
재능마켓 부문 수상
대한민국 중소기업인 대회
중소기업중앙회장 표창
국회 중소벤처기업위원회
위원장 표창