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

🌲 지식인의 숲 🌲

🌳 디자인
🌳 음악/영상
🌳 문서작성
🌳 번역/외국어
🌳 프로그램개발
🌳 마케팅/비즈니스
🌳 생활서비스
🌳 철학
🌳 과학
🌳 수학
🌳 역사
구매 만족 후기
추천 재능
























           
0, 마케팅위너
해당 지식과 관련있는 인기재능

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

* 프로그램에 대한 분석과 설계 구현.(OA,FA 등)* 업무 프로세스에 의한 구현.(C/C++, C#​) * 기존의 C/C++, C#, MFC, VB로 이루어진 프로그...

 >>>서비스 설명<<<저렴한 가격, 합리적인 가격, 최적의 공수로윈도우 프로그램을 제작해 드립니다고객이 원하는 프로그램...

#### 결재 먼저 하지 마시고 쪽지 먼저 주세요. ######## 결재 먼저 하지 마시고 쪽지 먼저 주세요. ####안녕하세요. C/C++/MFC/C#/Python 프...

PHP와 WebSocket을 이용한 실시간 알림 시스템

2025-01-09 07:00:26

재능넷
조회수 404 댓글수 0

PHP와 WebSocket으로 만드는 실시간 알림 시스템 🚀

콘텐츠 대표 이미지 - PHP와 WebSocket을 이용한 실시간 알림 시스템

 

 

안녕하세요, 여러분! 오늘은 정말 핫한 주제로 찾아왔어요. 바로 PHP와 WebSocket을 이용한 실시간 알림 시스템에 대해 알아볼 거예요. 이거 완전 트렌디하고 쓸모 있는 기술이라 여러분도 관심 있으실 것 같아요. ㅋㅋㅋ

요즘 시대에 실시간으로 정보를 주고받는 건 너무나 당연해졌잖아요? 카톡이나 인스타, 페북 같은 SNS에서도 실시간 알림이 뜨면 바로바로 확인하게 되죠. 그런데 이런 실시간 알림 시스템을 어떻게 만들 수 있을까요? 🤔

오늘 우리가 알아볼 PHP와 WebSocket을 이용한 방법은 정말 쩌는(?) 방법이에요. 이 기술을 익히면 여러분도 실시간 채팅 앱이나 실시간 알림 기능을 가진 웹사이트를 만들 수 있을 거예요. 심지어 재능넷 같은 재능 공유 플랫폼에서도 이런 기술이 유용하게 쓰일 수 있답니다!

자, 그럼 이제부터 PHP와 WebSocket의 세계로 함께 빠져볼까요? 준비되셨나요? 고고씽~ 🏃‍♂️💨

1. WebSocket이 뭐길래? 🤷‍♂️

먼저 WebSocket에 대해 알아볼게요. WebSocket이 뭔지 모르겠다고요? 걱정 마세요! 쉽게 설명해드릴게요.

WebSocket은 웹에서 실시간 양방향 통신을 가능하게 해주는 프로토콜이에요. 쉽게 말해서, 서버와 클라이언트(브라우저) 사이에 항상 열려있는 연결 통로라고 생각하면 돼요.

기존의 HTTP 통신은 어떻게 작동했냐면요:

  • 클라이언트가 요청을 보내면
  • 서버가 응답을 주고
  • 연결이 끊어지는 방식이었어요.

근데 이렇게 하면 실시간으로 데이터를 주고받기가 어렵잖아요? 그래서 나온 게 바로 WebSocket이에요!

WebSocket의 장점은 뭐냐면:

  • 연결이 한 번 established되면 계속 유지돼요.
  • 실시간으로 데이터를 주고받을 수 있어요.
  • 서버에서 클라이언트로 데이터를 push할 수 있어요.
  • HTTP보다 오버헤드가 적어서 빠르고 효율적이에요.

이해가 되시나요? WebSocket을 사용하면 실시간 채팅, 실시간 게임, 실시간 주식 정보 등을 구현할 수 있어요. 완전 쩔어요, 그쵸? ㅋㅋㅋ

🔍 알고 계셨나요?

WebSocket은 2011년에 표준화되었어요. 그 전에는 실시간 통신을 위해 Long Polling이나 Comet 같은 기술을 사용했답니다. WebSocket이 등장하면서 실시간 웹 애플리케이션 개발이 훨씬 쉬워졌죠!

자, 이제 WebSocket이 뭔지 대충 감이 오시죠? 그럼 이제 PHP와 어떻게 결합해서 사용하는지 알아볼까요? 🚀

2. PHP와 WebSocket의 찰떡궁합 💑

PHP는 웹 개발에서 정말 많이 사용되는 언어죠? 근데 PHP만으로는 실시간 기능을 구현하기가 좀 어려워요. 그래서 WebSocket과 함께 사용하면 완전 대박이에요! 👍

PHP와 WebSocket을 함께 사용하면 실시간 기능을 가진 강력한 웹 애플리케이션을 만들 수 있어요. 어떻게 하냐고요? 잘 들어보세요!

  1. PHP로 WebSocket 서버 구현하기: PHP에는 Ratchet이라는 라이브러리가 있어요. 이걸 사용하면 WebSocket 서버를 쉽게 만들 수 있답니다.
  2. 클라이언트 측 JavaScript로 WebSocket 연결하기: 브라우저에서 JavaScript를 사용해 WebSocket 연결을 만들어요.
  3. 실시간 데이터 교환: 서버와 클라이언트 사이에서 실시간으로 데이터를 주고받을 수 있어요.

이렇게 하면 PHP의 강력한 백엔드 기능과 WebSocket의 실시간 통신 기능을 동시에 활용할 수 있어요. 완전 꿀조합이죠? ㅋㅋㅋ

💡 팁: PHP와 WebSocket을 함께 사용할 때는 비동기 프로그래밍 개념을 이해하는 게 중요해요. PHP는 기본적으로 동기식이지만, WebSocket 서버를 운영할 때는 비동기 방식으로 동작해야 하거든요.

자, 이제 PHP와 WebSocket이 어떻게 함께 작동하는지 감이 오시나요? 그럼 이제 실제로 어떻게 구현하는지 자세히 알아볼까요? 준비되셨나요? 고고! 🚀

3. 실시간 알림 시스템 구현하기 🛠️

드디어 본격적으로 실시간 알림 시스템을 만들어볼 거예요! 어렵지 않을 테니 천천히 따라와 주세요. 😉

3.1. 환경 설정

먼저 필요한 도구들을 설치해야 해요:

  • PHP 7.2 이상
  • Composer (PHP 패키지 관리자)
  • Ratchet 라이브러리

Composer와 Ratchet을 설치하는 방법은 다음과 같아요:


# Composer 설치 (이미 설치되어 있다면 건너뛰세요)
curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer

# 프로젝트 디렉토리 생성 및 이동
mkdir realtime-notification
cd realtime-notification

# Composer 초기화
composer init

# Ratchet 설치
composer require cboden/ratchet

이렇게 하면 기본적인 환경 설정은 끝나요! 쉽죠? ㅎㅎ

3.2. WebSocket 서버 구현하기

이제 PHP로 WebSocket 서버를 만들어볼 거예요. 'server.php'라는 파일을 만들고 다음 코드를 입력해주세요:


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

require vendor/autoload.php;

class NotificationServer 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();
    }
}

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

$server->run();

우와, 코드가 좀 길죠? 하나씩 설명해드릴게요!

  • NotificationServer 클래스는 WebSocket 연결을 관리해요.
  • onOpen 메소드는 새로운 클라이언트가 연결될 때 호출돼요.
  • onMessage 메소드는 클라이언트로부터 메시지를 받았을 때 실행돼요. 여기서는 받은 메시지를 다른 모든 클라이언트에게 전송하고 있어요.
  • onCloseonError 메소드는 각각 연결이 끊어졌을 때와 에러가 발생했을 때 호출돼요.

마지막 부분에서는 서버를 8080 포트에서 실행하도록 설정하고 있어요.

🔔 주의사항: 실제 서비스에서는 보안을 위해 SSL/TLS를 사용해야 해요. 지금은 예제니까 그냥 넘어갈게요!

3.3. 클라이언트 측 구현하기

이제 클라이언트 측 코드를 작성해볼게요. 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>
        #notifications {
            width: 300px;
            height: 400px;
            border: 1px solid #ccc;
            overflow-y: scroll;
            padding: 10px;
        }
    </style>
</head>
<body>
    <h1>실시간 알림 시스템</h1>
    <div id="notifications"></div>
    <input type="text" id="message" placeholder="메시지 입력">
    <button onclick="sendMessage()">전송</button>

    <script>
        const socket = new WebSocket('ws://localhost:8080');
        const notifications = document.getElementById('notifications');
        const messageInput = document.getElementById('message');

        socket.onopen = function(e) {
            console.log("WebSocket 연결 성공!");
        };

        socket.onmessage = function(event) {
            const notification = document.createElement('p');
            notification.textContent = event.data;
            notifications.appendChild(notification);
            notifications.scrollTop = notifications.scrollHeight;
        };

        socket.onclose = function(event) {
            if (event.wasClean) {
                console.log(`WebSocket 연결 종료, 코드=${event.code} 이유=${event.reason}`);
            } else {
                console.log('WebSocket 연결 중단');
            }
        };

        socket.onerror = function(error) {
            console.log(`WebSocket 에러: ${error.message}`);
        };

        function sendMessage() {
            const message = messageInput.value;
            socket.send(message);
            messageInput.value = '';
        }
    </script>
</body>
</html>

이 코드는 간단한 채팅 인터페이스를 만들어요. 사용자가 메시지를 입력하면 WebSocket을 통해 서버로 전송되고, 서버는 이를 다른 모든 클라이언트에게 브로드캐스트해요.

3.4. 실행하기

자, 이제 모든 준비가 끝났어요! 실행해볼까요?

  1. 터미널에서 WebSocket 서버를 실행해주세요:
    php server.php
  2. 웹 브라우저에서 'index.html' 파일을 열어주세요.
  3. 여러 개의 브라우저 창을 열고 메시지를 주고받아보세요!

짜잔~ 🎉 이제 실시간으로 메시지를 주고받을 수 있는 간단한 알림 시스템이 완성됐어요! 어때요, 생각보다 쉽죠? ㅎㅎ

💡 응용 팁: 이 시스템을 확장해서 재능넷 같은 플랫폼에서 새로운 재능이 등록되면 실시간으로 알림을 보내는 기능을 만들 수 있어요. 멋지지 않나요?

자, 이제 기본적인 실시간 알림 시스템을 만들어봤어요. 하지만 이게 끝이 아니에요! 더 많은 기능을 추가하고 개선할 수 있답니다. 다음 섹션에서 어떻게 이 시스템을 발전시킬 수 있는지 알아볼까요? 고고! 🚀

4. 실시간 알림 시스템 개선하기 🔧

우리가 만든 기본적인 실시간 알림 시스템은 정말 멋져요! 하지만 실제 서비스에 적용하려면 좀 더 보완이 필요해요. 어떤 점들을 개선할 수 있을까요? 같이 알아볼까요?

4.1. 사용자 인증 추가하기

지금은 누구나 연결해서 메시지를 보낼 수 있잖아요? 이건 좀 위험할 수 있어요. 사용자 인증 기능을 추가해서 보안을 강화해볼까요?


// server.php 파일에 추가
class NotificationServer implements MessageComponentInterface {
    // ...기존 코드...

    public function onOpen(ConnectionInterface $conn) {
        // 연결 시 토큰 확인
        $query = $conn->httpRequest->getUri()->getQuery();
        parse_str($query, $params);
        
        if (!isset($params['token']) || !$this->validateToken($params['token'])) {
            $conn->close();
            return;
        }

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

    private function validateToken($token) {
        // 여기에 토큰 검증 로직 구현
        // 예: 데이터베이스에서 토큰 확인 또는 JWT 검증
        return true; // 임시로 항상 true 반환
    }
}

이렇게 하면 연결 시 토큰을 확인할 수 있어요. 클라이언트 측에서는 연결할 때 토큰을 함께 보내야 해요:


// index.html의 JavaScript 부분 수정
const token = 'your_auth_token_here'; // 실제로는 서버에서 발급받은 토큰을 사용해야 해요
const socket = new WebSocket(`ws://localhost:8080?token=${token}`);

4.2. 데이터베이스 연동하기

지금은 메시지를 그냥 메모리에 저장하고 있어요. 하지만 데이터베이스와 연동하면 메시지를 영구적으로 저장할 수 있어요. MySQL이나 MongoDB 같은 데이터베이스를 사용해볼까요?


// server.php에 데이터베이스 연결 코드 추가
class NotificationServer implements MessageComponentInterface {
    protected $clients;
    protected $db;

    public function __construct() {
        $this->clients = new \SplObjectStorage;
        $this->db = new mysqli("localhost", "username", "password", "database");
        
        if ($this->db->connect_error) {
            die("Connection failed: " . $this->db->connect_error);
        }
    }

    public function onMessage(ConnectionInterface $from, $msg) {
        // 메시지를 데이터베이스에 저장
        $stmt = $this->db->prepare("INSERT INTO messages (content) VALUES (?)");
        $stmt->bind_param("s", $msg);
        $stmt->execute();

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

    // ...기존 코드...
}

이렇게 하면 모든 메시지가 데이터베이스에 저장돼요. 나중에 메시지 히스토리를 볼 수도 있겠죠?

4.3. 실시간 알림 타입 추가하기

지금은 모든 메시지가 같은 형태로 전송되고 있어요. 하지만 알림의 종류를 구분하면 더 유용할 거예요. 예를 들어, 재능넷에서는 새 재능 등록, 메시지 수신, 거래 완료 등 다양한 알림이 있을 수 있잖아요?


// server.php 수정
public function onMessage(ConnectionInterface $from, $msg) {
    $data = json_decode($msg, true);
    
    if (!isset($data['type']) || !isset($data['content'])) {
        return;
    }

    switch ($data['type']) {
        case 'new_talent':
            $this->handleNewTalent($data['content']);
            break;
        case 'new_message':
            $this->handleNewMessage($data['content']);
            break;
        case 'transaction_complete':
            $this->handleTransactionComplete($data['content']);
            break;
    }

    // 다른 클라이언트에게 전송
    foreach ($this->clients as $client) {
        if ($from !== $client) {
            $client->send(json_encode($data));
        }
    }
}

private function handleNewTalent($content) {
    // 새 재능 등록 처리 로직
    echo "새 재능이 등록되었습니다: " . $content . "\n";
}

private function handleNewMessage($content) {
    // 새 메시지 처리 로직
    echo "새 메시지가 도착했습니다: " . $content . "\n";
}

private function handleTransactionComplete($content) {
    // 거래 완료 처리 로직
    echo "거래가 완료되었습니다: " . $content . "\n";
}

클라이언트 측에서는 이렇게 메시지를 보낼 수 있어요:


// index.html의 JavaScript 부분 수정
function sendMessage() {
    const message = messageInput.value;
    const data = {
        type: 'new_message',
        content: message
    };
    socket.send(JSON.stringify(data));
    messageInput.value = '';
}

4.4. 클라이언트 측 UI 개선하기

지금 UI가 좀 심플하죠? ㅋㅋㅋ 실제 서비스라면 사용자 경험(UX)을 개선해야 해요. 알림 타입별로 다른 스타일을 적용하고, 소리나 진동 효과를 추가해볼까요?


// index.html에 스타일 추가
<style>
    .notification {
        padding: 10px;
        margin-bottom: 10px;
        border-radius: 5px;
    }
    .new-talent {
        background-color: #e6f7ff;
        border-left: 5px solid #1890ff;
    }
    .new-message {
        background-color: #f6ffed;
        border-left: 5px solid #52c41a;
    }
    .transaction-complete {
        background-color: #fff7e6;
        border-left: 5px solid #faad14;
    }
</style>

// JavaScript 부분 수정
socket.onmessage = function(event) {
    const data = JSON.parse(event.data);
    const notification = document.createElement('div');
    notification.textContent = data.content;
    notification.classList.add('notification');
    
    switch (data.type) {
        case 'new_talent':
            notification.classList.add('new-talent');
            playNotificationSound('new-talent.mp3');
            break;
        case 'new_message':
            notification.classList.add('new-message');
            playNotificationSound('new-message.mp3');
            break;
        case 'transaction_complete':
            notification.classList.add('transaction-complete');
            playNotificationSound('transaction-complete.mp3');
            break;
    }
    
    notifications.appendChild(notification);
    notifications.scrollTop = notifications.scrollHeight;
};

function playNotificationSound(soundFile) {
    const audio = new Audio(soundFile);
    audio.play();
}

이렇게 하면 알림 타입별로 다른 스타일이 적용되고, 소리도 나오게 돼요. 완전 프로페셔널한 느낌 아니에요? ㅎㅎ

4.5. 확장성 고려하기

마지막으로, 시스템의 확장성을 고려해야 해요. 사용자가 많아지면 어떻게 할까요?

  • 로드 밸런싱: 여러 대의 WebSocket 서버를 운영하고, 로드 밸런서를 통해 트래픽을 분산시킬 수 있어요.
  • Redis pub/sub: 여러 서버 간 메시지 동기화를 위해 Redis의 pub/sub 기능을 활용할 수 있어요.
  • 마이크로서비스 아키텍처: 알림 시스템을 독립적인 마이크로서비스로 분리해서 관리할 수 있어요.

🚀 팁: 확장성을 고려할 때는 처음부터 완벽하게 설계하려고 하지 마세요. 시스템을 모듈화하고, 필요에 따라 점진적으로 개선해 나가는 것이 좋아요. 재능넷 같은 서비스도 처음에는 작게 시작해서 점점 확장해 나갔을 거예요!

자, 이렇게 우리의 실시간 알림 시스템을 한층 더 업그레이드했어요. 이제 정말 프로답게 변했죠? ㅎㅎ 하지만 여기서 끝이 아니에요. 계속해서 개선하고 발전시켜 나갈 수 있답니다!

5. 마무리: 실시간의 매력에 빠져보아요! 💖

우와~ 여러분, 정말 대단해요! 지금까지 PHP와 WebSocket을 이용해서 멋진 실시간 알림 시스템을 만들어봤어요. 어떠셨나요? 생각보다 재밌지 않았나요? ㅎㅎ

이런 실시간 기능은 요즘 웹 서비스에서 정말 중요해요. 사용자들은 즉각적인 반응과 실시간 정보를 원하거든요. 여러분이 만든 이 시스템을 응용하면 정말 다양한 곳에서 활용할 수 있어요!

  • 실시간 채팅 애플리케이션 🗨️
  • 실시간 주식 정보 서비스 📈
  • 실시간 게임 🎮
  • 협업 도구 (예: 구글 독스 같은) 📝
  • 그리고 물론, 재능넷 같은 플랫폼의 실시간 알림 시스템! 🔔

특히 재능넷 같은 서비스에서는 이런 실시간 기능이 정말 유용할 거예요. 새로운 재능이 등록됐을 때, 누군가 내 재능에 관심을 보였을 때, 거래가 성사됐을 때 등 다양한 상황에서 실시간 알림을 보낼 수 있겠죠?

💡 꿀팁: 실시간 기능을 추가할 때는 항상 사용자 경험을 최우선으로 생각하세요. 너무 많은 알림은 오히려 사용자를 피곤하게 할 수 있어요. 적절한 알림 설정과 관리 기능을 제공하는 것이 좋답니다!

여러분, 이제 실시간의 매력에 푹 빠지셨나요? ㅎㅎ 이 기술을 활용하면 정말 멋진 서비스를 만들 수 있을 거예요. 여러분의 상상력을 마음껏 펼쳐보세요! 🌈

그리고 잊지 마세요. 기술은 계속 발전하고 있어요. WebSocket 외에도 Server-Sent Events(SSE), Long Polling 등 다양한 실시간 통신 기술이 있답니다. 관심 있으시다면 이런 기술들도 한번 찾아보세요!

마지막으로, 코딩은 실습이 정말 중요해요. 이론만 알고 있다고 해서 실력이 늘지는 않아요. 꼭 직접 만들어보고, 실험해보고, 때로는 실패도 해보세요. 그 과정에서 정말 많은 것을 배울 수 있을 거예요.

자, 이제 여러분의 차례예요! 이 글을 읽고 영감을 받으셨다면, 당장 코딩을 시작해보는 건 어떨까요? 혹시 어려움이 있다면 언제든 물어보세요. 우리 함께 성장해 나가요! 화이팅! 💪😄

관련 키워드

  • PHP
  • WebSocket
  • 실시간 알림
  • Ratchet
  • 비동기 프로그래밍
  • 사용자 인증
  • 데이터베이스 연동
  • 실시간 채팅
  • 사용자 경험(UX)
  • 확장성

지적 재산권 보호

지적 재산권 보호 고지

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

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

© 2025 재능넷 | All rights reserved.

댓글 작성
0/2000

댓글 0개

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

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

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

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

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

📚 생성된 총 지식 12,899 개

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

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

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