>  기사  >  백엔드 개발  >  nodejs와 Python을 사용하여 작성된 간단한 HTTP 정적 파일 서버

nodejs와 Python을 사용하여 작성된 간단한 HTTP 정적 파일 서버

高洛峰
高洛峰원래의
2017-02-14 14:07:431309검색

일상적인 개발 과정에서 CDN에 있는 일부 정적 파일(예: JavaScript, CSS, HTML 파일 등)을 수정해야 하는 경우가 많습니다. 이 과정에서 온라인 CDN을 매핑할 수 있는 방법이 있기를 바랍니다. 디렉토리에서 로컬로 로컬에서 파일을 수정할 때 이를 게시할 필요가 없고 새로 고침 후 즉시 효과를 볼 수 있도록 하드 디스크의 디렉토리입니다.

예를 들어 CDN 도메인 이름은 http://a.mycdn.com이고 해당 로컬 디렉터리는 D:workassets입니다. com/* 액세스는 로컬 D:workassets*에 매핑됩니다. 예를 들어, http://a.mycdn.com/s/atp.js를 방문하면 인터넷에서 온라인 파일을 다운로드하지 않고 실제로 로컬 D:workassetssatp.js를 읽는 것입니다.

이 기능을 구현하는 방법은 매우 간단합니다.

1. 로컬에서 HTTP 서비스를 열고 포트 80을 수신합니다.
2. 파일에 "127.0.0.1 a.mycdn.com"을 추가하고, CDN 도메인 이름을 로컬 서버 주소에 바인딩합니다.
3. 로컬 HTTP 서비스를 구성한 후 먼저 해당 파일이 있는지 확인합니다. 로컬 하드 디스크가 있으면 반환합니다. 이 파일의 내용이 존재하지 않으면 해당 콘텐츠가 온라인으로 반환됩니다.

보시다시피 핵심 부분은 로컬 HTTP 서비스를 구축하는 것입니다. 이 영역에는 Apache 또는 Ngnix와 같은 서버 소프트웨어를 로컬로 설치한 다음 해당 전달 규칙을 구성하는 등 많은 자습서가 있습니다. 하지만 개인적으로 이 방법은 아직 좀 복잡하다고 생각합니다. 이 글에서 소개할 내용은 서버 소프트웨어를 설치할 필요가 없는 또 다른 방법입니다.

로컬에서 개발, 디버깅을 하다보니 성능이나 동시성에 대한 요구사항이 높지 않아서 사실 Apache/Ngnix 같은 전문적인 HTTP 소프트웨어는 필요 없고, HTTP를 제공할 수 있는 부분만 있으면 됩니다. 서비스 스크립트. 예를 들어 nodejs를 사용하여 구현하세요.

코드 복사 코드는 다음과 같습니다.


/**
 * 작성자: oldj
 *
 **/

var http = require("http "),
url = require("url"),
path = require("path"),
fs = require("fs"),
local_folders,
base_url;

local_folders = [ // 로컬 경로, 에이전트는 이 목록의 디렉터리에서 파일을 검색합니다. 찾을 수 없으면 온라인 주소
"D:/work/assets"
];
base_url = "http://10.232.133.214"; // 온라인 경로, 파일을 찾을 수 없으면 이 주소로 리디렉션


function loadFile(pathname, response) {
var i, l = local_folders.length,
fn;

console.log("try to load " + 경로명);

for (i = 0; i < i++ ) {

fn = local_folders[i] + 경로 이름;
if (path.existsSync(fn) && fs.statSync(fn).isFile()) {
fs .readFile(fn, 함수(err, data) {
response.writeHead(200);
response.write(data);
response.end();
});

return;
}

}

response.writeHead(302, {
"Location":base_url + pathname
});
응답. end();
}

http.createServer(
함수(요청, 응답) {

var req_url = request.url,
경로명;

// http://www.php.cn/,tbsp/tbsp.css?t=20110920172000.css와 유사한 요청 처리
pathname = req_url.indexOf("??") == -1 ? url.parse(request.url).pathname : req_url;
console.log("'' + 경로 이름 + "'에 대한 요청이 수신되었습니다.");
loadFile(경로 이름, 응답);

}).listen( 80);


위의 local_folders 및 base_url 변수의 값을 필요한 값으로 변경하세요. 예를 들어 이 파일을 local-cdn-proxy.js로 저장한 다음 명령줄에서 "node local-cdn-proxy.js"를 실행하면 로컬 서버가 실행됩니다. 물론 바인딩하는 것도 잊지 마세요. 호스트.

http를 통해 경로에 접근할 때 위 스크립트는 먼저 해당 로컬 디렉터리에서 검색하고, 발견되면 해당 파일의 내용을 반환하며, 발견되지 않으면 바로 302로 점프합니다. 해당 주소를 온라인으로. 찾을 수 없는 상황의 경우 또 다른 해결책은 로컬 서버가 온라인에서 해당 콘텐츠를 다운로드하여 반환하도록 하는 것입니다. 그러나 이 요구 사항의 경우 302 점프로 충분합니다.

nodejs 버전 외에 Python 버전도 작성했습니다.


코드 복사 코드는 다음과 같습니다.


# -*- 코딩: utf-8 -*-
#
# 작성자: oldj
#

import os
import BaseHTTPServer

LOCAL_FOLDERS = [
"D:/work/assets"
]
BASE_URL = "http://10.232.133.214"

class WebRequestHandler(BaseHTTPServer.BaseHTTPRequestHandler) :

def do_GET(self):
LOCAL_FOLDERS의 폴더에 대한 "'%s' 요청이 수신되었습니다." % self.path
인쇄:
fn = os.path.join(folder, self. path.replace("/", os.sep)[1:])
if os.path.isfile(fn):
self.send_response(200)
self.wfile.write(open( fn, "rb").read())
break

else:
self.send_response(302)
self.send_header("위치", "%s%s" % (BASE_URL, self.path))

server = BaseHTTPServer.HTTPServer(("0.0.0.0", 80), WebRequestHandler)
server.serve_forever()


보시다시피 Python 버전의 코드는 nodejs 버전보다 훨씬 더 간소화되었습니다.

위 두 코드의 기능은 비교적 간단합니다. 예를 들어 MIME-Type, Content-Length 및 기타 콘텐츠 헤더 정보가 출력되지 않으며 가능한 차단 작업(예: 파일 읽기 시간 초과 등)이 특수 처리됩니다. 이는 이미 로컬 개발 환경에서 작동하는 버전이며 더 많은 요구 사항을 충족하기 위해 이 두 스크립트를 계속 확장할 수 있습니다.

nodejs와 Python으로 작성된 간단한 HTTP 정적 파일 서버에 대한 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.