게시 요청과 요청 받기의 차이점을 구문 분석합니다.
post: 처리할 데이터를 지정된 리소스에 제출합니다. 데이터 길이는 무제한이고 캐시할 수 없으며 브라우저 기록에 저장할 수 없으며 보안이 매우 뛰어납니다. POST는 GET보다 안정적이고 신뢰할 수 있습니다.
1. HTTP 사양에 따르면 GET은 정보 획득에 사용되며 안전하고 멱등성이 있어야 합니다.
(1) 소위 안전하다는 것은 정보를 수정하는 것이 아니라 정보를 얻는 데 사용되는 작업을 의미합니다. 즉, GET 요청에는 일반적으로 부작용이 없어야 합니다. 즉, 데이터베이스 쿼리처럼 리소스 정보만 가져오며, 데이터를 수정하거나 추가하지 않으며 리소스 상태에 영향을 주지 않습니다.
* 참고: 여기서 보안이란 수정되지 않은 정보만을 의미합니다.
(2)는 동일한 URL에 대한 여러 요청이 동일한 결과를 반환해야 함을 의미합니다. 여기서는 멱등성의 개념을 다시 설명하겠습니다.
멱등성(idempotent, 멱등성)은 추상 대수학에서 흔히 발견되는 수학 또는 컴퓨터 과학 개념입니다.
불능에는 다음과 같은 정의가 있습니다.
단항 연산의 경우 연산이 범위 내 모든 숫자에 대해 여러 번 연산을 수행하면 연산으로 얻은 결과는 연산을 한 번 수행하여 얻은 결과와 같습니다. 작업은 멱등적이라고 합니다. 예를 들어, 절대값 연산이 예로 들어 있습니다. 실수 집합에는 abs(a)=abs(abs(a))가 있습니다.
쌍안 연산의 경우 연산에 참여하는 두 값이 같을 때 연산 결과가 연산에 참여하는 두 값과 같을 경우 해당 연산을 멱등하다고 합니다 , 예를 들어 두 숫자의 최대값을 찾는 것과 같습니다. 의 함수는 실수 집합에서 멱등적입니다. 즉, max(x,x) = x입니다.
위의 설명을 읽고 나면 GET 멱등성의 의미를 이해할 수 있을 것입니다.
그러나 실제 적용에서는 위의 두 가지 규정이 그렇게 엄격하지는 않습니다. 다른 사람의 기사를 인용하는 예: 예를 들어 뉴스 사이트의 첫 페이지는 지속적으로 업데이트됩니다. 두 번째 요청은 다른 배치의 뉴스를 반환하지만 작업은 항상 현재 뉴스를 반환하므로 여전히 안전하고 멱등성 있는 것으로 간주됩니다. 기본적으로 사용자가 링크를 열 때 자신의 관점에서 리소스가 변경되지 않았음을 확신할 수 있는 것이 목표라면,
2. HTTP 사양에 따르면 POST는 서버의 리소스를 수정할 수 있는 요청을 나타냅니다. 위의 예를 계속 인용하자면, 뉴스 웹사이트를 예로 들어보겠습니다. 뉴스에 대한 독자의 댓글은 댓글이 제출된 후 사이트의 리소스가 다르거나 수정되기 때문에 POST를 통해 구현되어야 합니다.
위의 내용은 HTTP 사양에서 GET 및 POST의 몇 가지 원칙 문제에 대해 간략하게 설명합니다. 그러나 실제로는 많은 사람들이 HTTP 사양을 따르지 않습니다.
1. 많은 사람들이 편의성을 추구하여 리소스 업데이트 시 GET을 사용합니다. 왜냐하면 POST는 FORM(form)으로 이동해야 하기 때문입니다. ), 조금 더 번거로울 것입니다.
2. 리소스 추가, 삭제, 수정, 확인은 실제로 GET/POST를 통해 완료할 수 있으며, PUT, DELETE를 사용할 필요가 없습니다.
3. 또 하나는 초기 웹 MVC 프레임워크 디자이너들이 URL을 추상적인 리소스로 의식적으로 처리하고 설계하지 않았기 때문에 더 심각한 문제는 기존 웹 MVC 프레임워크는 기본적으로 GET과 POST 두 가지 HTTP 메서드만 지원하지만 PUT과 DELETE 메서드는 지원한다는 점입니다. 지원되지 않습니다.
* MVC에 대한 간략한 설명: MVC는 원래 데스크톱 프로그램에 존재했습니다. M은 데이터 모델을 나타내고 V는 사용자 인터페이스를 나타내며 C는 컨트롤러를 나타냅니다. MVC를 사용하는 목적은 M과 V의 구현 코드를 분리하여 동일한 프로그램이 다른 표현을 사용할 수 있도록 하는 것입니다.
위의 세 가지 사항은 일반적으로 HTTP 사양을 엄격하게 준수하지 않는 이전 스타일을 설명합니다. 아키텍처가 발전하면서 이제 HTTP 사양을 지원하는 새로운 스타일이 등장하게 되었습니다. 여기서는 더 이상 설명하지 않겠습니다. "RESTful 웹 서비스"를 참조하세요.
원칙 문제에 대해 이야기한 후 표면적으로 GET과 POST의 차이점을 살펴보겠습니다.
1. GET에서 요청한 데이터는 URL에 추가됩니다(즉, 데이터는 다음 위치에 배치됩니다). HTTP 프로토콜 헤더), URL을 분할하고 ?로 데이터를 전송하고 매개변수를 &로 연결합니다(예: login.action?name=hyddd&password=idontknow&verify=%E4%BD%A0%E5%A5%BD). 데이터가 영문/숫자라면 그대로 보내고, 공백이라면 +로 변환하고, 한자/기타 문자라면 BASE64로 직접 암호화하면 %E4와 같은 결과가 나옵니다. %BD%A0%E5%A5% BD, 여기서 %XX의 XX는 16진수 기호의 ASCII 표현입니다.
POST는 제출된 데이터를 HTTP 패키지의 본문에 배치합니다.
2. "GET 방식으로 제출하는 데이터는 최대 1024바이트까지만 가능합니다. 이론적으로 POST에는 제한이 없으며 더 많은 양의 데이터를 전송할 수 있습니다. 최대값은 IIS4에서 80KB, IIS5에서 100KB입니다."? ? !
위 문장을 다른 글에서 옮겨왔습니다. 사실 이렇게 말하는 것은 틀리고 부정확합니다.
(1) 우선 "GET으로 제출하는 데이터는 최대 1024바이트까지만 가능하다". GET은 URL을 통해 데이터를 제출하기 때문에 GET으로 제출할 수 있는 데이터의 양은 URL의 길이와 직접적인 관련이 있다. . 실제로 URL에는 매개변수 상한이 없으며 HTTP 프로토콜 사양은 URL 길이를 제한하지 않습니다. 이 제한은 특정 브라우저 및 서버에 의해 부과됩니다. IE의 URL 길이 제한은 2083바이트(2K+35)입니다. Netscape, FireFox 등 다른 브라우저의 경우 이론적으로 길이 제한이 없으며 운영 체제 지원에 따라 제한이 달라집니다.
이 제한은 매개변수 값 데이터 길이뿐만 아니라 전체 URL 길이에도 적용됩니다. [참고 5 참조]
(2) 이론적으로 POST에는 크기 제한이 없으며, HTTP 프로토콜 사양에서는 "80K/100K 크기 제한이 있습니다"라고 말하는 것은 정확하지 않습니다. 데이터 볼륨." POST 데이터에는 제한이 없습니다. 제한은 서버 핸들러의 처리 능력입니다.
ASP 프로그램의 경우 요청 개체는 각 양식 필드를 처리할 때 데이터 길이 제한이 100K입니다. 그러나 Request.BinaryRead를 사용하면 그러한 제한이 없습니다.
이에 더해 Microsoft는 IIS 6.0에 대해 보안상의 이유로 제한을 강화했습니다. 또한 다음 사항에 주의해야 합니다.
1) IIS 6.0의 기본 ASP POST 데이터 볼륨은 최대 200KB이며 각 양식 필드의 제한은 100KB입니다.
2).IIS 6.0에서 업로드되는 파일의 기본 최대 크기는 4MB입니다.
3) IIS 6.0의 기본 최대 요청 헤더는 16KB입니다.
IIS 6.0 이전에는 이러한 제한이 없었습니다. [참고 5 참조]
그러니까 위의 80K와 100K는 그냥 기본값일 수도 있지만(참고: IIS4와 IIS5의 매개변수는 확인하지 않았습니다), 물론 직접 설정할 수도 있습니다. IIS 버전마다 이러한 매개변수의 기본값이 다르기 때문에 자세한 내용은 관련 IIS 구성 설명서를 참조하세요.
3. ASP에서 서버는 Request.QueryString을 사용하여 GET 요청 매개변수를 얻고 Request.Form을 사용하여 POST 요청 매개변수를 얻습니다. JSP에서는 request.getParameter("XXXX")를 사용하여 이를 얻습니다. jsp에도 request.getQueryString() 메소드가 있지만 사용하기가 더 번거롭습니다. 예를 들어 test.jsp?name=hyddd&password=를 전달하십시오. hyddd, 요청을 사용하세요. getQueryString()은 이름=hyddd&password=hyddd를 가져옵니다. PHP에서는 $_GET 및 $_POST를 사용하여 각각 GET 및 POST에서 데이터를 얻을 수 있는 반면, $_REQUEST는 GET 및 POST 요청 모두에서 데이터를 얻을 수 있습니다. JSP에서 요청을 사용하고 PHP에서 $_REQUEST를 사용하는 데에는 숨겨진 위험이 있다는 점은 주목할 가치가 있습니다. 다음에 기사 요약을 작성하겠습니다.
4.POST가 GET보다 더 안전합니다. 참고: 여기서 언급된 보안은 위의 GET에서 언급된 "보안"과 동일한 개념이 아닙니다. 위의 "보안"의 의미는 데이터 수정이 이루어지지 않는다는 것이며 여기서 보안의 의미는 보안의 진정한 의미입니다. 예를 들어 GET을 통해 데이터를 제출하면 사용자 이름과 비밀번호가 URL에 일반 텍스트로 표시됩니다. , (1) 로그인 페이지가 브라우저 캐시일 수 있고 (2) 다른 사람이 브라우저 기록을 본 다음 다른 사람이 귀하의 계정과 비밀번호를 얻을 수 있기 때문입니다. 또한 GET을 사용하여 데이터를 제출하면 교차 사이트 요청 위조 공격이 발생할 수도 있습니다.
요약하자면 Get은 서버에 데이터를 요청하는 것이고 Post는 데이터를 서버에 제출하라는 요청입니다. FORM(form)에서 Method의 기본값은 "GET"입니다. 본질적으로 GET과 POST는 The입니다. 전송 메커니즘이 다릅니다. 하나를 취하고 하나를 보내는 것이 아닙니다!
위 내용은 게시 요청과 요청 받기의 차이점을 구문 분석합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











C 언어에서 char와 wchar_t의 주요 차이점은 문자 인코딩입니다. char ascii를 사용하거나 ascii를 확장하고, wchar_t는 유니 코드를 사용합니다. Char는 1-2 바이트를 차지하고 WCHAR_T는 2-4 바이트를 차지합니다. Char는 영어 텍스트에 적합하며 WCHAR_T는 다국어 텍스트에 적합합니다. Char_t는 널리 지원되며, 컴파일러 및 운영 체제가 유니 코드를 지원하는지 여부에 따라 다릅니다. Char는 문자 범위가 제한되며 WCHAR_T는 더 큰 문자 범위를 가지며 특수 함수는 산술 작업에 사용됩니다.

멀티 스레딩과 비동기식의 차이점은 멀티 스레딩이 동시에 여러 스레드를 실행하는 반면, 현재 스레드를 차단하지 않고 비동기식으로 작업을 수행한다는 것입니다. 멀티 스레딩은 컴퓨팅 집약적 인 작업에 사용되며 비동기식은 사용자 상호 작용에 사용됩니다. 멀티 스레딩의 장점은 컴퓨팅 성능을 향상시키는 것이지만 비동기의 장점은 UI 스레드를 차단하지 않는 것입니다. 멀티 스레딩 또는 비동기식을 선택하는 것은 작업의 특성에 따라 다릅니다. 계산 집약적 작업은 멀티 스레딩을 사용하고 외부 리소스와 상호 작용하고 UI 응답 성을 비동기식으로 유지 해야하는 작업을 사용합니다.

C 언어에는 내장 합계 기능이 없으므로 직접 작성해야합니다. 합계는 배열 및 축적 요소를 가로 질러 달성 할 수 있습니다. 루프 버전 : 루프 및 배열 길이를 사용하여 계산됩니다. 포인터 버전 : 포인터를 사용하여 배열 요소를 가리키며 효율적인 합계는 자체 증가 포인터를 통해 달성됩니다. 동적으로 배열 버전을 할당 : 배열을 동적으로 할당하고 메모리를 직접 관리하여 메모리 누출을 방지하기 위해 할당 된 메모리가 해제되도록합니다.

Char 및 Unsigned Char는 문자 데이터를 저장하는 두 가지 데이터 유형입니다. 주요 차이점은 음수 및 양수를 다루는 방법입니다. 음수 처리 : char는 부정확 한 char가 할 수없고 음수를 저장할 수 있습니다. 비트 모드 : char 가장 높은 비트는 기호, 부호없는 문자 부호 비트를 나타냅니다. 산술 연산 : char and signed char는 서명하고 서명되지 않은 유형이며, 산술 작업은 다릅니다. 호환성 : 문자와 서명되지 않은 숯

C 언어 기능은 코드 모듈화 및 프로그램 구축의 기초입니다. 그들은 선언 (함수 헤더)과 정의 (기능 본문)로 구성됩니다. C 언어는 값을 사용하여 기본적으로 매개 변수를 전달하지만 주소 패스를 사용하여 외부 변수를 수정할 수도 있습니다. 함수는 반환 값을 가질 수 있거나 가질 수 있으며 반환 값 유형은 선언과 일치해야합니다. 기능 명명은 낙타 또는 밑줄을 사용하여 명확하고 이해하기 쉬워야합니다. 단일 책임 원칙을 따르고 기능 단순성을 유지하여 유지 관리 및 가독성을 향상시킵니다.

멀티 스레딩은 컴퓨터 프로그래밍에서 중요한 기술이며 프로그램 실행 효율성을 향상시키는 데 사용됩니다. C 언어에는 스레드 라이브러리, Posix 스레드 및 Windows API를 포함하여 멀티 스레딩을 구현하는 방법에는 여러 가지가 있습니다.

H5. 미니 프로그램과 앱의 주요 차이점은 다음과 같습니다. 기술 아키텍처 : H5는 웹 기술을 기반으로하며 미니 프로그램 및 앱은 독립적 인 응용 프로그램입니다. 경험과 기능 : H5는 가볍고 사용하기 쉽고 기능이 제한되어 있습니다. 미니 프로그램은 가벼우 며 상호성이 우수합니다. 앱은 강력하고 부드러운 경험이 있습니다. 호환성 : H5는 크로스 플랫폼 호환성이며 애플릿 및 앱은 플랫폼에 의해 제한됩니다. 개발 비용 : H5는 개발 비용이 낮고 중간 미니 프로그램 및 최고 앱이 있습니다. 적용 가능한 시나리오 : H5는 정보 표시에 적합하고 애플릿은 가벼운 응용 프로그램에 적합하며 앱은 복잡한 기능에 적합합니다.

C와 C#은 유사성이 있지만 완전히 다릅니다. C는 프로세스 지향, 수동 메모리 관리 및 시스템 프로그래밍에 사용되는 플랫폼 의존 언어입니다. C#은 데스크탑, 웹 응용 프로그램 및 게임 개발에 사용되는 객체 지향, 쓰레기 수집 및 플랫폼 독립 언어입니다.
