개인 재정 C ++에서 코드 삽입을 피하는 방법 - 더미

C ++에서 코드 삽입을 피하는 방법 - 더미

비디오: Computational Thinking - Computer Science for Business Leaders 2016 2024

비디오: Computational Thinking - Computer Science for Business Leaders 2016 2024
Anonim

코드 삽입 방지의 첫 번째 규칙 C ++ 프로그램으로의 변환은 결코 적 없다. 는 사용자 입력이 범용 언어 인터프리터에 의해 처리되도록 허용한다. SQL 인젝션의 일반적인 오류는 프로그램이 사용자 입력을 항상 받아 들일 수있는 것처럼 받아들이고 SQL 쿼리에 삽입하여 처리를 위해 데이터베이스 엔진으로 전달된다는 것입니다. 예를 들어, 날짜에 대한 사용자 입력을 요구하는 프로그램이 해킹 당할 수 있습니다. 가장 안전하고 사용자 친화적 인 접근 방법은 사용자에게 시작 날짜와 종료 날짜를 선택할 수있는 캘린더 그래픽을 제공하는 것입니다. 그런 다음 프로그램은 사용자가 클릭 한 내용을 기반으로 날짜를 만듭니다.

이것이 가능하지 않은 경우, 프로그램은 신중하게 입력을 검사하여 입력이 올바른 날짜 형식인지 확인합니다 (이 경우

yyyy / mm / dd < - 즉, 네 자리 숫자 뒤에 슬래시와 두 자리 숫자, 슬래시 및 마지막으로 두 자리 숫자가옵니다. 다른 어떤 것도 수용 가능한 입력으로 간주되어서는 안됩니다. 때로는 형식에 대해 구체적 일 수는 없습니다. 사용자가 유연한 텍스트를 입력하도록 허용해야한다면 특수 문자를 피할 수 있습니다. 예를 들어, 작은 따옴표 나 큰 따옴표를 사용하지 않고도 SQL 코드 삽입을 수행하는 것은 거의 불가능합니다.

작음 기호 ()를 사용하지 않고 HTML 태그를 삽입 할 수 없습니다. 또는 ASCII 텍스트 이외의 다른 것을 허용하지 않을 수도 있습니다:

// 일부 문자열을 검사하여 직선인지 확인하십시오. size_type off = s. find_first_not_of ("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234567890_"); 이 코드는 문자열

s

에서 A부터 Z까지의 문자 중 하나가 아닌 문자를 검색합니다 (즉,! = string:: npos) {cerr << "errorn", 0-9 또는 밑줄. 그러한 문자를 찾으면 프로그램은 입력을 거부합니다.

여기에 표시된 라틴 문자 만 허용하는 경우 아랍어, 중국어, 히브리어 또는 영어 문자 세트를 사용하지 않는 외국 시장에서는 응용 프로그램을 사용할 수 없습니다 러시아어, 몇 가지 예를 든다). 정반대의 접근 방식을 취해야하고 나쁜 문자를 찾아야 할 수도 있습니다.

C ++에서 코드 삽입을 피하는 방법 - 더미

편집자의 선택

Dragon Go! iPhone 및 iPad 용 앱 - 인형

Dragon Go! iPhone 및 iPad 용 앱 - 인형

Dragon Search를 사용하시는 분이라면 Dragon Go를 사용하는 것이 좋습니다! Nuance는 iPhone 3GS, iPhone 5, iPhone 4, iPod touch (3 세대), iPod touch (4 세대) 및 iPad에서 사용할 수 있도록 무료로 다운로드 할 수있는이 앱을 만들었습니다. (iOS 4.0 이상이어야합니다.) Android 기기에서도 사용할 수 있습니다. 드래곤가! ...

드래곤에서 피할 수있는 10 가지 실수 말하기 - 인형

드래곤에서 피할 수있는 10 가지 실수 말하기 - 인형

모두가 실수를 저지르고 어떤 사람들은 정말 크고 재미있게 만든다. 실수. NaturallySpeaking을 사용하여 많은 실수를 저 지르므로 때때로 수시로 일부를 만들 수도 있습니다. 내가 묻는 것은 다음과 같습니다. 내가 미리 짐작했던 10 가지 분명한 실수를하지 마십시오. 원래의 수. 창조적으로 행동하십시오. 거기서 나가서 ...

NaturallySpeaking을위한 10 가지 시간 절약 팁 - 인형

NaturallySpeaking을위한 10 가지 시간 절약 팁 - 인형

때로는 잘하고 그냥 사용하는 것의 차이 새로운 소프트웨어는 더 지혜롭고 경험 많은 스승의 충고 한 부분입니다. 누군가가 당신에게 전에 말했었 으면 좋을 10 가지가 있습니다. 대화 상자의 단축키 사용 대화 상자, 라디오 버튼, 확인란의 다양한 기능 ...

편집자의 선택

Google SketchUp 8에서 새로운 지형 모델을 만드는 법 - Google에서 모델링 할 때 인형

Google SketchUp 8에서 새로운 지형 모델을 만드는 법 - Google에서 모델링 할 때 인형

SketchUp을 사용하면 지형을 만들어야 할 수 있습니다. 건물에 대한 패치를 모델링하든 센트럴 파크를 다시 디자인하든 기존 데이터로 지형을 모델링 할 수 있습니다. 기존 데이터는 일반적으로 등고선 또는 토폴 라인 형태로 도착합니다. 지형지도에서 볼 수있는 삐걱 거리는 선을 알고 있습니다.

SketchUp에서 드레이프로 경로와 도로를 만드는 법 - 스케치 업에서 드레이프 도구

SketchUp에서 드레이프로 경로와 도로를 만드는 법 - 스케치 업에서 드레이프 도구

드레이프 도구가 작동 함 쿠키 커터와 조금 같다. 그것을 사용하여 객체의 가장자리를 직접 그 아래에있는 다른 표면으로 전송합니다. 아마도 당신은 부드럽게 경 사진 지형을 가지고 있으며, 당신은 그것에 사행 경로를 그리기를 원할 것입니다. 경로는 윤곽선을 따라야합니다.

SketchUp 모델을 3D 인쇄 용 부품으로 자르는 방법 - 인형

SketchUp 모델을 3D 인쇄 용 부품으로 자르는 방법 - 인형

SketchUp 모델 자르기 Intersect Faces 도구를 사용하여 그룹을 결합하는 것과 매우 유사합니다. 더 큰 오브젝트와 교차하여 커팅의 새 가장자리가 될 커터로 지오메트리를 사용할 것입니다. 모델이 매우 단순하고 SketchUp을 사용하는 경우 ...

편집자의 선택

Route Prefix를 사용하여 Junos - dummy에서 라우팅 필터를 생성하는 방법

Route Prefix를 사용하여 Junos - dummy에서 라우팅 필터를 생성하는 방법

라우팅 정책은 특정 경로가 라우팅 테이블에 수용되거나 일부 인접 라우터에 보급되는 것을 방지하기위한 것입니다. 경우에 따라 특정 경로 또는 경로 집합을 일치시키는 것이 유용 할 수 있습니다. 이렇게하려면 경로 필터를 사용합니다. 경로 필터는 특정 IP 주소 또는 접두어 범위에서 일치합니다. ...

Junos 라우터에서 COS의 코드 포인트 별명을 사용하는 방법 - 인형

Junos 라우터에서 COS의 코드 포인트 별명을 사용하는 방법 - 인형

전달 수업은 고통 스러울 수 있습니다. 더 좋은 방법은 코드 포인트 별칭을 사용하는 것입니다. CoS (Class of Service) 정책을 결정할 때 비트 패턴을 지정하는 대신 비트 패턴을 나타내는 별칭 이름을 정의 할 수 있습니다. 이러한 별칭을 코드 포인트 별칭이라고합니다. 간단히 말하자면 코드 포인트를 사용하십시오 ...

Junos 라우팅 정보를 요약하는 방법 - 더미

Junos 라우팅 정보를 요약하는 방법 - 더미

때때로 라우팅 정보를 간단하게 요약 할 수 있습니다 라우터. 예를 들어, 네트워크에서 OSPF를 방금 구성 했으므로 라우팅 테이블에 특정 수의 OSPF 경로가 표시 될 것으로 예상됩니다. show route summary 명령을 실행하여 모든 경로를 볼 수 있습니다 ...