인터넷의 발달과 함께 웹 개발은 전 세계적으로 매우 인기 있는 산업이 되었습니다. 개발자들에게 코드를 빠르고 효과적으로 개발하고 게시하려면 특히 정적 리소스를 관리하고 처리하는 데 도움이 되는 정적 리소스 서버가 필요합니다. 프론트엔드와 백엔드가 분리된 개발 모델에서는 Node.js가 출시된 이후 매우 인기 있는 개발 언어가 되었습니다. 특히 정적 리소스 서버를 구축하는 데 적합합니다. 이 기사에서는 Node.js를 사용하여 경량 정적 리소스 서버를 구축하는 방법을 소개합니다.
1. Node 설치
먼저 JavaScript 기반의 서버측 프로그래밍 언어인 Node.js를 설치해야 하며 공식 웹사이트에서 다운로드하여 설치할 수 있습니다.
2. 프로젝트 초기화
로컬에 폴더를 만들고 이를 위한 노드 프로젝트를 초기화해야 합니다.
명령줄에 다음 명령을 입력하세요.
mkdir node-static-server cd node-static-server npm init
위 명령을 입력하면 이 프로젝트의 초기화 매개변수를 빌드하라는 메시지가 표시됩니다. Enter를 눌러 기본값을 사용할 수도 있습니다.
프로젝트에 index.html이라는 파일을 생성하고 아래와 같이 간단한 html 태그를 추가합니다.
<!DOCTYPE html> <html> <head></head> <body> <h1 id="Hello-World">Hello, World!</h1> </body> </html>
3. 서버를 생성합니다.
프로젝트에 server.js라는 파일을 생성합니다. Node.js의 http 모듈에서 웹 서버를 생성하는 코드는 다음과 같습니다.
const http = require('http'); const fs = require('fs'); const path = require('path'); const server = http.createServer((req, res) => { // 处理首页请求 if (req.url === '/') { fs.readFile(path.join(__dirname, 'index.html'), (err, data) => { if (err) { res.writeHead(500); return res.end('Error loading index.html'); } res.writeHead(200); res.end(data); }); } else { // 处理其他静态文件请求 const filePath = path.join(__dirname, req.url); fs.readFile(filePath, (err, data) => { if (err) { res.writeHead(404); return res.end('404 not found'); } res.writeHead(200); res.end(data); }); } }); const port = process.env.PORT || 3000; server.listen(port, () => console.log(`Server running at http://localhost:${port}`));
4. 서버를 실행합니다.
서버를 시작하려면 명령줄에 다음 명령을 입력합니다.
node server.js
http://를 엽니다. 브라우저 localhost:3000에서 정적 리소스 서버가 실행 중임을 확인할 수 있습니다.
모든 것이 순조롭게 진행된다면 브라우저에서 http://localhost:3000/을 방문하면 index.html에 작성한 콘텐츠가 렌더링됩니다.
5. 다양한 정적 파일 요청 처리
홈페이지 응답 외에도 CSS, JS, 이미지 파일 등과 같은 다른 정적 파일에 대한 요청도 처리해야 합니다. 이는 해당 정적 리소스를 추가하여 수행할 수 있습니다. 다양한 유형의 정적 파일을 요청하려면 디렉터리를 서버에 연결하세요. 여기서는 정적 파일을 저장하기 위해 public이라는 디렉터리를 만들었습니다. 다음 코드는 이 디렉터리의 내용을 서버의 루트 디렉터리에 매핑합니다.
const server = http.createServer((req, res) => { if (req.url === '/') { // 处理首页请求省略 } else { // 处理其他静态文件请求 const filePath = path.join(__dirname, 'public', req.url); fs.readFile(filePath, (err, data) => { if (err) { res.writeHead(404); return res.end('404 not found'); } if (req.url.endsWith('.css')) { res.writeHead(200, { 'content-type': 'text/css' }); } if (req.url.endsWith('.js')) { res.writeHead(200, { 'content-type': 'application/javascript' }); } if (req.url.endsWith('.png')) { res.writeHead(200, { 'content-type': 'image/png' }); } res.end(data); }); } });
6. 요약
Node.js를 사용하여 정적 리소스 구축 서버는 다음과 같습니다. 간단하고 편리합니다. 내장된 http 모듈을 사용하면 HTML, CSS, JS, 이미지 등과 같은 정적 리소스에 대한 요청을 처리하는 기본 서버를 쉽게 만들 수 있습니다. 향후 개발 과정에서 우리는 보다 효율적이고 강력한 서버를 달성하기 위해 필요에 따라 적합한 서버 프레임워크를 선택할 수 있습니다.
위 내용은 Nodejs는 정적 리소스 서버를 구축합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

아니요, 당신은 uplemultipleidsinthesamedom.1) idsmustbeuniqueperhtmlspecification, andusingduplicatescancauseSconsistentBrowserBehavior.2) useclassesforstylingmultipleelements, attributesectorscendats eftibutes 및 descenderfortrecture

html5aimstoenhancewebcapabilities, MakingItmoredynamic, Interactive, and Accessible.1) itsupportsmultimediaelementslikeand, 2) SemanticlementsImpreveAcessibilityandCodeReardability.3) 특징적인 부대, 응답 Whebappl

html5aimstoenhancewebdevelopmentandusereerexperiencetroughsemanticstructure, multimediaintegration 및 performanceimprovements

html5isnotinherentlyinsecure, buttsfeaturescanleadtosecurityRiskSifMisusedOrimProperSimplemented.1) USETHETSANDTRIFICEINIFRAMESTOCONTROLEMEDEDEDENDENDENDENDENDENDENDENDENDENTANDENTANDERVULNERABILITIESLIKECLIKEJACKINGINITIONSLIKECLIKETHOING.2) 피난처에 대한 비난을 피하십시오

html5aimedtoenhanceWebDevelopmentByIntrictionmanticalLiticalEmentements, nativeMultiMediasupport, 개선 된 정보 및 및 플린 컨테이션, html4andxhtml.1) itintructed -temantictagsiver ,, 개선 부양

ID 선택기를 사용하는 것은 본질적으로 CSS에서 나쁘지 않지만주의해서 사용해야합니다. 1) ID 선택기는 고유 한 요소 또는 JavaScript 후크에 적합합니다. 2) 일반적인 스타일의 경우 클래스 선택기가보다 유연하고 유지 관리 가능하므로 사용해야합니다. ID 및 클래스 사용의 균형을 유지함으로써보다 강력하고 효율적인 CSS 아키텍처를 구현할 수 있습니다.

HTML5'SGOALSIN2024FOCUSONERFINEMENTANDENDEND 및 최적화, NOTNEWFEATURES.1) 최적화 된 렌더링을 향상시킵니다

html5aimedtoimprovewebdevelopmentinfourkeyareas : 1) Multimediasupport, 2) Semantictructure, 3) Formcapabilities, 및 4) OfflineandStorageOptions.1) Html5intrudceDandlements, Simplifying MediaembeddingandenUsereXperxpercepence.2) NewSmanticallementalmentalmentementlementmentmentmentmentmentmentmentmentmentmentmentmentmentmentmentmentmentmentalments


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경