[정보] 소스코드 정적 분석 도구 추천
·
🤖정보보안/💙블루팀
정적 분석 도구는 코드를 분석하여 취약점을 찾는데 유용한 도구입니다. 다음은 몇 가지 인기 있는 정적 분석 도구입니다. SonarQube: 오픈 소스로 제공되는 자동화된 코드 검사 도구입니다. 다양한 언어 및 프레임워크를 지원하며, 보안, 코드 복잡도, 코드 커버리지, 코드 스타일 등의 다양한 지표를 검사합니다. FindBugs: 오픈 소스로 제공되는 Java 언어용 정적 분석 도구입니다. 코드 스타일, 오류, 성능 문제 등을 검사하며, IDE와 연동되어 사용할 수 있습니다. Checkmarx: 상용 제품으로, 다양한 언어 및 프레임워크를 지원하는 정적 분석 도구입니다. 소스 코드 내의 취약점을 검사하고 보고서를 생성합니다. Veracode: 상용 제품으로, 다양한 언어 및 프레임워크를 지원하는 클라우드..
[정보] 리버싱 기초 개념
·
카테고리 없음
리버싱을 하기 위해서는 다양한 도구들이 있습니다. 이 중에서 가장 일반적으로 사용되는 도구들은 다음과 같습니다: 디버거 (Debugger): 디버거는 프로그램의 실행 중에 코드의 동작을 조사하고 오류를 해결하기 위해 사용됩니다. 대부분의 프로그래밍 언어와 플랫폼은 내장된 디버거를 제공하며, 제3의 디버거 도구도 많이 있습니다. 디컴파일러 (Decompiler): 디컴파일러는 컴파일된 프로그램을 역으로 변환하여 소스 코드를 생성합니다. 이를 통해 리버싱을 수행할 수 있습니다. 언패커 (Unpacker): 언패커는 패킹된 프로그램을 해제하고 원래의 실행 파일을 추출합니다. 패킹된 프로그램은 프로그램 코드를 암호화하거나, 복호화하기 위한 인증 절차를 수행하기 때문에 리버싱을 어렵게 만들기 때문에 언패킹을 먼저..
[정보] JavaScript에서 HTTP 요청을 만드는 방법
·
🐞프로그래밍
JavaScript에서 HTTP 요청을 만드는 방법으로는 내장된 fetch() 함수나 XMLHttpRequest (XHR) 객체를 사용할 수 있습니다. 다음은 fetch()을 사용하는 예시입니다: fetch('https://example.com/data') .then(response => response.json()) .then(data => console.log(data)) .catch(error => console.error(error)); 이 예시에서는 https://example.com/data로 GET 요청을 보내고 있습니다. fetch() 함수는 요청에 대한 서버의 응답을 나타내는 Response 객체를 반환하는 Promise를 반환합니다. 그런 다음, Response 객체에서 json() 메..
[정보] 젠킨스 활용 방법
·
🐞프로그래밍
CI/CD(Continuous Integration/Continuous Deployment)는 소프트웨어를 개발하고 배포하는 데 있어서 지속적인 통합 및 배포를 수행하는 방법론입니다. 이를 위해서 젠킨스(Jenkins)는 많이 활용되는 오픈 소스 도구 중 하나입니다. 젠킨스를 활용하여 CI/CD 파이프라인을 구성하는 방법은 다음과 같습니다. 젠킨스 설치 및 설정: 젠킨스 웹 사이트에서 다운로드 받아 설치합니다. 설치 후, 젠킨스 서버를 시작하고, 관리자 계정을 생성합니다. 소스 코드 저장소와 연결: CI/CD를 위해서는 소스 코드를 저장하고 있는 저장소(Git, SVN 등)와 연결해야 합니다. 이를 위해, 젠킨스에서 "저장소 관리" 메뉴를 이용하여 소스 코드 저장소와의 연결을 설정합니다. 빌드 환경 설정..
[정보] 사이트 분석 방법
·
카테고리 없음
사이트 분석이란, 웹사이트의 구조, 콘텐츠, 링크 구조, 검색 엔진 최적화 상태 등을 분석하는 것을 의미합니다. 사이트 분석을 수행하는 방법에는 여러 가지가 있습니다. 일부는 수동으로 진행하며, 다른 일부는 자동화 도구를 사용하여 수행할 수 있습니다. 수동으로 사이트를 분석하는 방법은 웹사이트에 직접 접속하여 분석하거나, 웹사이트의 소스 코드를 직접 분석하는 것입니다. 이를 통해 웹사이트의 사용자 경험, 성능, 보안, 검색 엔진 최적화 상태 등을 평가할 수 있습니다. 반면에 자동화 도구를 사용하면 크롤링, 스크래핑, SEO 분석 등을 자동으로 수행할 수 있습니다. 대표적인 사이트 분석 도구로는 Google Analytics, SEMrush, Ahrefs, Moz 등이 있습니다. 이러한 도구를 사용하여 웹..
[정보] 파이썬 파일 인코딩 변환 함수
·
🐞프로그래밍
파이썬에서 파일 인코딩을 변환하기 위해 codecs 모듈을 사용할 수 있습니다. 아래는 codecs 모듈을 사용하여 파일의 인코딩을 변환하는 예시 코드입니다. import codecs def convert_encoding(file_path, from_encoding, to_encoding): with codecs.open(file_path, 'r', from_encoding) as file: content = file.read() with codecs.open(file_path, 'w', to_encoding) as file: file.write(content) 위의 convert_encoding 함수는 세 개의 인자를 받습니다: file_path: 인코딩을 변환하고자 하는 파일 경로입니다. from_e..
[정보] 프로그래밍에서 가장 많이 범하는 실수 TOP10
·
카테고리 없음
프로그래밍에서 가장 많이 하는 실수 중 일부는 다음과 같습니다. 문법 오류: 프로그래밍 언어의 구문 규칙을 준수하지 않아 발생하는 오류로, 대부분 오타, 괄호 누락 등이 있습니다. 변수 사용: 변수를 선언하지 않거나, 잘못된 데이터 타입을 사용하는 경우가 많습니다. 이로 인해 런타임 오류가 발생할 수 있습니다. 메모리 관리: 동적 메모리 할당과 해제가 제대로 이루어지지 않으면 메모리 누수가 발생할 수 있습니다. 배열 인덱스 오류: 배열을 사용할 때, 인덱스가 배열 범위를 벗어나거나 음수인 경우가 많습니다. 재귀 함수 오류: 재귀 함수를 사용할 때, 종료 조건이 충족되지 않거나 잘못된 매개변수를 사용하는 경우가 있습니다. 로직 오류: 로직 오류는 프로그램이 원래 의도와 다르게 동작할 때 발생합니다. 이는 ..
[정보] ChatGPT와 ChatGTP Plus의 성능 차이
·
카테고리 없음
ChatGPT와 ChatGPT Plus의 성능 차이를 비유하면, ChatGPT는 소형차나 경차 수준의 성능이라고 할 수 있습니다. 반면 ChatGPT Plus는 중형차나 대형차 수준의 성능을 가지고 있습니다. 즉, ChatGPT Plus는 대량의 데이터를 다루거나 복잡한 작업을 수행하는 데 더 적합하며, 높은 정확도와 자연스러운 답변을 제공할 수 있습니다.
[정보] XDR과 EDR의 차이
·
🤖정보보안/💙블루팀
XDR(Extended Detection and Response)와 EDR(Endpoint Detection and Response)는 모두 보안분야에서 사용되는 용어이며, 주로 공격 탐지 및 대응에 사용됩니다. EDR은 엔드포인트에서 발생하는 보안 이벤트를 탐지하고 분석하여 대응하는 솔루션입니다. 보통 안티바이러스, 침입방지시스템(IPS), 로그분석 등과 같은 다른 보안 솔루션과 통합하여 사용됩니다. 반면에 XDR은 EDR과 유사하지만, 더 확장된 범위의 보안 이벤트를 탐지하고 대응하는 솔루션입니다. XDR은 여러 종류의 보안 이벤트 데이터를 수집하고 분석하여, 공격의 범위와 영향력을 파악하고, 보안 이벤트들 간의 상관관계를 분석하여 통찰력 있는 대응 전략을 수립합니다. 따라서 XDR은 EDR을 포함하..
[정보] 웹 방화벽 ip 차단 시 주의 사항
·
🤖정보보안/💙블루팀
IP 차단은 웹 방화벽에서 매우 일반적인 방법 중 하나입니다. 그러나 소스 IP를 기반으로 불필요하게 차단되는 경우가 있을 수 있으므로 몇 가지 고려해야 할 사항이 있습니다. 이러한 고려 사항은 다음과 같습니다. 프록시 서버에서 오는 요청일 수 있으므로, 실제 IP와 다른 IP를 보낼 수 있습니다. 따라서 다른 보안 방법을 사용하여 정확한 IP를 확인할 필요가 있습니다. IP 차단으로 인해 다른 사용자들도 차단될 수 있으므로, 특정 IP 주소가 악성 행동을 하는 경우에만 차단하는 것이 좋습니다. 공격자가 IP 주소를 변경하는 경우가 많으므로, 다른 보안 방법을 사용하여 공격을 방지하는 것이 좋습니다. IP 주소가 변동적이거나 동적으로 할당되는 경우, 매우 일시적인 차단으로 인해 불만을 불러 일으킬 수 있..