메뉴 건너뛰기

창작에 관련된 질문이나 간단한 팁, 예제를 올리는 곳

문제점:

클라이언트 <-> 서버 통신을 하면서 다음과 같이 메세지를 주고받기로 함

패킷종류|파라미터1|파라미터2

 

예)

MOTDREQ -> 서버에 MOTD를 요청 (파라미터 없음)

MOTD|공지사항입니다 -> MOTD는 "공지사항입니다" 임 (파라미터 1개)

MSG|김덕배|안녕하세요 -> 닉네임이 "김덕배" 인 사용자가 "안녕하세요" 라는 메세지를 보냄

 

그런데 공지사항이나 사용자 닉네임같은 경우 사용자가 마음대로 정할 수 있는 입력값이고

따라서 닉네임을 김덕|배 같은 걸로 지으면 MSG|김덕|배|안녕하세요 이런 메세지가 보내질거고

메세지 구조가 망쳐지고 잠재적인 오류가 발생할 수 있는 가능성이 있음

 

해결방법:

구분자로 사용되는 문자를 다 걸러내고 그런 솔루션을 생각했는데

그냥 사용자한테 입력받아서 오염의 껀덕지가 있는 문자들을 Base64 등으로 인코딩해서 보내고 받을 때 디코딩하면 끝임

MSG|김덕|배|안녕하세요

->

MSG|6rmA642VfOuwsA==|7JWI64WV7ZWY7IS47JqU

 

캐릭터이름도 DB에 저장할때 캐릭터명이 '); DROP TABLE USER; -- 이따구일 경우에 DB에 저장하는 쿼리를 날릴경우 문제가 생길 수 있는데

저걸 그대로 저장하지 말고 Jyk7IERST1AgVEFCTEUgVVNFUjsgLS0= 로 저장하고 주고받고, 사용자한테 보여줄때만 복호화하면 됨

(캐릭터 이름에 사용할 수 있는 언어나 문자셋을 제한하는 건 보안상의 이유 말고 미관상의 이유로도 필요하겠지만 대충 이런방법도 있다는거임)

조회 수 :
22
등록일 :
2023.07.17
14:51:10 (*.168.186.88)
엮인글 :
게시글 주소 :
https://hondoom.com/zbxe/index.php?mid=study&document_srl=821956

흑곰

2023.07.18
17:06:13
(*.109.221.10)

illegal character 방지와 별개로 "MSG|김덕배|안녕하세요" 에 대해 얘기해보자면 "김덕배"는 보낼 필요가 없습니다.

클라이언트가 접속할 때마다 해당 클라이언트 전용소켓이 만들어집니다.

그걸 서버에서 관리하고 있다면, 누가 보냈는지는 서버에서 알 수 있습니다.

 

보내는 사람의 이름, 보내는 사람의 ID 등을 메시지에 의존하는 것은 안전하지 않습니다.

물론 우리가 만드는 게임 수준에서 "김덕배"를 "홍길동"으로 변조해서 보낼 클라이언트는 없습니다.

 

그냥 소켓 통신에 대해서 팁을 드리고자 하는 것입니다.

만약 MAP1이라는 공간에서 x10,y10 위치에 존재하는 사용자가 오른쪽으로 한칸 이동한다면?

MOVE|RIGHT 만 보내면 됩니다.

 

그런데 MOVE|김덕배|MAP1|x10,y10|RIGHT 이렇게 보낼 건가요?

김덕배, MAP1, x10,y10 은 서버가 갖고 있어야 합니다.

클라이언트가 소켓으로 어떤 메시지를 보내건, 서버는 "응, 김덕배가 뭔가를 보냈네. 얘는 현재 MAP1에 있고, x좌표 10, y좌표 10에 있는 친구네."라고 알 수 있게 구조를 만들어야 합니다.

 

보안상으로도 안전하지만 보안상 안전하다 얘기를 하는 게 아니라,

코딩을 할때 훨씬 간결해지고 소켓 통신하는 내용도 훨씬 단순해져서

게임 개발 퍼포먼스가 올라가실 겁니다.

노루발

2023.07.19
06:57:58
(*.149.251.187)

감사합니다. 좀 더 고민해보겠습니다.

흑곰

2023.07.19
16:14:30
(*.255.218.134)

정답이 아니고 의견이니 참고만 하시면 될듯 합니다. 수고하십시오

List of Articles
번호 제목 글쓴이 조회 수sort 추천 수 날짜 최근 수정일
25 김프로 이미지 맵 만들기 노루발 393   2015-11-11 2015-11-11 08:05
https://docs.gimp.org/en/plug-in-imagemap.html  
24 PHP로 웹게임 만드는 영상 [1] 노루발 388   2021-06-25 2022-01-28 03:40
Simple PHP Strategy Game - YouTube  
23 Love2d 게임 중간에 광고 표시 [1] 노루발 377   2015-11-12 2015-11-17 00:16
http://love2d.org/forums/viewtopic.php?f=11&t=81224  
22 [Lua] Split 노루발 361   2013-09-17 2013-09-17 08:16
상황을 가정해보자. 웹 서버에 부탁해서 유희왕 덱의 리스트를 가져왔다. 원문은 대략 이렇다고 가정하자.   셰이프스내치x3 모린팬x3 트렌트x3 ...    보기엔 이렇지만 이걸 가져오면 아래와 같이 뜰 것이다. (웹 서버니까 HTML로 줌) 셰이프스내치x3<br>모...  
21 멘탈붕괴의 절정을 부르는 파일입출력 노루발 273   2013-09-17 2013-09-17 08:18
Love2D의 love.filesystem.load는 훼이크입니다. 파일을 로드하는 것 같지만 사실 lua 파일을 불러옴. love.filesystem.read도 그리 믿음직하지 못함. (고정 크기의 파일만 읽어옴) 우리가 믿을 수 있는 최후의 보루는 love.filesystem.lines 이었던 것입니다....  
20 love.update(dt) 에서 버벅이는 현상. 노루발 256   2013-09-17 2013-09-17 08:15
윈도우를 잡고 흔들거나 윈도우 사이로 잠시 전환하거나.. 등으로 원치 않는 렉이 발생할 시 dt의 값이 평소보다 크게 들어갑니다. (예를 들면, 평소에 0.25가 들어간다면 이번에는 3.1이 들어갑니다.) 이건 평소보다 더 많이 크기 때문에, dt를 가지고 타이...  
19 Love2d로 만든 로그라이크 예제 노루발 252   2020-11-30 2020-11-30 22:54
https://gitlab.com/Jalexander39/roguelikedev-does-the-complete-roguelike-tutorial 이걸 왜 여태 몰랐지...  
18 Love2d DPI 이슈 해결 [3] 노루발 97   2019-06-29 2019-07-01 06:34
이런 love 프로젝트가 있다고 하자. (conf.lua) function love.conf(t) t.window.width = 640 t.window.height = 360 end 창 크기를 640*480으로 설정한 뒤 실행하면 어떻게 보일까? 당연히 창 크기가 640*480 크기로 보여야겠지만 내 컴퓨터에서는 이렇게 보...  
17 Oracle cloud에 Nginx/MariaDB 설치하기 노루발 93   2020-12-06 2020-12-06 20:19
https://itreport.tistory.com/624  
16 Windows To Go와 R-Studio를 이용한 손실된 데이터 복구하기 노루발 89   2020-01-30 2020-01-30 19:52
하기의 복구 방법으로 모든 자료를 100% 복구할 수는 없으므로 자료의 손실 이전에 신뢰성 있고 주기적인 백업이 선행되어야 한다. 준비물: - 부팅 USB 혹은 외장 HDD/SSD - 복구한 자료를 저장할 외부 저장장치 (옵션) - R-Studio https://www.r-studio.com/ ...  
15 특정좌표를 기준으로 zoom in/zoom out하기 노루발 58   2020-11-11 2020-11-11 01:22
-- x,y - 줌인/줌아웃시 기준점 (좌표 이동이나 scale에 영향받지 않는 순수한 화면 좌표) -- scale - 현재 scale(1:그대로 0.5:1/2 사이즈 2:2배 사이즈) -- scaleinc - 얼마나 scale을 변화시킬것인가 (I usually use 0.1 or -0.1) -- camx - 카메라의 x좌표...  
14 Love2d 게임 안드로이드로 패키징하기 노루발 48   2021-01-11 2021-02-21 01:45
http://hondoom.com/zbxe/index.php?mid=study&document_srl=797993 버전이 바뀌면서 빌드 방법이 바뀌었기에 다시 정리한다. 1. Android studio 설치 https://developer.android.com/studio/index.html SDK 플랫폼 - Android 11.0 [API 30] SDK 버전 - An...  
13 Love2d 이미지 하얗게 그리기 노루발 42   2020-11-23 2020-11-23 04:11
아래와 같은 코드를 사용해 이미지에 색상을 적용할 수 있다. hamster = love.graphics.newImage("hamster.png") love.graphics.setColor(1, 0, 0) -- 빨간색으로 그리기 love.graphics.draw(hamster) love.graphics.setColor(1, 1, 1) 하지만 이미지를 하얗게...  
12 이쁜 눈나가 유니티 개발 알려주는 재생목록 노루발 37   2020-11-12 2020-11-12 05:59
https://www.youtube.com/watch?v=Ur2jN6_si6c&list=PLi-ukGVOag_1lNphWV5S-xxWDe3XANpyE https://www.youtube.com/watch?v=sJClf9S7AMA&list=PLi-ukGVOag_0HR09oTs966Wt81IYYXlFH 유니티를 배우고 있는 건 아닌데 만들어진 라이브러리를 다루는게 아...  
11 Lua 인수로 nil값이 들어왔을 경우 처리하기 노루발 36   2020-11-06 2020-11-06 20:29
or 연산자를 사용한다. 예제 코드: function moveplayer(direction) direction = direction or "nowhere" print("player moved to ".. direction) end moveplayer() --> "player moved to nowhere" moveplayer("north") -- "player moved to north" 이런 코드...  
10 루아 스타일 가이드 노루발 33   2020-11-19 2020-11-19 00:58
http://lua-users.org/wiki/LuaStyleGuide https://github.com/Olivine-Labs/lua-style-guide  
9 Lua 테이블 안에 함수 저장하기 노루발 28   2020-11-06 2020-11-06 21:07
테이블 안에 함수를 저장할 수 있다. function move(object, direction) print(object .. " moved to ".. direction) end scheduler = {} scheduler.queue = {} function scheduler.newentry(action, args) scheduler.queue[#scheduler.queue + 1] = {} schedu...  
8 Lua 클래스 만들고 활용하기 노루발 23   2020-11-06 2020-11-06 22:43
------------------------ stairs.lua ------------------------ Stairs = {} function Stairs:new(x, y, floor, direction, locked) local newStairs = {x = x, y = y, floor = floor, direction = direction, locked = locked} self.__index = self retur...  
» illegal character 방지 [3] 노루발 22   2023-07-17 2023-07-19 16:14
문제점: 클라이언트 <-> 서버 통신을 하면서 다음과 같이 메세지를 주고받기로 함 패킷종류|파라미터1|파라미터2 예) MOTDREQ -> 서버에 MOTD를 요청 (파라미터 없음) MOTD|공지사항입니다 -> MOTD는 "공지사항입니다" 임 (파라미터 1개) MSG|김덕배|안녕하세...  
6 Lua-love2d TCP 통신 [1] 노루발 21   2023-07-14 2023-07-22 16:19
서버: Lua 클라이언트: Love2d(Lua) 서버 구동에는 luasocket 라이브러리가 필요하며, luarocks로 설치할 수 있음. 별도 패키지 관리자가 있는 리눅스 시스템에서는 apt-get install lua-socket 등의 패키지 관리자 명령어로 설치 가능하며 Windows에서 구동시...