Node.js 쿼리스트링 조건문(5)

Sunny Kim·2020년 9월 28일
0

node.js

목록 보기
6/16

쿼리스트링이 없는 메인페이지 내용 설정

메인 페이지에 아무 내용을 설정해주지 않았기 때문에, undefinde라고 나옴. 주소가 쿼리스트링을 가지고 있지 않더라도 내용을 설정해줄 수 있는 방법이 있다. if조건문을 걸어서 해결해주면 된다.

var http = require('http');
var fs = require('fs');
var url = require('url'); // url이라는 모듈을 사용할 것이다라고 알려주는 것

var app = http.createServer(function(request,response){
    var _url = request.url; // 위의 모듈 url과 구별하기 위해 _url로 변경
    var queryData = url.parse(_url, true).query;
    var pathname = url.parse(_url, true).pathname;

    console.log(pathname);
    // if(_url == '/'){
    //   title='Welcome';
    // }
    // if(_url == '/favicon.ico'){
    //   return response.writeHead(404);
    // }
    response.writeHead(200);
    //쿼리스트링에 따라 파일명 생성
    if(pathname === '/'){
      if(queryData.id === undefined){ // 쿼리스트링이 없는 경우 출력될 내용
        fs.readFile(`data/${queryData.id}`, 'utf-8', function(err, data){
          var title = 'Welcome';
          var data = 'Hello, Node.js';
          var template = `
          <!doctype html>
          <html>
          <head>
            <title>WEB1 - ${title}</title>
            <meta charset="utf-8">
          </head>
          <body>
            <h1><a href="/">WEB</a></h1>
            <ol>
              <li><a href="/?id=HTML">HTML</a></li>
              <li><a href="/?id=CSS">CSS</a></li>
              <li><a href="/?id=JAVASCRIPT">JavaScript</a></li>
            </ol>
            <h2>${title}</h2>
            <p>${data}</p>
          </body>
          </html>
          `;
          response.writeHead(200); // 200은 성공
          response.end(template); 
        });
      }else{
        fs.readFile(`data/${queryData.id}`, 'utf-8', function(err, data){
          var title = queryData.id;
          var template = `
          <!doctype html>
          <html>
          <head>
            <title>WEB1 - ${title}</title>
            <meta charset="utf-8">
          </head>
          <body>
            <h1><a href="/">WEB</a></h1>
            <ol>
              <li><a href="/?id=HTML">HTML</a></li>
              <li><a href="/?id=CSS">CSS</a></li>
              <li><a href="/?id=JAVASCRIPT">JavaScript</a></li>
            </ol>
            <h2>${title}</h2>
            <p>${data}</p>
          </body>
          </html>
          `;
          response.writeHead(200); // 200은 성공
          response.end(template); 
        });
      }
  }else{
    response.writeHead(400);
    response.end('Not found'); 
  }
});
app.listen(3000);

  • 항상 노드를 실행할 때는 해당 경로로 이동해서 node 파일명으로 실행
profile
풀스택개발자를 목표로 공부중

0개의 댓글