commit
3279e939ce
@ -0,0 +1,25 @@ |
|||||||
|
# Logs |
||||||
|
logs |
||||||
|
*.log |
||||||
|
npm-debug.log* |
||||||
|
yarn-debug.log* |
||||||
|
yarn-error.log* |
||||||
|
pnpm-debug.log* |
||||||
|
lerna-debug.log* |
||||||
|
|
||||||
|
node_modules |
||||||
|
dist |
||||||
|
dist.* |
||||||
|
dist-ssr |
||||||
|
*.local |
||||||
|
|
||||||
|
# Editor directories and files |
||||||
|
.vscode/* |
||||||
|
!.vscode/extensions.json |
||||||
|
.idea |
||||||
|
.DS_Store |
||||||
|
*.suo |
||||||
|
*.ntvs* |
||||||
|
*.njsproj |
||||||
|
*.sln |
||||||
|
*.sw? |
@ -0,0 +1,55 @@ |
|||||||
|
const Koa = require('koa') |
||||||
|
const app = new Koa() |
||||||
|
const views = require('koa-views') |
||||||
|
const json = require('koa-json') |
||||||
|
const onerror = require('koa-onerror') |
||||||
|
const logger = require('koa-logger') |
||||||
|
const {koaBody} = require('koa-body')// 支持form-data,支持文件,不支持x-www-form-urlencoded,不可同时使用,
|
||||||
|
|
||||||
|
const index = require('./routes/index') |
||||||
|
const users = require('./routes/users') |
||||||
|
|
||||||
|
// error handler
|
||||||
|
onerror(app) |
||||||
|
|
||||||
|
// middlewares
|
||||||
|
app.use(json()) |
||||||
|
app.use(logger()) |
||||||
|
app.use(require('koa-static')(__dirname + '/public')) |
||||||
|
|
||||||
|
app.use(views(__dirname + '/views', { |
||||||
|
extension: 'pug' |
||||||
|
})) |
||||||
|
|
||||||
|
// logger
|
||||||
|
app.use(async (ctx, next) => { |
||||||
|
const start = new Date() |
||||||
|
await next() |
||||||
|
const ms = new Date() - start |
||||||
|
console.log(`${ctx.method} ${ctx.url} - ${ms}ms`) |
||||||
|
}) |
||||||
|
app.use(koaBody({ |
||||||
|
multipart: true, // 支持文件上传
|
||||||
|
encoding: 'gzip', |
||||||
|
strict: false,// 参数:如果启用,则不解析GET,HEAD,DELETE请求,默认为true
|
||||||
|
formidable: { |
||||||
|
// uploadDir:path.join(__dirname,'public/upload/'), // 设置文件上传目录
|
||||||
|
keepExtensions: true, // 保持文件的后缀
|
||||||
|
maxFieldsSize: 10 * 1024 * 1024, // 文件上传大小
|
||||||
|
// onFileBegin:(name,file) => { // 文件上传前的设置
|
||||||
|
// // console.log(`name: ${name}`);
|
||||||
|
// // console.log(file);
|
||||||
|
// },
|
||||||
|
} |
||||||
|
})); |
||||||
|
|
||||||
|
// routes
|
||||||
|
app.use(index.routes(), index.allowedMethods()) |
||||||
|
app.use(users.routes(), users.allowedMethods()) |
||||||
|
|
||||||
|
// error-handling
|
||||||
|
app.on('error', (err, ctx) => { |
||||||
|
console.error('server error', err, ctx) |
||||||
|
}); |
||||||
|
|
||||||
|
module.exports = app |
@ -0,0 +1,90 @@ |
|||||||
|
#!/usr/bin/env node |
||||||
|
|
||||||
|
/** |
||||||
|
* Module dependencies. |
||||||
|
*/ |
||||||
|
|
||||||
|
var app = require('../app'); |
||||||
|
var debug = require('debug')('demo:server'); |
||||||
|
var http = require('http'); |
||||||
|
|
||||||
|
/** |
||||||
|
* Get port from environment and store in Express. |
||||||
|
*/ |
||||||
|
|
||||||
|
var port = normalizePort(process.env.PORT || '3000'); |
||||||
|
// app.set('port', port); |
||||||
|
|
||||||
|
/** |
||||||
|
* Create HTTP server. |
||||||
|
*/ |
||||||
|
|
||||||
|
var server = http.createServer(app.callback()); |
||||||
|
|
||||||
|
/** |
||||||
|
* Listen on provided port, on all network interfaces. |
||||||
|
*/ |
||||||
|
|
||||||
|
server.listen(port); |
||||||
|
server.on('error', onError); |
||||||
|
server.on('listening', onListening); |
||||||
|
|
||||||
|
/** |
||||||
|
* Normalize a port into a number, string, or false. |
||||||
|
*/ |
||||||
|
|
||||||
|
function normalizePort(val) { |
||||||
|
var port = parseInt(val, 10); |
||||||
|
|
||||||
|
if (isNaN(port)) { |
||||||
|
// named pipe |
||||||
|
return val; |
||||||
|
} |
||||||
|
|
||||||
|
if (port >= 0) { |
||||||
|
// port number |
||||||
|
return port; |
||||||
|
} |
||||||
|
|
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Event listener for HTTP server "error" event. |
||||||
|
*/ |
||||||
|
|
||||||
|
function onError(error) { |
||||||
|
if (error.syscall !== 'listen') { |
||||||
|
throw error; |
||||||
|
} |
||||||
|
|
||||||
|
var bind = typeof port === 'string' |
||||||
|
? 'Pipe ' + port |
||||||
|
: 'Port ' + port; |
||||||
|
|
||||||
|
// handle specific listen errors with friendly messages |
||||||
|
switch (error.code) { |
||||||
|
case 'EACCES': |
||||||
|
console.error(bind + ' requires elevated privileges'); |
||||||
|
process.exit(1); |
||||||
|
break; |
||||||
|
case 'EADDRINUSE': |
||||||
|
console.error(bind + ' is already in use'); |
||||||
|
process.exit(1); |
||||||
|
break; |
||||||
|
default: |
||||||
|
throw error; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* Event listener for HTTP server "listening" event. |
||||||
|
*/ |
||||||
|
|
||||||
|
function onListening() { |
||||||
|
var addr = server.address(); |
||||||
|
var bind = typeof addr === 'string' |
||||||
|
? 'pipe ' + addr |
||||||
|
: 'port ' + addr.port; |
||||||
|
debug('Listening on ' + bind); |
||||||
|
} |
@ -0,0 +1,27 @@ |
|||||||
|
{ |
||||||
|
"name": "md5file", |
||||||
|
"version": "0.1.0", |
||||||
|
"private": true, |
||||||
|
"scripts": { |
||||||
|
"start": "node bin/www", |
||||||
|
"dev": "node_modules\\.bin\\nodemon bin\\www", |
||||||
|
"prd": "pm2 start bin/www", |
||||||
|
"test": "echo \"Error: no test specified\" && exit 1" |
||||||
|
}, |
||||||
|
"dependencies": { |
||||||
|
"debug": "^4.1.1", |
||||||
|
"koa": "^2.7.0", |
||||||
|
"koa-body": "^6.0.1", |
||||||
|
"koa-convert": "^1.2.0", |
||||||
|
"koa-json": "^2.0.2", |
||||||
|
"koa-logger": "^3.2.0", |
||||||
|
"koa-onerror": "^4.1.0", |
||||||
|
"koa-router": "^7.4.0", |
||||||
|
"koa-static": "^5.0.0", |
||||||
|
"koa-views": "^6.2.0", |
||||||
|
"pug": "^2.0.3" |
||||||
|
}, |
||||||
|
"devDependencies": { |
||||||
|
"nodemon": "^1.19.1" |
||||||
|
} |
||||||
|
} |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,8 @@ |
|||||||
|
body { |
||||||
|
padding: 50px; |
||||||
|
font: 14px "Lucida Grande", Helvetica, Arial, sans-serif; |
||||||
|
} |
||||||
|
|
||||||
|
a { |
||||||
|
color: #00B7FF; |
||||||
|
} |
@ -0,0 +1,19 @@ |
|||||||
|
const router = require('koa-router')() |
||||||
|
|
||||||
|
router.get('/', async (ctx, next) => { |
||||||
|
await ctx.render('index', { |
||||||
|
title: 'Hello Koa 2!' |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
router.get('/string', async (ctx, next) => { |
||||||
|
ctx.body = 'koa2 string' |
||||||
|
}) |
||||||
|
|
||||||
|
router.get('/json', async (ctx, next) => { |
||||||
|
ctx.body = { |
||||||
|
title: 'koa2 json' |
||||||
|
} |
||||||
|
}) |
||||||
|
|
||||||
|
module.exports = router |
@ -0,0 +1,19 @@ |
|||||||
|
const router = require('koa-router')() |
||||||
|
|
||||||
|
router.get('/', async (ctx, next) => { |
||||||
|
await ctx.render('index', { |
||||||
|
title: 'Hello Koa 2!' |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
router.get('/string', async (ctx, next) => { |
||||||
|
ctx.body = 'koa2 string' |
||||||
|
}) |
||||||
|
|
||||||
|
router.get('/json', async (ctx, next) => { |
||||||
|
ctx.body = { |
||||||
|
title: 'koa2 json' |
||||||
|
} |
||||||
|
}) |
||||||
|
|
||||||
|
module.exports = router |
@ -0,0 +1,13 @@ |
|||||||
|
const router = require('koa-router')() |
||||||
|
|
||||||
|
router.prefix('/users') |
||||||
|
|
||||||
|
router.get('/', function (ctx, next) { |
||||||
|
ctx.body = 'this is a users response!' |
||||||
|
}) |
||||||
|
|
||||||
|
router.get('/bar', function (ctx, next) { |
||||||
|
ctx.body = 'this is a users/bar response' |
||||||
|
}) |
||||||
|
|
||||||
|
module.exports = router |
@ -0,0 +1,6 @@ |
|||||||
|
extends layout |
||||||
|
|
||||||
|
block content |
||||||
|
h1= message |
||||||
|
h2= error.status |
||||||
|
pre #{error.stack} |
@ -0,0 +1,5 @@ |
|||||||
|
extends layout |
||||||
|
|
||||||
|
block content |
||||||
|
h1= title |
||||||
|
p Welcome to #{title} |
@ -0,0 +1,7 @@ |
|||||||
|
doctype html |
||||||
|
html |
||||||
|
head |
||||||
|
title= title |
||||||
|
link(rel='stylesheet', href='/stylesheets/style.css') |
||||||
|
body |
||||||
|
block content |
Loading…
Reference in new issue