PHP를 사용하여 TCP 소켓 서버를 만드는 방법
PHP를 사용하여 TCP 소켓 서버를 만드는 방법은 다음과 같습니다.
[code]
<?php
// 호스트와 포트 설정
$host = 'localhost';
$port = 8080;
// 소켓 생성
$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
// 소켓 바인딩
socket_bind($socket, $host, $port);
// 연결 대기
socket_listen($socket);
echo "서버가 시작되었습니다. 호스트: $host, 포트: $port\n";
while (true) {
// 클라이언트로부터 연결 수락
$clientSocket = socket_accept($socket);
// 클라이언트로부터 데이터 읽기
$data = socket_read($clientSocket, 1024);
// 클라이언트로부터 받은 데이터 출력
echo "받은 데이터: $data\n";
// 클라이언트에 데이터 보내기
$response = "서버에서 클라이언트로 보낸 응답입니다.";
socket_write($clientSocket, $response, strlen($response));
// 소켓 닫기
socket_close($clientSocket);
}
// 소켓 닫기
socket_close($socket);
?>
[/code]
이 코드는 localhost의 8080번 포트에서 소켓 서버를 실행합니다. 클라이언트로부터 연결을 수락하고 데이터를 읽은 후, 받은 데이터를 출력하고 응답을 보내는 간단한 예제입니다. 이 예제는 루프를 통해 클라이언트의 연결을 계속해서 수락할 수 있도록 하였습니다.
게시판 목록
개발자팁
질문은 QA에서 해주시기 바랍니다.
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|---|
| 5246 | node.js |
swallow
|
2년 전 | 1105 | |
| 5245 | PHP |
swallow
|
2년 전 | 2527 | |
| 5244 | PHP |
swallow
|
2년 전 | 1286 | |
| 5243 | JavaScript |
swallow
|
2년 전 | 685 | |
| 5242 | node.js |
swallow
|
2년 전 | 666 | |
| 5241 | node.js |
swallow
|
2년 전 | 778 | |
| 5240 | MySQL |
swallow
|
2년 전 | 808 | |
| 5239 | MySQL | 2년 전 | 781 | ||
| 5238 | JavaScript | 2년 전 | 983 | ||
| 5237 | 웹서버 |
swallow
|
2년 전 | 3989 | |
| 5236 | PHP |
swallow
|
2년 전 | 899 | |
| 5235 | PHP |
swallow
|
2년 전 | 1378 | |
| 5234 | 기타 | 2년 전 | 759 | ||
| 5233 | jQuery |
swallow
|
2년 전 | 2036 | |
| 5232 | 2년 전 | 618 | |||
| 5231 | 2년 전 | 1173 | |||
| 5230 | 2년 전 | 1076 | |||
| 5229 | PHP |
swallow
|
2년 전 | 1023 | |
| 5228 | MySQL | 2년 전 | 726 | ||
| 5227 | PHP |
swallow
|
2년 전 | 836 | |
| 5226 | PHP |
swallow
|
2년 전 | 1811 | |
| 5225 | PHP | 2년 전 | 576 | ||
| 5224 | node.js |
swallow
|
2년 전 | 4082 | |
| 5223 | PHP |
swallow
|
2년 전 | 1317 | |
| 5222 | 기타 |
techstar
|
2년 전 | 562 | |
| 5221 | PHP | 2년 전 | 652 | ||
| 5220 |
swallow
|
2년 전 | 904 | ||
| 5219 | 2년 전 | 881 | |||
| 5218 | 2년 전 | 523 | |||
| 5217 | 2년 전 | 1000 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기