금융, 정부 웹사이트등에 널리 쓰이는 보안 프로그램인 가상키보드(vKeypad)를 우회합니다
미리 각 키별 이미지를 저장해두고, 저장한 이미지와의 유사도를 분석하는 방식으로 가상키보드를 우회합니다.
키 배열이 무작위로 바뀌는 경우에도 인식이 가능합니다
vkeypad-studio는 각 키별 이미지와, 키보드상 이미지 좌표 추출을 도와주는 도구입니다.
편안한 레이아웃 추출을 위해 figma에서 그린 각 레이어의 위치를 분석해 이미지와, 좌표값을 저장해줍니다.
- 가상키보드 이미지를 준비합니다
- Figma에서 가상 키보드 이미지를 업로드 합니다
- Figma에서 사각형으로 가상 키보드 각각의 키를 덮어줍니다
- Figma에서 svg 파일로 Export 합니다
- 터미널에서
vkeypad-studio [이미지 파일] [svg 파일]을 입력합니다 - 새로 뜬 창에서, 이미지에 해당되는 키보드 키를 눌러줍니다
- assets 폴더 속 사진들과, data.json을 보관 합니다.
이 라이브러리에선 aseets속 사진들과, data.json를 이용해 이미지 비교도를 분석하여 어떤 키인지 확인합니다.
pip install vkeypad-bypass import cv2 from vkeypadbypass import get_keymap img = cv2.imread("test_assets/vKeypad.png") keymap = get_keymap( img=img, asset_path="test_assets/", data_path="test_assets/data.json", threshold=100 ) print(keymap)- img: cv2로 읽은 데이터
- asset_path: assets 폴더 경로
- data_path: data.json의 경로
- threshold: 이미지 일치도 가중치
결과값: 바운딩 박스의 좌표와 키코드를 순서대로 출력합니다
[ {"box": [0, 0, 55, 55], "key_code": 49}, {"box": [58, 0, 113, 55], "key_code": 50}, {"box": [116, 0, 171, 55], "key_code": 51}, {"box": [0, 58, 55, 113], "key_code": 52}, {"box": [58, 58, 113, 113], "key_code": 53}, {"box": [116, 58, 171, 113], "key_code": 54}, {"box": [0, 116, 55, 171], "key_code": 55}, {"box": [58, 116, 113, 171], "key_code": 56}, {"box": [116, 116, 171, 171], "key_code": 57}, {"box": [58, 174, 113, 229], "key_code": 48}, ]Selenium에서 좌표를 이용한 Click 혹은, tag를 이용한 Click이 가능합니다.
이 라이브러리는simple_bank_korea에서 영감을 받아 제작하였습니다

