node.js 입문 #6

학미새🐥·2022년 1월 18일
0
post-custom-banner

콘솔에서의 입력값 전달하기

var args = process.argv;
console.log(args);

node main.js hello

이렇게 위의 코드를 cmd창에서 실행시키는 node main.js와 원하는 입력값 hello를 입력하여
enter버튼을 누르면
console.log(args)를 통해 cmd창에는
['내용1', '내용2', 'hello']와 같은 배열이 output으로 출력된다. 즉, 이와 같은 값이 변수 args 안에 들어있다는 의미이고, 그것은 process.argv을 통해 불러온 값이라는 것을 알 수 있다.

  • 내용1 : node.js 런타임의 위치
  • 내용2 : 실행시킨 파일의 경로

여기서 입력값은 당연히 여러개가 될 수 있다 node main.js hello1 hello2이렇게 공백을 통해 입력값을 여러개 입력하면, 배열은 세번째 자리부터 여러 입력값을 요소로 가진다. [내용1, 내용2, 'hello1', 'hello2']이렇게.
배열의 세번째 요소, 즉 args[2]부터 cmd창에서 입력한 입력값이 담기는 것이다.

존재하지 않는 경로에 접근했을 때 오류메시지 전송하는 기능 구현하기

  • 사용자가 root로 접근했는가? 부터 따지기 (localhost:3000 뒤에 패스가 붙지 않는 것이 root)
console.log(url.parse(_url,true));

이 코드는 주어진 url을 분석해서 쉽게 쓸 수 있도록 object를 출력해주는 코드이다.
이 object중 pathname은 querystring을 제외한 path만을 보여주고, path는 querystring도 포함한 path를 값으로 가진다.
우리는 이 중 pathname의 값을 도출하기 위해

var pathname = url.parse(_rul, true).pathname;

로 경로를 알아내고, 이 경로가 root인지를 판단하기 위해 조건문을 사용한다.

if(pathname === '/') {
  //사용자가 root에 접속했을 시 
} else {
  //사용자가 root로 접속하지 않았을 시 error 메시지
}

서버가 브라우저에게 보내는 코드의 의미

  • 파일 찾기 성공 : 200
  • 파일 찾기 실패 : 404

예제 코드 및 설명 주석
조건문의 형태와 else body를 주목하자

var http = require('http');
var fs = require('fs');
var url = require('url');
 
var app = http.createServer(function(request,response){
    var _url = request.url;
    var queryData = url.parse(_url, true).query;
    var pathname = url.parse(_url, true).pathname;
    var title = queryData.id;
 
  	//사용자가 root로 접속했는지 판단하는 조건문
    if(pathname === '/'){
      fs.readFile(`data/${queryData.id}`, 'utf8', function(err, description){
        var template = `
        <!doctype html>
        <html>
        <head>
          <title>WEB1 - ${title}</title>
          <meta charset="utf-8">
        </head>
        <body>
          <h1><a href="/">WEB</a></h1>
          <ul>
            <li><a href="/?id=HTML">HTML</a></li>
            <li><a href="/?id=CSS">CSS</a></li>
            <li><a href="/?id=JavaScript">JavaScript</a></li>
          </ul>
          <h2>${title}</h2>
          <p>${description}</p>
        </body>
        </html>
        `;
        response.writeHead(200);  //서버가 브라우저에게 파일 찾기 성공을 알리는 코드
        response.end(template);
      });
    } else {    //사용자가 root로 접속하지 않았을 시 실행할 부분
      response.writeHead(404);   //파일을 찾지 못했음을 서버가 브라우저에게 알리는 코드
      response.end('Not found');  //잘못된 접속 시 페이지에 뜰 문구
    }
 
 
 
});
app.listen(3000);

위와 같은 코드를 node main.js로 실행시킨 뒤, localhost:3000으로 접속하면 정상적으로 기존의 웹페이지가 나타나지만, localhost:3000/egeglkwnelk등 잘못된 경로로 접근하면 Not found라고 적혀있는 오류메시지 전달 화면이 나타나게 된다.

profile
뭐든 다해보려는 공대생입니다
post-custom-banner

0개의 댓글