이 기사에서는 Express를 통해 자체 서버를 구축하는 노드를 주로 소개합니다. 편집자는 이것이 꽤 좋다고 생각하므로 지금 공유하고 참고용으로 제공하겠습니다. 편집자를 따라가서 모두에게 도움이 되기를 바랍니다.
머리말
시뮬레이션 프로젝트를 시작하려면 데이터를 호출할 수 있는 API를 제공하는 서버가 필요합니다. 이번에는 Express 프레임워크를 사용하여 API 인터페이스를 작성했습니다. 모든 요청은 데이터를 반환하기 위해 서버에 대한 ajax 요청을 통해 이루어집니다. 노드를 사용하여 백엔드를 작성하는 것은 기본적으로 돌을 느끼면서 강을 건너는 것과 같습니다. 기사에 부족한 점이 있으면 지적해 주세요.
Express 프레임워크 설치
Portal: expressofficial
그럼 Node 자체에서 제공하는 일부 라이브러리를 도입해야 하는 미들웨어를 소개하겠습니다. require를 통해 직접 참조할 수 있습니다. 제공되지 않는 라이브러리의 경우 수동 npm을 통해 설치할 수도 있습니다
var fs = require('fs'); 操作文件模块 var http = require('http'); http模块 var url = require('url'); 获取url信息模块 var qs = require('querystring'); 处理url参数模块 var path = require('path'); 文件路径模块 var bodyParser = require('body-parser'); 请求体对象化 (必须)否则后台无法解析前端发送的body内容
그런 다음 모듈을 직접 활성화할 수 있습니다
app.use(bodyParser.json()); // 访问静态资源文件 这里是访问所有dist目录下的静态资源文件 app.use(express.static(path.resolve(__dirname, '../dist'))) app.use(express.static('public')); // 因为是单页应用 所有请求都走/dist/index.html app.get('/', function(req, res) { const html = fs.readFile(path.resolve(__dirname, '../dist/index.html'), 'utf-8'); res.send(html) }); //处理请求跨域 app.all('*', function(req, res, next) { res.header("Access-Control-Allow-Origin", "*"); res.header("Access-Control-Allow-Headers", "X-Requested-With"); res.header("Content-Type", "application/json;charset=utf-8"); res.header("Access-Control-Allow-Headers", "content-type"); next(); });
준비가 완료되면 작성을 시작할 수 있습니다. 인터페이스. 데이터베이스에 관해서는 json을 시뮬레이션할 수도 있고 실제로 온라인 데이터베이스를 시뮬레이션할 수도 있습니다.
다음은 설명-데이터베이스 도킹, 요청 작업, 파일 요청 작업의 세 부분으로 나누어집니다.
데이터베이스 연결
여기에서는 mongodb 데이터베이스를 설치하고 성공적으로 활성화했다고 가정합니다. Express 튜토리얼을 주의 깊게 읽으면 프레임워크가 mongodb에 대한 지원을 제공한다는 것을 알게 될 것입니다. Mongodb에는 mongoose와 같은 데이터베이스를 사용하기 위한 많은 확장 플러그인이 있습니다. 여기서는 데이터베이스에 연결하기 위해 Express에서 공식적으로 제공하는 mongoskin을 사용합니다.
$ npm install mongoskin #####官方实例 var db = require('mongoskin').db('localhost:27017/animals'); db.collection('mamals').find().toArray(function(err, result) { if (err) throw err; console.log(result); });
설치가 성공적으로 완료되면 먼저 우리가 사용하고 있는 데이터베이스를 소개합니다.
var db = require('mongoskin').db('mongodb://localhost:27017/blog'); var ObjectId = require('mongodb').ObjectID;
위 코드는 블로그 데이터베이스에 성공적으로 연결되었고 자동으로 개인 ID를 활성화했다는 의미입니다. mongodb에서 생성된 데이터에 추가됩니다. 직접 사용할 수 있습니다. 이제 데이터베이스와 서버가 연결되었습니다.
프런트 엔드에서 보낸 요청 처리
Get 요청 처리
/** * 获取文章信息 */ app.get('/article/info', function (req, res) { >>> 获取请求参数 var arg = qs.parse(url.parse(req.url).query); var id = arg.id; >>> 链接数据库根据参数查找文档并返回 db.collection('articleList').find({ "_id": ObjectId(id)}).toArray(function(err, result) { if (err) throw err; console.log(result) res.end(JSON.stringify(result)) }); });
위 코드는 get 요청 처리를 구현하고, 매개변수 모듈을 통해 URL의 매개변수를 가져오며, db는 연결된 데이터베이스. ID를 기준으로 'articleList'의 데이터 테이블을 검색한 후 res.end()를 통해 데이터를 반환하여 응답을 완료합니다.
Post 요청 처리
/** * 提交留言信息 */ app.post('/board/post', function (req, res) { >>>> 获取请求参数 var data = { date: req.body.date, name: req.body.name, content: req.body.content, time: req.body.time, position: req.body.position }; >>> 链接数据库并插入数据 db.collection('board').insert(data, function(err, result) { if(err) { res.end('Error:'+ err) } res.end('提交成功') }); });
post 요청의 매개변수 획득은 get과 다릅니다. req.body를 통해 프런트 엔드에서 전송된 요청 본문을 직접 얻을 수 있습니다. js 객체를 통해 매개변수를 가져옵니다. 그런 다음 매개변수를 기반으로 데이터베이스 작업을 수행합니다. 이 시점에서 기본 요청이 도입되었습니다. 이미지 업로드와 같은 일반적인 파일 작업 요구 사항을 처리하는 방법에 대해 이야기해 보겠습니다.
프런트 엔드에서 파일 요청 처리
작업을 단순화하기 위해 multer 모듈을 도입하여 파일을 처리할 수 있습니다. 코드는 다음과 같습니다
var multer = require('multer'); var storage = multer.diskStorage({ //设置上传后文件路径,uploads文件夹会自动创建。 destination: function (req, file, cb) { cb(null, './public/uploads') }, //给上传文件重命名,获取添加后缀名 filename: function (req, file, cb) { var fileFormat = (file.originalname).split("."); cb(null, file.fieldname + '-' + Date.now() + "." + fileFormat[fileFormat.length - 1]); } }); //生成上传模块,让API调用 var upload = multer({ storage: storage }).single('file');
위 코드는 파일 업로드 모듈을 성공적으로 도입했습니다. 해당 콘텐츠를 신속하게 생성할 수 있습니다. 구체적인 사용 방법은 공식 문서를 확인하세요. 준비 작업이 완료된 후 프로젝트에 사용하세요.
/** * 图片上传 */ app.post('/upload', function (req, res) { upload(req, res, function (err) { if (err) { console.log(err) return } console.log(req.file) res.end(JSON.stringify(req.file)) }) }); //图片上传到服务器 ,向客户端返回文件信息 比如文件的存储位置,之后就可以通过地址访问服务器的图片 /** * 图片删除 */ app.post('/image/delete', function (req, res) { fs.unlink(req.body.path, function(err) { if (err) { return console.error(err); } res.end("文件删除成功!"); }); });
여기에 사진을 업로드하려면 이전에 작성한 업로드 모듈을 직접 사용합니다. 인터페이스 요청이 성공하면 파일이 성공적으로 업로드된 것입니다. 미리보기 프로세스가 있는 경우 업로드 인터페이스를 직접 호출하면 안 됩니다. 기본 노드 fs 모듈을 통해 추가된 파일을 삭제하고 수정할 수도 있습니다.
온라인 접속 후 발생하는 기록 모드의 새로 고침 문제
온라인 프로세스는 프로그램을 실행하기 위해 컴퓨터를 변경하는 것으로 생각할 수 있습니다. 여기서는 Alibaba Cloud 서버를 사용하고 있습니다. 클라우드 서버에 좋은 환경을 설치하고, 여기에 프로젝트를 복제하고, 영원히와 같은 영구 런타임 라이브러리를 설치하고, 시작 ~ 확인하면 프로젝트가 항상 실행됩니다. www 액세스가 필요한 경우 서버를 가리키는 DNS 확인 및 도메인 이름도 구입해야 합니다.
위 프로젝트를 로컬에서 실행한다면 기본적으로 문제가 없을 것입니다. 하지만 프로젝트가 온라인 상태가 된 후에는 새로 고쳐질 것입니다. 뭐? ? 404 도대체 뭐야? Baidu를 열고 찾아보세요. 엄청나네요~~ 현재 엔드에서는 히스토리 모드가 활성화되어 있고, 백엔드에서도 히스토리 지원이 활성화되어야 합니다. Express 환경은 다음과 같습니다:
var history = require('connect-history-api-fallback'); var connect = require('connect'); /////// app.use(history());
업데이트 코드 새로고침~좋아요 완벽해요!
요약
뭔가를 잘 배우고 싶다면 장기적인 축적이 필요합니다. 프런트엔드로서 서버 데이터베이스에 대한 일부 지식은 형제(백엔드)와의 더 나은 의사소통에 도움이 될 뿐만 아니라 프런트엔드에게는 물 속의 물고기와도 같습니다.
관련 권장사항:
Express.Router 인스턴스를 사용하는 Node.js에 대한 자세한 설명
jq Paginator와 Express를 결합하여 페이징 효과를 구현함
nodejs+express를 사용하여 간단한 파일 업로드를 구현하는 자세한 설명 기능
위 내용은 Node는 Express를 구현하여 자체 서버 인스턴스를 구축합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

JavaScript는 브라우저 및 Node.js 환경에서 실행되며 JavaScript 엔진을 사용하여 코드를 구문 분석하고 실행합니다. 1) 구문 분석 단계에서 초록 구문 트리 (AST)를 생성합니다. 2) 컴파일 단계에서 AST를 바이트 코드 또는 기계 코드로 변환합니다. 3) 실행 단계에서 컴파일 된 코드를 실행하십시오.

Python 및 JavaScript의 미래 추세에는 다음이 포함됩니다. 1. Python은 과학 컴퓨팅 분야에서의 위치를 통합하고 AI, 2. JavaScript는 웹 기술의 개발을 촉진하고, 3. 교차 플랫폼 개발이 핫한 주제가되고 4. 성능 최적화가 중점을 둘 것입니다. 둘 다 해당 분야에서 응용 프로그램 시나리오를 계속 확장하고 성능이 더 많은 혁신을 일으킬 것입니다.

개발 환경에서 Python과 JavaScript의 선택이 모두 중요합니다. 1) Python의 개발 환경에는 Pycharm, Jupyternotebook 및 Anaconda가 포함되어 있으며 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 2) JavaScript의 개발 환경에는 Node.js, VScode 및 Webpack이 포함되어 있으며 프론트 엔드 및 백엔드 개발에 적합합니다. 프로젝트 요구에 따라 올바른 도구를 선택하면 개발 효율성과 프로젝트 성공률이 향상 될 수 있습니다.

예, JavaScript의 엔진 코어는 C로 작성되었습니다. 1) C 언어는 효율적인 성능과 기본 제어를 제공하며, 이는 JavaScript 엔진 개발에 적합합니다. 2) V8 엔진을 예를 들어, 핵심은 C로 작성되며 C의 효율성 및 객체 지향적 특성을 결합하여 C로 작성됩니다.

JavaScript는 웹 페이지의 상호 작용과 역학을 향상시키기 때문에 현대 웹 사이트의 핵심입니다. 1) 페이지를 새로 고치지 않고 콘텐츠를 변경할 수 있습니다. 2) Domapi를 통해 웹 페이지 조작, 3) 애니메이션 및 드래그 앤 드롭과 같은 복잡한 대화식 효과를 지원합니다. 4) 성능 및 모범 사례를 최적화하여 사용자 경험을 향상시킵니다.

C 및 JavaScript는 WebAssembly를 통한 상호 운용성을 달성합니다. 1) C 코드는 WebAssembly 모듈로 컴파일되어 컴퓨팅 전력을 향상시키기 위해 JavaScript 환경에 도입됩니다. 2) 게임 개발에서 C는 물리 엔진 및 그래픽 렌더링을 처리하며 JavaScript는 게임 로직 및 사용자 인터페이스를 담당합니다.

JavaScript는 웹 사이트, 모바일 응용 프로그램, 데스크탑 응용 프로그램 및 서버 측 프로그래밍에서 널리 사용됩니다. 1) 웹 사이트 개발에서 JavaScript는 HTML 및 CSS와 함께 DOM을 운영하여 동적 효과를 달성하고 jQuery 및 React와 같은 프레임 워크를 지원합니다. 2) 반응 및 이온 성을 통해 JavaScript는 크로스 플랫폼 모바일 애플리케이션을 개발하는 데 사용됩니다. 3) 전자 프레임 워크를 사용하면 JavaScript가 데스크탑 애플리케이션을 구축 할 수 있습니다. 4) node.js는 JavaScript가 서버 측에서 실행되도록하고 동시 요청이 높은 높은 요청을 지원합니다.

Python은 데이터 과학 및 자동화에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 데이터 처리 및 모델링을 위해 Numpy 및 Pandas와 같은 라이브러리를 사용하여 데이터 과학 및 기계 학습에서 잘 수행됩니다. 2. 파이썬은 간결하고 자동화 및 스크립팅이 효율적입니다. 3. JavaScript는 프론트 엔드 개발에 없어서는 안될 것이며 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축하는 데 사용됩니다. 4. JavaScript는 Node.js를 통해 백엔드 개발에 역할을하며 전체 스택 개발을 지원합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

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

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

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