모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 게시물ID : programmer_22740
    작성자 : 봄아
    추천 : 9
    조회수 : 1457
    IP : 125.128.***.86
    댓글 : 3개
    등록시간 : 2018/12/14 17:56:55
    http://todayhumor.com/?programmer_22740 모바일
    나쁜 인증 시도 방어하기! 3편
    옵션
    • 창작글
    • 본인삭제금지
    <div>주말 출근해서 다시 DB를 살펴 봤다. <br></div> <div>아니~ 이 녀석들이~! <br></div> <div>뚫었다. 인증 시도 건수가 예전만큼 많아 진 것은 아니지만 분명 Bot이 돌면서 인증 시도를 계속 하고 있었다. DB 기록 봐서는 인증 건당 재 시도하는데 수분이 소요 되는 것으로 보였다.</div> <div><br></div> <div>터미널 접속해 로그를 확인해 봤다. 인증 시도와 Captcha 정보를 얻어 오는 것 까지는 정상적인 루틴을 보여 준다. 그 다음 Captcha의 내용 분석 하는데 시간이 걸리는 것 같다. 일치 여부 체크 하는 로그를 보면 얼토 당토 않은 값을 전달하는 시도가 많이 보인다. 아마도 그림 문자 해석기를 이용해 이 값을 뚫어 버리는 짓을 하는 것 같았다. 구글링 해 보니 음성 출력 소스를 클라우드로 넘겨 보안 문자를 뚫는 기술도 있다고 하는데 현 서버의 로그에선 음성 요청 하는 로그는 보이지 않아 이 방법은 아닌 것으로 판단 됐다. <br></div> <div>그렇다면 이 Captcha의 난이도를 높이는 방법이 가장 빠르게 할 수 있는 방안이라 생각했다. 우선 배경이 WHITE Flat 이였는데 디자인 팀에 요청해 알록달록 이쁜 것으로 요청 했다. 글자 폰트 및 컬러도 몇 가지 더 추가 했다.</div>그리고 한 화면에서 Captcha 새로 생성하는 것과 문자 검증하는 횟수도 3회로 제한 했다. 이 정도면 3회 이상 시도할 경우 다시 창을 닫고 시도해야 하는 번거로움이 생길 것이다.<br><br>허나 이것만으로는 좀 불안 했다. 더 나은 방법은 없을까?<br>일반적인 사용자라면 정보를 입력 할 때 Input Layer에선 포커싱 이벤트와 Key 관련 이벤트가 발생 될 것이라 판단하고 그 값이 Bot일 경우 다른 형태로 존재 할 것이라 생각했다. 그래서 각 개인정보 입력 Input의 이벤트 함수에 발생되는 이벤트 시간 값을 마킹 하고 그 값들을 인증 요청 시 함께 전달 하는 것으로 방향을 잡았다.<br>Front 와 Back단에서 각 작업을 하고 개발 서버에서 테스트 진행했다.<br><br>“모두들 한번씩 인증 시도 해줘~”<br><br>다닥. 다닥. 키보드와 마우스의 소리가 귀엽게 났다. 로그에선 일정 시간 차가 적절하게 올라 왔다. <br><br>“자 이번엔 더 빠르게~ 최대한 빨리 인증 시도 해줘. 빠르게 하는거 실패 하면 창 닫고 다시 시도해 줘~ 자~ 고고고”<br><br>파파파파파팍팍팍팍. 키보드와 마우스의 부숴지는 소리가 요란스럽게 났다. 로그를 보니 아까 패턴과는 조금 더 시간차가 줄어든 값이 올라 왔다. 실제 사용자의 경우 더 빠른 사람들도 있을 테니 테스트에서 얻은 값 보다 0.5~1S 정도 더 줄여 Bot 여부 검증을 통과 하도록 작업을 했다. 이보다 더 빠르면 인간이 아닌 것이다. <br>만일 Bot일 경우 새로 추가된 사용 패턴에 대응 못했을 수도 있어서 새로 추가된 변수는 필수가 아닌 것으로 처리 했다. 만일 이 변수가 빈 값으로 전달 될 경우 100% Bot이라 확신 할 수 있는 근거가 되기 때문이다. 이 IP도 수집 할 수 있도록 DB 작업도 추가 됐다.<br>만일 저 Bot 여부를 통과 하지 못할 경우 고객 센터로 문의 달라는 에러 메시지도 추가 했다. 실제 사용자들한텐 어떤 결과가 나올 지 몰라서… ㅎㄷㄷ. 서비스 올리기 전 CS팀장을 찾아갔다.<br><br>“팀장님~ 저 이번에 새로 올릴 껀데 에러 메시지에 고객센터 문의 하라는 글이 추가 될 꺼에요. 혹시라도 인증 관련 CS 접수 되면 저한테 바로 콜 해 주세요~”<br>“네. 꼭 연락 드릴께요.”<br><br>CS팀장이나 나나 굳은 결의에 찬 표정을 지었다. 이번엔 잘 되리라! 믿으며.<br><div>서비스 막상 올리니까 겁나 빠른 사용자들이 나왔다. 헐… 이 시간에 어떻게 입력 하지? Bot의 시간보단 느린 값이라 분명 사람이 입력한 값이긴 했지만 너무 빠른 값이 였다. 뭔가 다른 버그가 있나? <br></div> <div>퍼블리셔와 얘기 해 보고 다양하게 테스트를 진행 해 봤다. 입력 안하고 재빨리 Input란을 터치 터치 하며 옮기면 그 주기가 엄청 짧아 Bot으로 인식 할 수 있는 버그가 재현됐다. 퍼블리셔는 난감해 하고~ 나도 헐~ 당황해 했다. 게다가 FireFox의 경우 이벤트 처리가 달라 Script 함수 작업도 추가 됐다. </div><br>다시 서비스 반영 후 로그와 DB는 꽤나 안정화 된 수치를 보여 줬다. 물론 Bot이 계속 시도를 하는 것으로 보였다. 하지만 통과 비율은 현저히 줄어 들었다. 게다가 결정적으로 새로 추가된 변수에 대한 값이 없는 상태로 인증 시도 로그가 올라 오고 있었다. 바로 이것들, 확실한 Bot이다. 이 나쁜 요청 값을 가진 IP들은 차곡 차곡 DB에 쌓이고 있었다. 그리고 그들의 결과에는 거짓 값을 리턴해 줘 마치 정상인양 리턴을 주고 있었다. 디테일 하게 딜레이도 3~5초 정도 줬다. <br><br>DB는 완전 실 사용자 데이터로 채워 졌다. 아주 만족스럽도다.<br>정상이다. <br>잘 끝났군. 퇴근하자.<br>(하지만 어떻게 완전히 못 오게 막지?)<br><br><div style="border:3px dashed #0000FF;display:none;"></div> <div style="display:none;width:0px;height:0px;background:none repeat scroll 0% 0%;"></div>

    이 게시물을 추천한 분들의 목록입니다.
    [1] 2018/12/14 19:36:17  110.70.***.132  엉덩탱탱  683937
    [2] 2018/12/14 20:10:11  147.46.***.42  CandyJelly  566431
    [3] 2018/12/14 23:11:26  59.187.***.112  정통당근주스  210848
    [4] 2018/12/15 14:21:36  124.56.***.85  doraq  92937
    [5] 2018/12/16 21:03:23  222.234.***.42  뻐그  555466
    [6] 2018/12/17 16:22:19  211.36.***.68  아일턴  507576
    [7] 2018/12/17 20:33:05  27.122.***.71  re0201  136641
    [8] 2018/12/18 10:12:21  211.118.***.239  야간산책  406206
    [9] 2018/12/19 17:21:07  58.233.***.146  프로그래머  53975
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    22752
    보안취약점을 체크하는 프로그램이 프리웨어로도 있나요? [3] 본인삭제금지 jar 18/12/24 20:07 912 0
    22749
    엑셀로 이벤트 당첨자 만들기 다음과 같이 가능할까요? [2] 미친색기 18/12/23 20:15 795 0
    22748
    const 한정자는 좋은 코딩 습관의 기초 [1] ★☆ 18/12/22 00:30 1386 2
    22747
    나의 코딩 룰. [7] 봄아 18/12/21 12:00 1644 2
    22746
    [gcc] 의미없어 보이지만 의미심장한 (X)+0 그리고 함수 오버로딩 [6] ★☆ 18/12/21 07:40 1338 2
    22745
    c언어 동적 char 할당의 메모리.... [3] 정답이없음 18/12/20 11:01 964 0
    22744
    [java] NIO Socket 예제 창작글본인삭제금지 봄아 18/12/18 15:07 872 0
    22743
    나쁜 인증 시도 방어하기! 4편(final) [5] 창작글본인삭제금지 봄아 18/12/17 10:28 1484 7
    22742
    매틀랩으로 컴파일된 파일 실행시.. 대기시간.. [1] 베오베금지본인삭제금지외부펌금지 샤브레 18/12/16 19:58 760 0
    나쁜 인증 시도 방어하기! 3편 [3] 창작글본인삭제금지 봄아 18/12/14 17:56 1458 9
    22739
    c언어 증감연산자 질문 [18] 창작글베스트금지 정답이없음 18/12/14 12:35 1035 0
    22737
    나쁜 인증 시도 방어하기! 2편 창작글본인삭제금지 봄아 18/12/13 11:08 1409 11
    22736
    [android]navigation 레이아웃의 타이틀바 제거 가능한가요? noway130 18/12/13 10:03 589 0
    22735
    카카오봇 써보신분 계신가요?! 윰블리95 18/12/13 02:59 797 0
    22734
    나쁜 인증 시도 방어하기! 1편 [2] 창작글본인삭제금지 봄아 18/12/12 16:14 1822 8
    22733
    c 언어 str 쪽 한번만 봐주실 수 있으신가요? [6] 본인삭제금지 강무 18/12/11 17:15 922 0
    22731
    본삭금 / C#에서 이미지 바이트배열에 대해 궁금한게있습니다. [1] 본인삭제금지 이비서 18/12/11 10:25 763 0
    22730
    질문/본삭금/ 개인 어플 개발 후 서버 이용 비용 관련 [10] 본인삭제금지 돌고래03 18/12/09 21:26 1000 0
    22729
    개발자 입장에서 라이센스 관리(?)에 관한 질문 [2] 창작글본인삭제금지외부펌금지 샤브레 18/12/09 20:25 906 0
    22726
    c언어 구조체 포인터 질문입니다 ㅠㅠ 도와주세요 ㅠㅠ [4] 본인삭제금지 슴여슷 18/12/07 19:05 1653 0
    22725
    c에서 gets()가 자꾸 스킵이 돼요..ㅜㅠ [1] 본인삭제금지 birthdream 18/12/07 16:26 1075 0
    22724
    홈페이지 슬라이더 CSS랑 js 코드 좀 여쭤봐요! [3] 베스트금지베오베금지본인삭제금지외부펌금지 꽃징어꽃꽃 18/12/07 16:00 690 0
    22723
    c언어 strstr관련 질문 하나만 드려도 될까요...? [2] 본인삭제금지 birthdream 18/12/07 11:05 847 0
    22721
    LLVM컴파일러를 배우고싶은데요 외부펌금지 망고뫄이쪙 18/12/07 10:09 625 0
    22720
    솔직한 답변 부탁드립니다 [6] 나눔거지 18/12/06 22:57 857 0
    22717
    개발자 연봉 [7] 방탄승 18/12/06 10:46 1930 0
    22715
    Json 에서 json schema 로 변경하는 java 프로젝트가있을까 [2] 본인삭제금지 under1 18/12/04 20:27 811 0
    22714
    Vue.js로 todo 어플리케이션 만들기 강의를 만들었습니다. 창작글 따라라따라 18/12/04 09:36 933 1
    22713
    HTML에서 상세 데이터 출력 후 저장 구현 부분 질문입니다. [2] 본인삭제금지외부펌금지 TeamDKs 18/12/04 07:01 707 0
    22711
    Atmega128 4x4키패드 한번만 봐주세요.. 기마온 18/12/03 01:48 1172 0
    [◀이전10개] [11] [12] [13] [14] [15] [16] [17] [18] [19] [20] [다음10개▶]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈