> 웹 프론트엔드 > JS 튜토리얼 > Nodejs+express 모듈을 사용하여 서버를 만드는 방법에 대한 자세한 설명

Nodejs+express 모듈을 사용하여 서버를 만드는 방법에 대한 자세한 설명

青灯夜游
풀어 주다: 2021-03-24 11:10:25
앞으로
2072명이 탐색했습니다.

이 기사에서는 Nodejs에서 express 모듈을 사용하여 서버를 만드는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

Nodejs+express 모듈을 사용하여 서버를 만드는 방법에 대한 자세한 설명

express 모듈을 사용하여 서버 만들기

  • 새 폴더를 만듭니다. 폴더 이름이 중국어가 아니며 이름이 모듈 이름과 동일하면 안 됩니다.

  • npm init - y 초기화

  • 모듈을 다운로드하고 npm 공식 웹사이트로 이동하여 모듈을 검색한 후 해당 지침을 따르세요. 다운로드에 실패하면

    이 명령을 사용하여 캐시를 지우고 다시 다운로드하세요. , 모듈의 공식 웹사이트로 이동하거나 모듈 설명에서
    • npm cache clean -f
      // 导入express模块
      const express = require("express");
      
      // 创建一个服务器
      const app = express();
      
      // 设置返回给用户看的内容
      app.get("/", function (req, res) {
        // 如果是用内置模块http创建的服务器返回的内容用res.end()响应
        // 现在我们这里用的是express模块创建的服务器,那用res.send()响应
        res.send("Hello World");
      });
      
      // 启动服务器
      app.listen(4399, () => {
        console.log("服务器开启了...");
      });
      로그인 후 복사
    • [관련 권장 사항: "
    nodejs tutorial
  • "]
  • Express 모듈을 사용하여 정적 리소스 서버를 생성하세요

    const express = require("express");
    const app = express();
    // 例如,通过如下代码就可以将 web 目录下的图片、CSS 文件、JavaScript 文件对外开放访问了:
    app.use(express.static("web"));
    const port = 8089;
    
    // app.get("/", (req, res) => res.send("Hello World!"));
    
    app.listen(port, () => console.log(`Example app listening on port ${port}!`));
    로그인 후 복사
get/ post 차이

get 값은 url을 통해 전달됩니다. post는 요청 본문(guerystring)을 통해 전달됩니다.

get으로 전달된 데이터는 상대적으로 작은 반면, post로 전달된 데이터는 상대적으로 큽니다

    get으로 전달된 값은 uri로 전달되기 때문에 안전합니다.
  • post 값 전송 보안이 상대적으로 높습니다. - 포인트

  • get - 일반적으로 데이터 요청/데이터 획득에 사용됩니다.

    post - 일반적으로 데이터 제출에 사용됩니다.

  • 예:
  • 대규모 이벤트 프로젝트

    개인 센터 정보 수정 인터페이스: post
    기사 게시 인터페이스: post

    n 페이지의 기사 인터페이스 가져오기: get

  • express는 간단한 가져오기 인터페이스를 구현합니다


    /**
     * 接口:得到一条随机笑话
     * 接口地址:/joke
     * 请求方式:get
     * 参数:无
     * 返回:一条笑话
     */
    const express = require("express");
    const app = express();
    
    app.get("/joke", function (req, res) {
      // 准备n条笑话(实际开放的时候笑话们肯定是从数据库或者是其他的数据源获取的
      let arr = [
        "一个男生暗恋一个女生很久了。一天自习课上,男生偷偷的传了小纸条给女生,上面写着“其实我注意你很久了”。不一会儿,女生传了另一张纸条,男生心急火燎的打开一看“拜托你不要告诉老师,我保证以后再也不嗑瓜子了”。。。。。。男生一脸懵逼",
        "在公园里看到一对很有爱的父女,父亲大约五十岁左右,女儿二十来岁,女儿很乖巧的给爸爸剥了一个茶叶蛋,说说什么互相开怀大笑,好温馨的家庭。但是,为什么后来他们就舌吻了呢?",
        "有一次和男友吵架了在电话里哭,闺蜜来安慰我,突然,他盯着我的眼睛看。冒出一句:“你的睫毛膏用的什么牌子的,这么哭成这B样,都没掉”。我真是气打不一处来,电话一扔也不哭了。",
        "昨天因为一件事骂儿子,说你妈妈是猪,你也是头猪。儿子却反过来说我:爸爸你怎么这么衰,娶了一头猪,还生了一只猪!你说你这熊孩子,这是不是找打。",
      ];
      let index = Math.floor(Math.random() * 4);
      res.send(arr[index]);
    });
    app.listen(4399, () => {
      console.log("服务器开启了...");
    });
    로그인 후 복사


    express 구현 get 매개변수가 있는 인터페이스

    const express = require("express");
    const app = express();
    
    app.get("/getNickName", function (req, res) {
      // 要接收前端传递过来的参数(英雄名)
      console.log(req.query);
      // 处理
      let heroNickName = "";
      switch (req.query.heroName) {
        case "提莫":
          heroNickName = "迅捷斥候";
          break;
        case "李青":
          heroNickName = "盲僧";
          break;
        case "盖伦":
          heroNickName = "德玛西亚之力";
          break;
        case "亚索":
          heroNickName = "疾风剑豪";
          break;
        case "阿狸":
          heroNickName = "九尾妖狐";
          break;
        default:
          heroNickName = "该英雄不存在";
          break;
      }
      res.send(heroNickName);
    });
    app.listen(4399, () => {
      console.log("服务器开启了...");
    });
    로그인 후 복사
간단한 게시 인터페이스 구현

const express = require("express");
const app = express();

app.post("/sb", function (req, res) {
  res.send("sb,这是一个post接口");
});
app.listen(4399, () => {
  console.log("服务器开启了...");
});
로그인 후 복사

매개변수가 있는 게시 인터페이스 구현

/**
 * 接口:用户登录
 * 请求地址:/login
 * 请求方式:post
 * 请求参数:username       password
 *          登录账号/用户名  用户密码
 * 返回值:登录成功/登录失败
 */
const express = require("express");
var bodyParser = require("body-parser");

// 创建服务器
const app = express();

// parse application/x-www-form-urlencoded
app.use(bodyParser.urlencoded({ extended: false }));

app.post("/login", function (req, res) {
  // 接收用户传递过来的用户名和密码

  // 由于是post方式传递过来的参数,所以用req.query这种方式拿不到
  // console.log(req)
  // console.log(req.query)

  // 要想获取到通过post传递过来的参数,就要使用第三方模块:body-parser
  // 就用req.body来获取参数
  console.log(req.body); // { username: 'admin', password: '888888' }

  // 处理
  if (req.body.username == "admin" && req.body.password == "888888") {
    res.send({
      code: 200,
      msg: "登录成功",
    });
  } else {
    res.send({
      code: 400,
      msg: "账号密码不对",
    });
  }
});
app.listen(4399, () => {
  console.log("服务器开启了...");
});
로그인 후 복사

반환 값이 json 형식 문자열인 인터페이스 반환

/***
 * 接口:获取一个实物
 * 接口地址:/getFood
 * 请求方式:get
 * 返回数据:json
 */

// 导包
const express = require("express");

// 创建服务器
const app = express();

// 写接口
app.get("/getFood", (req, res) => {
  // 逻辑处理

  // 要去设置一个请求头
  res.setHeader("Content-Type", "application/json");
  // 返回一个json格式的字符串
  res.send(`
        {
            "foodName":"红烧肉",
            "price":50,
            "description":"好吃,油而不腻"
        }
    `);
});

// 开启服务器
app.listen(4399, () => {
  console.log("服务器开启了...");
});
로그인 후 복사

게시물 쓰기 파일 매개변수 전달 방법 인터페이스

/**
 * 接口:登录接口
 * 接口地址:/register
 * 请求方式:post
 * 接口参数:username password
 * 返回值:登录成功/登录失败
 */

// 导包
const express = require("express");
const multer = require("multer");
const upload = multer({ dest: "uploads/" });

// 创建服务器
const app = express();

// 写接口
app.post("/register", upload.single("usericon"), (req, res) => {
  // 传递过来的username,password,usericon如何接收?
  // 需要使用到一个第三方模块 multer

  // req.file is the `avatar` file // 传过来的文件,参数名用usericon
  // req.body will hold the text fields, if there were any // 一起传过来的文本保存在req.body中

  console.log(req.file);
  console.log(req.body);

  res.send("sb");
});

// 开启服务器
app.listen(4399, () => {
  console.log("服务器开启了...");
});
로그인 후 복사
더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 비디오

를 방문하세요! !

위 내용은 Nodejs+express 모듈을 사용하여 서버를 만드는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿