[C#] C #에서 간단한 프록시를 만드는 방법은 무엇입니까?

몇 주 전에 Privoxy를 다운로드했으며 재미를 위해 간단한 버전의 버전을 수행하는 방법을 알고 싶었습니다.

프록시에 요청을 보내려면 브라우저 (클라이언트)를 구성해야한다는 것을 알고 있습니다. 프록시는 요청을 웹에 보냅니다 (http 프록시라고 말하십시오). 프록시는 응답을 수신하지만 프록시는 어떻게 요청을 브라우저 (클라이언트)에게 다시 보낼 수 있습니까?

웹에서 C # 및 http 프록시를 검색했지만 장면 뒤에서 올바르게 작동하는 방식을 이해할 수있는 것을 찾지 못했습니다. (역 프록시를 원하지는 않지만 확실하지 않습니다).

이 소규모 프로젝트를 계속 진행할 수있는 설명이나 정보가 있습니까?

최신 정보

이것이 내가 이해하는 것입니다 (아래 그림 참조).

1 단계 프록시가 수신하는 포트에서 모든 요청을 127.0.0.1로 보내도록 클라이언트 (브라우저)를 구성합니다. 이런 식으로 요청은 인터넷으로 직접 전송되지 않지만 프록시에 의해 처리됩니다.

2 단계 프록시가 새 연결을보고 HTTP 헤더를 읽고 실행해야하는 요청을 확인합니다. 그는 요청을 실행합니다.

3 단계 프록시는 요청으로부터 응답을받습니다. 이제 그는 웹에서 클라이언트로 답변을 보내야하지만 어떻게 ???

대체 텍스트

유용한 링크

Mentalis Proxy :이 프로젝트가 프록시라는 것을 알았습니다. 소스를 확인할 수도 있지만 더 많은 개념을 이해하기 위해 기본적인 것을 원했습니다.

ASP 프록시 : 여기에서도 정보를 얻을 수 있습니다.

리플렉터 요청 : 간단한 예입니다.

다음은 간단한 Http 프록시 가있는 Git Hub 리포지토리입니다 .



답변

HttpListener클래스로 하나를 작성하여 들어오는 요청을 수신하고 HttpWebRequest클래스가 요청을 릴레이 할 수 있습니다.


답변

HttpListener 또는 이와 유사한 것을 사용하지 않으므로 많은 문제가 발생합니다.

가장 중요한 것은 지원하는 데 큰 고통이 될 것입니다.

  • 프록시 연결 유지
  • SSL이 작동하지 않습니다 (올바른 방식으로 팝업이 표시됨)
  • .NET 라이브러리는 RFC를 엄격하게 준수하므로 일부 요청은 실패합니다 (IE, FF 및 기타 다른 브라우저에서도 작동).

당신이해야 할 일은 :

  • TCP 포트 청취
  • 브라우저 요청 파싱
  • TCP 레벨에서 해당 호스트에 호스트 연결 추출
  • 사용자 정의 헤더 등을 추가하지 않으려면 모든 것을 앞뒤로 전달하십시오.

다른 요구 사항으로 .NET에 2 개의 다른 HTTP 프록시를 작성했으며 이것이 최선의 방법이라고 말할 수 있습니다.

Mentalis는이 작업을 수행하지만 코드는 “대리 스파게티”이며 GoTo보다 나쁩니다.)


답변

최근에 TcpListenerTcpClient 사용하여 c # .net에 간단한 프록시를 작성했습니다 .

https://github.com/titanium007/Titanium-Web-Proxy

클라이언트 시스템은 프록시가 사용하는 루트 인증서를 신뢰해야합니다. WebSockets 릴레이도 지원합니다. 파이프 라이닝을 제외한 HTTP 1.1의 모든 기능이 지원됩니다. 어쨌든 대부분의 최신 브라우저에서는 파이프 라이닝을 사용하지 않습니다. Windows 인증 (일반, 다이제스트)도 지원합니다.

프로젝트를 참조하여 응용 프로그램을 연결 한 다음 모든 트래픽을보고 수정할 수 있습니다. (요청 및 답변).

성능까지는 내 컴퓨터에서 테스트했으며 눈에 띄게 지연없이 작동합니다.


답변

프록시는 다음과 같은 방식으로 작동 할 수 있습니다.

1 단계 : proxyHost : proxyPort를 사용하도록 클라이언트를 구성하십시오.

프록시는 proxyHost : proxyPort에서 수신 대기하는 TCP 서버입니다. 브라우저가 프록시와의 연결을 열고 Http 요청을 보냅니다. 프록시는이 요청을 구문 분석하고 “호스트”헤더를 감지하려고합니다. 이 헤더는 프록시에게 연결을 열 위치를 알려줍니다.

2 단계 : 프록시가 “호스트”헤더에 지정된 주소로 연결을 엽니 다. 그런 다음 HTTP 요청을 해당 원격 서버로 보냅니다. 응답을 읽습니다.

3 단계 : 원격 HTTP 서버에서 응답을 읽은 후 프록시는 브라우저와 이전에 열린 TCP 연결을 통해 응답을 보냅니다.

스키마는 다음과 같습니다.

Browser                            Proxy                     HTTP server
  Open TCP connection
  Send HTTP request  ----------->
                                 Read HTTP header
                                 detect Host header
                                 Send request to HTTP ----------->
                                 Server
                                                      <-----------
                                 Read response and send
                   <-----------  it back to the browser
Render content


답변

트래픽을 가로 채기를 원하는 경우 피들러 코어를 사용하여 프록시를 만들 수 있습니다.

http://fiddler.wikidot.com/fiddlercore

UI에서 fiddler를 먼저 실행하여 기능을 확인하십시오. http / https 트래픽을 디버깅 할 수있는 프록시입니다. c #으로 작성되었으며 자신의 응용 프로그램에 빌드 할 수있는 핵심이 있습니다.

FiddlerCore는 상업용 응용 프로그램에는 무료가 아닙니다.


답변

OWIN과 WebAPI는 정말 쉬워졌습니다. C # 프록시 서버를 검색 할 때이 게시물 http://blog.kloud.com.au/2013/11/24/do-it-yourself-web-api-proxy/도 발견했습니다 . 이것이 내가가는 길이 될 것입니다.


답변

HTTPListener를 사용하는 경우 악의에 동의하면 많은 문제가 발생하고 요청을 구문 분석해야하며 헤더에 참여하게됩니다 …

  1. tcp listener를 사용하여 브라우저 요청을 청취
  2. 요청의 첫 번째 줄만 구문 분석하고 호스트 도메인과 포트를 연결하십시오.
  3. 브라우저 요청의 첫 번째 줄에서 찾은 호스트에게 정확한 원시 요청을 보냅니다.
  4. 대상 사이트에서 데이터 수신 (이 섹션에 문제가 있음)
  5. 호스트로부터받은 정확한 데이터를 브라우저로 전송

브라우저 요청에 무엇이 있는지 알 필요가 없으며 구문 분석하고 첫 번째 줄에서만 대상 사이트 주소를 가져옵니다. 첫 번째 줄은 일반적으로 다음 GET http://google.com HTTP1.1 또는 CONNECT facebook.com을 좋아합니다 . 443 (ssl 요청 용)