Showing
26 changed files
with
641 additions
and
0 deletions
08_Node.js/ex01/app01.js
0 → 100644
| 1 | +"use strict" | ||
| 2 | + | ||
| 3 | +var http = require('http'); | ||
| 4 | +var server = http.createServer(function(req, res) { | ||
| 5 | + res.writeHeader(200, {"Content-Type": "text/plain"}); | ||
| 6 | + res.write("Hello World"); | ||
| 7 | + res.end(); | ||
| 8 | +}); | ||
| 9 | + | ||
| 10 | +server.listen(3000, function() { | ||
| 11 | + console.log("Sever listeining on http://localhost:3000"); | ||
| 12 | +}); |
08_Node.js/ex01/app02.js
0 → 100644
| 1 | +"use strict" | ||
| 2 | + | ||
| 3 | +var http = require('http'), | ||
| 4 | + path = require('path'), | ||
| 5 | + url = require('url'), | ||
| 6 | + fs = require('fs'); | ||
| 7 | + | ||
| 8 | +var DOCUMENT_ROOT = "../../05_CSS/"; | ||
| 9 | +var server = http.createServer(function(req, res) { | ||
| 10 | + var reqPath = url.parse(req.url).pathname; | ||
| 11 | + if (reqPath == "/") { | ||
| 12 | + reqPath = "ex01.html"; | ||
| 13 | + } | ||
| 14 | + var fullPath = path.join(process.cwd(), DOCUMENT_ROOT, reqPath); | ||
| 15 | + fs.readFile(fullPath, "binary", function(err, file) { | ||
| 16 | + if(err) { | ||
| 17 | + if (err.code == "ENOENT") { | ||
| 18 | + console.log("SEND 404 for " + req.url); | ||
| 19 | + res.writeHeader(404, {"Content-Type": "text/html"}); | ||
| 20 | + res.write("<h1>Not found</h1>"); | ||
| 21 | + res.end(); | ||
| 22 | + } else { | ||
| 23 | + console.error("Error", err); | ||
| 24 | + res.writeHeader(500, {"Content-Type": "text/plain"}); | ||
| 25 | + res.write(err + "\n"); | ||
| 26 | + res.end(); | ||
| 27 | + } | ||
| 28 | + } else{ | ||
| 29 | + console.log("SEND 200 for " + req.url); | ||
| 30 | + res.writeHeader(200); | ||
| 31 | + res.write(file, "binary"); | ||
| 32 | + res.end(); | ||
| 33 | + } | ||
| 34 | + }); | ||
| 35 | +}); | ||
| 36 | + | ||
| 37 | +server.listen(3000, function() { | ||
| 38 | + console.log("Sever listeining on http://localhost:3000"); | ||
| 39 | +}); | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
08_Node.js/ex01/app03/.gitignore
0 → 100644
| 1 | +# Logs | ||
| 2 | +logs | ||
| 3 | +*.log | ||
| 4 | + | ||
| 5 | +# Runtime data | ||
| 6 | +pids | ||
| 7 | +*.pid | ||
| 8 | +*.seed | ||
| 9 | + | ||
| 10 | +# Directory for instrumented libs generated by jscoverage/JSCover | ||
| 11 | +lib-cov | ||
| 12 | + | ||
| 13 | +# Coverage directory used by tools like istanbul | ||
| 14 | +coverage | ||
| 15 | + | ||
| 16 | +# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) | ||
| 17 | +.grunt | ||
| 18 | + | ||
| 19 | +# node-waf configuration | ||
| 20 | +.lock-wscript | ||
| 21 | + | ||
| 22 | +# Compiled binary addons (http://nodejs.org/api/addons.html) | ||
| 23 | +build/Release | ||
| 24 | + | ||
| 25 | +# Dependency directory | ||
| 26 | +# https://docs.npmjs.com/cli/shrinkwrap#caveats | ||
| 27 | +node_modules | ||
| 28 | + | ||
| 29 | +# Debug log from npm | ||
| 30 | +npm-debug.log |
08_Node.js/ex01/app03/app.js
0 → 100644
| 1 | +var express = require('express'); | ||
| 2 | +var path = require('path'); | ||
| 3 | +var favicon = require('serve-favicon'); | ||
| 4 | +var logger = require('morgan'); | ||
| 5 | +var cookieParser = require('cookie-parser'); | ||
| 6 | +var bodyParser = require('body-parser'); | ||
| 7 | + | ||
| 8 | +var index = require('./routes/index'); | ||
| 9 | +var users = require('./routes/users'); | ||
| 10 | + | ||
| 11 | +var app = express(); | ||
| 12 | + | ||
| 13 | +// view engine setup | ||
| 14 | +app.set('views', path.join(__dirname, 'views')); | ||
| 15 | +app.set('view engine', 'ejs'); | ||
| 16 | + | ||
| 17 | +// uncomment after placing your favicon in /public | ||
| 18 | +//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); | ||
| 19 | +app.use(logger('dev')); | ||
| 20 | +app.use(bodyParser.json()); | ||
| 21 | +app.use(bodyParser.urlencoded({ extended: false })); | ||
| 22 | +app.use(cookieParser()); | ||
| 23 | +app.use(require('node-sass-middleware')({ | ||
| 24 | + src: path.join(__dirname, 'public'), | ||
| 25 | + dest: path.join(__dirname, 'public'), | ||
| 26 | + indentedSyntax: true, | ||
| 27 | + sourceMap: true | ||
| 28 | +})); | ||
| 29 | +app.use(express.static(path.join(__dirname, 'public'))); | ||
| 30 | + | ||
| 31 | +app.use('/', index); | ||
| 32 | +app.use('/users', users); | ||
| 33 | + | ||
| 34 | +// catch 404 and forward to error handler | ||
| 35 | +app.use(function(req, res, next) { | ||
| 36 | + var err = new Error('Not Found'); | ||
| 37 | + err.status = 404; | ||
| 38 | + next(err); | ||
| 39 | +}); | ||
| 40 | + | ||
| 41 | +// error handler | ||
| 42 | +app.use(function(err, req, res, next) { | ||
| 43 | + // set locals, only providing error in development | ||
| 44 | + res.locals.message = err.message; | ||
| 45 | + res.locals.error = req.app.get('env') === 'development' ? err : {}; | ||
| 46 | + | ||
| 47 | + // render the error page | ||
| 48 | + res.status(err.status || 500); | ||
| 49 | + res.render('error'); | ||
| 50 | +}); | ||
| 51 | + | ||
| 52 | +module.exports = app; |
08_Node.js/ex01/app03/bin/www
0 → 100644
| 1 | +#!/usr/bin/env node | ||
| 2 | + | ||
| 3 | +/** | ||
| 4 | + * Module dependencies. | ||
| 5 | + */ | ||
| 6 | + | ||
| 7 | +var app = require('../app'); | ||
| 8 | +var debug = require('debug')('app03:server'); | ||
| 9 | +var http = require('http'); | ||
| 10 | + | ||
| 11 | +/** | ||
| 12 | + * Get port from environment and store in Express. | ||
| 13 | + */ | ||
| 14 | + | ||
| 15 | +var port = normalizePort(process.env.PORT || '3000'); | ||
| 16 | +app.set('port', port); | ||
| 17 | + | ||
| 18 | +/** | ||
| 19 | + * Create HTTP server. | ||
| 20 | + */ | ||
| 21 | + | ||
| 22 | +var server = http.createServer(app); | ||
| 23 | + | ||
| 24 | +/** | ||
| 25 | + * Listen on provided port, on all network interfaces. | ||
| 26 | + */ | ||
| 27 | + | ||
| 28 | +server.listen(port); | ||
| 29 | +server.on('error', onError); | ||
| 30 | +server.on('listening', onListening); | ||
| 31 | + | ||
| 32 | +/** | ||
| 33 | + * Normalize a port into a number, string, or false. | ||
| 34 | + */ | ||
| 35 | + | ||
| 36 | +function normalizePort(val) { | ||
| 37 | + var port = parseInt(val, 10); | ||
| 38 | + | ||
| 39 | + if (isNaN(port)) { | ||
| 40 | + // named pipe | ||
| 41 | + return val; | ||
| 42 | + } | ||
| 43 | + | ||
| 44 | + if (port >= 0) { | ||
| 45 | + // port number | ||
| 46 | + return port; | ||
| 47 | + } | ||
| 48 | + | ||
| 49 | + return false; | ||
| 50 | +} | ||
| 51 | + | ||
| 52 | +/** | ||
| 53 | + * Event listener for HTTP server "error" event. | ||
| 54 | + */ | ||
| 55 | + | ||
| 56 | +function onError(error) { | ||
| 57 | + if (error.syscall !== 'listen') { | ||
| 58 | + throw error; | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + var bind = typeof port === 'string' | ||
| 62 | + ? 'Pipe ' + port | ||
| 63 | + : 'Port ' + port; | ||
| 64 | + | ||
| 65 | + // handle specific listen errors with friendly messages | ||
| 66 | + switch (error.code) { | ||
| 67 | + case 'EACCES': | ||
| 68 | + console.error(bind + ' requires elevated privileges'); | ||
| 69 | + process.exit(1); | ||
| 70 | + break; | ||
| 71 | + case 'EADDRINUSE': | ||
| 72 | + console.error(bind + ' is already in use'); | ||
| 73 | + process.exit(1); | ||
| 74 | + break; | ||
| 75 | + default: | ||
| 76 | + throw error; | ||
| 77 | + } | ||
| 78 | +} | ||
| 79 | + | ||
| 80 | +/** | ||
| 81 | + * Event listener for HTTP server "listening" event. | ||
| 82 | + */ | ||
| 83 | + | ||
| 84 | +function onListening() { | ||
| 85 | + var addr = server.address(); | ||
| 86 | + var bind = typeof addr === 'string' | ||
| 87 | + ? 'pipe ' + addr | ||
| 88 | + : 'port ' + addr.port; | ||
| 89 | + debug('Listening on ' + bind); | ||
| 90 | +} |
08_Node.js/ex01/app03/package.json
0 → 100644
| 1 | +{ | ||
| 2 | + "name": "app03", | ||
| 3 | + "version": "0.0.0", | ||
| 4 | + "private": true, | ||
| 5 | + "scripts": { | ||
| 6 | + "start": "node ./bin/www" | ||
| 7 | + }, | ||
| 8 | + "dependencies": { | ||
| 9 | + "body-parser": "~1.16.0", | ||
| 10 | + "cookie-parser": "~1.4.3", | ||
| 11 | + "debug": "~2.6.0", | ||
| 12 | + "ejs": "~2.5.5", | ||
| 13 | + "express": "~4.14.1", | ||
| 14 | + "morgan": "~1.7.0", | ||
| 15 | + "node-sass-middleware": "0.9.8", | ||
| 16 | + "serve-favicon": "~2.3.2" | ||
| 17 | + } | ||
| 18 | +} |
| 1 | +{ | ||
| 2 | + "version": 3, | ||
| 3 | + "file": "style.css", | ||
| 4 | + "sources": [ | ||
| 5 | + "style.sass" | ||
| 6 | + ], | ||
| 7 | + "mappings": "AAAA,AAAA,IAAI,CAAC;EACH,OAAO,EAAE,IAAK;EACd,IAAI,EAAE,kDAAmD,GAAG;;AAE9D,AAAA,CAAC,CAAC;EACA,KAAK,EAAE,OAAQ,GAAG", | ||
| 8 | + "names": [] | ||
| 9 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
08_Node.js/ex01/app03/routes/index.js
0 → 100644
08_Node.js/ex01/app03/routes/users.js
0 → 100644
08_Node.js/ex01/app03/views/error.ejs
0 → 100644
08_Node.js/ex01/app03/views/index.ejs
0 → 100644
08_Node.js/ex01/readme.md
0 → 100644
| 1 | +# Node.js를 이용한 간단한 웹서버 구축 | ||
| 2 | + | ||
| 3 | +## 실행 방법 | ||
| 4 | + | ||
| 5 | +1. Hello World 웹 서버 | ||
| 6 | + ``` | ||
| 7 | + node app01.js | ||
| 8 | + ``` | ||
| 9 | + | ||
| 10 | +2. 03 실습의 내용을 제공하는 웹서버 | ||
| 11 | + ``` | ||
| 12 | + node app02.js | ||
| 13 | + ``` | ||
| 14 | + | ||
| 15 | +## TIP | ||
| 16 | +1. 코드를 수정할 때 마다 서버를 새로 띄워야 해서 불편하다면 nodemon을 설치하고 nodemon으로 서버를 실행할 수 있습니다. 소스 코드가 수정되면 자동으로 서버가 다시 시작됩니다. | ||
| 17 | + ``` | ||
| 18 | + npm install --global nodemon | ||
| 19 | + | ||
| 20 | + nodemon app02.js | ||
| 21 | + ``` |
08_Node.js/ex02/app03/.gitignore
0 → 100644
| 1 | +# Logs | ||
| 2 | +logs | ||
| 3 | +*.log | ||
| 4 | + | ||
| 5 | +# Runtime data | ||
| 6 | +pids | ||
| 7 | +*.pid | ||
| 8 | +*.seed | ||
| 9 | + | ||
| 10 | +# Directory for instrumented libs generated by jscoverage/JSCover | ||
| 11 | +lib-cov | ||
| 12 | + | ||
| 13 | +# Coverage directory used by tools like istanbul | ||
| 14 | +coverage | ||
| 15 | + | ||
| 16 | +# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) | ||
| 17 | +.grunt | ||
| 18 | + | ||
| 19 | +# node-waf configuration | ||
| 20 | +.lock-wscript | ||
| 21 | + | ||
| 22 | +# Compiled binary addons (http://nodejs.org/api/addons.html) | ||
| 23 | +build/Release | ||
| 24 | + | ||
| 25 | +# Dependency directory | ||
| 26 | +# https://www.npmjs.org/doc/misc/npm-faq.html#should-i-check-my-node_modules-folder-into-git- | ||
| 27 | +node_modules | ||
| 28 | + | ||
| 29 | +# Debug log from npm | ||
| 30 | +npm-debug.log |
08_Node.js/ex02/app03/app.js
0 → 100644
| 1 | +var express = require('express'); | ||
| 2 | +var path = require('path'); | ||
| 3 | +var favicon = require('serve-favicon'); | ||
| 4 | +var logger = require('morgan'); | ||
| 5 | +var cookieParser = require('cookie-parser'); | ||
| 6 | +var bodyParser = require('body-parser'); | ||
| 7 | + | ||
| 8 | +var routes = require('./routes/index'); | ||
| 9 | +var users = require('./routes/users'); | ||
| 10 | + | ||
| 11 | +var app = express(); | ||
| 12 | + | ||
| 13 | +// view engine setup | ||
| 14 | +app.set('views', path.join(__dirname, 'views')); | ||
| 15 | +app.set('view engine', 'ejs'); | ||
| 16 | + | ||
| 17 | +// uncomment after placing your favicon in /public | ||
| 18 | +//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); | ||
| 19 | +app.use(logger('dev')); | ||
| 20 | +app.use(bodyParser.json()); | ||
| 21 | +app.use(bodyParser.urlencoded({ extended: false })); | ||
| 22 | +app.use(cookieParser()); | ||
| 23 | +app.use(require('node-sass-middleware')({ | ||
| 24 | + src: path.join(__dirname, 'public'), | ||
| 25 | + dest: path.join(__dirname, 'public'), | ||
| 26 | + indentedSyntax: true, | ||
| 27 | + sourceMap: true | ||
| 28 | +})); | ||
| 29 | +app.use(express.static(path.join(__dirname, 'public'))); | ||
| 30 | + | ||
| 31 | +app.use('/', routes); | ||
| 32 | +app.use('/users', users); | ||
| 33 | + | ||
| 34 | +// catch 404 and forward to error handler | ||
| 35 | +app.use(function(req, res, next) { | ||
| 36 | + var err = new Error('Not Found'); | ||
| 37 | + err.status = 404; | ||
| 38 | + next(err); | ||
| 39 | +}); | ||
| 40 | + | ||
| 41 | +// error handlers | ||
| 42 | + | ||
| 43 | +// development error handler | ||
| 44 | +// will print stacktrace | ||
| 45 | +if (app.get('env') === 'development') { | ||
| 46 | + app.use(function(err, req, res, next) { | ||
| 47 | + res.status(err.status || 500); | ||
| 48 | + res.render('error', { | ||
| 49 | + message: err.message, | ||
| 50 | + error: err | ||
| 51 | + }); | ||
| 52 | + }); | ||
| 53 | +} | ||
| 54 | + | ||
| 55 | +// production error handler | ||
| 56 | +// no stacktraces leaked to user | ||
| 57 | +app.use(function(err, req, res, next) { | ||
| 58 | + res.status(err.status || 500); | ||
| 59 | + res.render('error', { | ||
| 60 | + message: err.message, | ||
| 61 | + error: {} | ||
| 62 | + }); | ||
| 63 | +}); | ||
| 64 | + | ||
| 65 | + | ||
| 66 | +module.exports = app; |
08_Node.js/ex02/app03/bin/www
0 → 100644
| 1 | +#!/usr/bin/env node | ||
| 2 | + | ||
| 3 | +/** | ||
| 4 | + * Module dependencies. | ||
| 5 | + */ | ||
| 6 | + | ||
| 7 | +var app = require('../app'); | ||
| 8 | +var debug = require('debug')('app03:server'); | ||
| 9 | +var http = require('http'); | ||
| 10 | + | ||
| 11 | +/** | ||
| 12 | + * Get port from environment and store in Express. | ||
| 13 | + */ | ||
| 14 | + | ||
| 15 | +var port = normalizePort(process.env.PORT || '3000'); | ||
| 16 | +app.set('port', port); | ||
| 17 | + | ||
| 18 | +/** | ||
| 19 | + * Create HTTP server. | ||
| 20 | + */ | ||
| 21 | + | ||
| 22 | +var server = http.createServer(app); | ||
| 23 | + | ||
| 24 | +/** | ||
| 25 | + * Listen on provided port, on all network interfaces. | ||
| 26 | + */ | ||
| 27 | + | ||
| 28 | +server.listen(port); | ||
| 29 | +server.on('error', onError); | ||
| 30 | +server.on('listening', onListening); | ||
| 31 | + | ||
| 32 | +/** | ||
| 33 | + * Normalize a port into a number, string, or false. | ||
| 34 | + */ | ||
| 35 | + | ||
| 36 | +function normalizePort(val) { | ||
| 37 | + var port = parseInt(val, 10); | ||
| 38 | + | ||
| 39 | + if (isNaN(port)) { | ||
| 40 | + // named pipe | ||
| 41 | + return val; | ||
| 42 | + } | ||
| 43 | + | ||
| 44 | + if (port >= 0) { | ||
| 45 | + // port number | ||
| 46 | + return port; | ||
| 47 | + } | ||
| 48 | + | ||
| 49 | + return false; | ||
| 50 | +} | ||
| 51 | + | ||
| 52 | +/** | ||
| 53 | + * Event listener for HTTP server "error" event. | ||
| 54 | + */ | ||
| 55 | + | ||
| 56 | +function onError(error) { | ||
| 57 | + if (error.syscall !== 'listen') { | ||
| 58 | + throw error; | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + var bind = typeof port === 'string' | ||
| 62 | + ? 'Pipe ' + port | ||
| 63 | + : 'Port ' + port; | ||
| 64 | + | ||
| 65 | + // handle specific listen errors with friendly messages | ||
| 66 | + switch (error.code) { | ||
| 67 | + case 'EACCES': | ||
| 68 | + console.error(bind + ' requires elevated privileges'); | ||
| 69 | + process.exit(1); | ||
| 70 | + break; | ||
| 71 | + case 'EADDRINUSE': | ||
| 72 | + console.error(bind + ' is already in use'); | ||
| 73 | + process.exit(1); | ||
| 74 | + break; | ||
| 75 | + default: | ||
| 76 | + throw error; | ||
| 77 | + } | ||
| 78 | +} | ||
| 79 | + | ||
| 80 | +/** | ||
| 81 | + * Event listener for HTTP server "listening" event. | ||
| 82 | + */ | ||
| 83 | + | ||
| 84 | +function onListening() { | ||
| 85 | + var addr = server.address(); | ||
| 86 | + var bind = typeof addr === 'string' | ||
| 87 | + ? 'pipe ' + addr | ||
| 88 | + : 'port ' + addr.port; | ||
| 89 | + debug('Listening on ' + bind); | ||
| 90 | +} |
08_Node.js/ex02/app03/package.json
0 → 100644
| 1 | +{ | ||
| 2 | + "name": "app03", | ||
| 3 | + "version": "0.0.0", | ||
| 4 | + "private": true, | ||
| 5 | + "scripts": { | ||
| 6 | + "start": "node ./bin/www" | ||
| 7 | + }, | ||
| 8 | + "dependencies": { | ||
| 9 | + "body-parser": "~1.13.2", | ||
| 10 | + "cookie-parser": "~1.3.5", | ||
| 11 | + "debug": "~2.2.0", | ||
| 12 | + "ejs": "~2.3.3", | ||
| 13 | + "express": "~4.13.1", | ||
| 14 | + "morgan": "~1.6.1", | ||
| 15 | + "node-sass-middleware": "0.8.0", | ||
| 16 | + "serve-favicon": "~2.3.0" | ||
| 17 | + } | ||
| 18 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
| 1 | +{ | ||
| 2 | + "version": 3, | ||
| 3 | + "file": "style.css", | ||
| 4 | + "sources": [ | ||
| 5 | + "style.sass" | ||
| 6 | + ], | ||
| 7 | + "sourcesContent": [], | ||
| 8 | + "mappings": "AAAA,IAAI,CAAC;EACH,OAAO,EAAE,IAAK;EACd,IAAI,EAAE,kDAAmD,GAFrD;;AAIN,CAAC,CAAC;EACA,KAAK,EAAE,OAAQ,GADd", | ||
| 9 | + "names": [] | ||
| 10 | +} | ||
| ... | \ No newline at end of file | ... | \ No newline at end of file |
08_Node.js/ex02/app03/routes/index.js
0 → 100644
08_Node.js/ex02/app03/routes/users.js
0 → 100644
08_Node.js/ex02/app03/views/error.ejs
0 → 100644
08_Node.js/ex02/app03/views/index.ejs
0 → 100644
08_Node.js/ex02/readme.md
0 → 100644
| 1 | +# 실습하는 법 | ||
| 2 | + | ||
| 3 | +1. npm을 이용하여 express-generator (express app 뼈대를 자동 생성해주는 프로그램)을 설치합니다. | ||
| 4 | + ``` | ||
| 5 | + npm install -g express-generator | ||
| 6 | + ``` | ||
| 7 | + | ||
| 8 | +1. express generator를 이용하여 app을 하나 만듭니다. | ||
| 9 | + ```sh | ||
| 10 | + express -e -c sass --git app03 | ||
| 11 | + # -e: Jade대신 EJS template 엔진을 이용합니다. Jade도 좋지만, 일단은 HTML과 가장 유사한 EJS를 사용해봅시다. | ||
| 12 | + # -c sass: sass나 scss를 사용하려고 합니다. | ||
| 13 | + # --git: git을 사용할 때 편리하도록 .gitignore를 자동으로 생성합니다. | ||
| 14 | + ``` | ||
| 15 | + | ||
| 16 | +1. 디렉토리에 들어가서 파일들을 살펴봅시다. | ||
| 17 | + ``` | ||
| 18 | + cd app03 | ||
| 19 | + atom . | ||
| 20 | +``` | ||
| 21 | + | ||
| 22 | +1. package들을 설치합니다. | ||
| 23 | + ``` | ||
| 24 | + npm install | ||
| 25 | + ``` | ||
| 26 | + | ||
| 27 | +1. 서버를 실행해봅시다. | ||
| 28 | + ``` | ||
| 29 | + nodemon ./bin/www | ||
| 30 | + ``` | ||
| 31 | + | ||
| 32 | +1. 웹브라우져에서 http://localhost:3000 에 접속해봅시다. | ||
| 33 | + | ||
| 34 | +1. 디렉토리 설명 | ||
| 35 | + - app.js: Express 미들웨어들이 설정되어 있습니다. | ||
| 36 | + - routes/: 라우팅 정보, 즉 URL로 들어온 처리를 어떻게 하는지 관리합니다. | ||
| 37 | + - views/: 화면에 출력할 View Template이 들어있습니다. | ||
| 38 | + - public/: static파일로 처리될 image, javascript, stylesheet 등이 있습니다. SCSS를 사용해볼 때도 여기서 해봅니다. | ||
| 39 | + - node_modules: 로컬에 인스톨된 패키지가 있는 곳입니다. 건드리지 맙시다. | ||
| 40 | + | ||
| 41 | +## 참고 | ||
| 42 | + | ||
| 43 | +### npm : Package Manager for Node.js | ||
| 44 | +- 참고: https://docs.npmjs.com/getting-started/what-is-npm | ||
| 45 | + | ||
| 46 | + | ||
| 47 | +1. npm init | ||
| 48 | + - 패키지 관리 시작. 해당 디렉토리에 package.json을 만듭니다. | ||
| 49 | + - Git Bash에서 에러가 나는 경우 윈도우 cmd 창에서 실행하세요. | ||
| 50 | + - 차례로 물어보는 것에 대답하면 package.json 파일이 생깁니다. | ||
| 51 | + | ||
| 52 | +2. npm install | ||
| 53 | + - npm를 이용해 원하는 패키지를 인스톨 합시다. | ||
| 54 | + - 옵션 | ||
| 55 | + - -g (--global)은 global로 인스톨 합니다. 그러면 이 프로그램을 cmd 창에서 유틸리티 처럼 사용할 수 있습니다. | ||
| 56 | + - --save는 이 프로젝트의 로컬에 인스톨 하면서 package.json에 기록되어 추후 npm install 로 한꺼번에 인스톨 할 수 있습니다. | ||
| 57 | + - --save-dev는 save와 유사하지만, 프로젝트의 실행에는 필요없고, 개발 단계에서만 필요하다는 뜻입니다. | ||
| 58 | + - 예 | ||
| 59 | + ``` | ||
| 60 | + npm install -g gulp | ||
| 61 | + npm install --save-dev gulp | ||
| 62 | + npm install --save express | ||
| 63 | + npm install -g express-generator | ||
| 64 | + ``` |
-
Please register or login to post a comment