AirJD 焦点
AirJD

没有录音文件
00:00/00:00
加收藏

node.js security(安全的node.js代码) by Maciej Lasyk

发布者 noder
发布于 1451955722983  浏览 6622 关键词 Node.JS, JavaScript, English 
分享到

第1页

Maciej Lasyk, node.js security
Maciej Lasyk
SEConference
Kraków, 2014-05-09
node.js security

第2页

Sysadmin about node.js security?
- not only sysadmin ;)
- node needs thorough understanding of whole infra
- 14+ years of exp software dev. / sysop
- currently “noding” 4 prv & Fedora
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第3页

JS security recap – evals & co
eval() like fncs takes string argument and
evalute those as source code
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第4页

JS security recap – evals & co
eval() like fncs takes string argument and
evalute those as source code
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
srsly – who does that?
Maciej Lasyk, node.js security

第5页

JS security recap – evals & co
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var x = req.body.x;
var y = req.body.y;
var sum = eval(a + "+" + b);
Maciej Lasyk, node.js security

第6页

JS security recap – evals & co
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var x = req.body.x;
var y = req.body.y;
var sum = eval(a + "+" + b);
what if attacker fills 'x' with:

some.super.class.wipe.the.database('now');

LOL :)
Maciej Lasyk, node.js security

第7页

JS security recap – evals & co
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
not only evals:

setInterval(code,2)

setTimeout(code,2)

str = new Function(code)

Chrome CSP denies those also :)
Maciej Lasyk, node.js security

第8页

JS security recap – global namespace pollution
- node.js is single threaded
- all variable values are common
- one could thrtically change bhv of others reqs
- watch out for globals then!
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第9页

JS security recap – global namespace pollution
some very awful example:
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var auth = false;
app.get('/auth', function(req, res) {
    if(legit) {auth = true; res.send("success");
});
 
app.get('/payments-db', function(req, res) {

   if (auth) res.send("legit to see all payments data");

   else res.send("not logged in");
})
 
app.listen(8080);
Maciej Lasyk, node.js security

第10页

JS security recap – global namespace pollution
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
So now imagine..

global namespace pollution + evals & co
Maciej Lasyk, node.js security

第11页

JS security recap – global namespace pollution
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
So now imagine..

global namespace pollution + evals & co
Maciej Lasyk, node.js security

第12页

JS security recap – global namespace pollution
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
So now imagine..

global namespace pollution + evals & co
Watch out who you are hiring
Maciej Lasyk, node.js security

第13页

JS security recap – strict mode
- let's throw all errors!
- declare variables!
- global namespaces help
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第14页

JS security recap – strict mode
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
"use strict";

function testFunction(){
    var testvar = 4;
    return testvar;
}

// This causes a syntax error.
testvar = 5;
Maciej Lasyk, node.js security

第15页

JS security recap – strict mode
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
// This causes a syntax error:

"use strict";
testvar = 5;
// This is ok:

"use strict";
var testvar = 0;
testvar = 5;
Maciej Lasyk, node.js security

第16页

JS security recap – strict mode
- evals & co are not that insecure now
- no access to caller and args props
- enable globally or for some scope
- what about strict mode in 3rd party mods?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第17页

JS security recap – strict mode
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
"use strict";

function do_smt() {
do_smt.caller; // no way :)
do_smt.arguments; // no way :)
}
Maciej Lasyk, node.js security

第18页

JS security recap – strict mode
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
"use strict";
eval("var smt = 123");
console.log(smt); // sorry – ReferenceError
Maciej Lasyk, node.js security

第19页

JS security recap – strict mode
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
"use strict";
eval("var smt = 123");
console.log(smt); // sorry – ReferenceError
But watch out:

"use strict";
var smt = 0;
eval("smt = 123");
console.log(smt); // outputs “123” properly
Maciej Lasyk, node.js security

第20页

JS security recap – object properties
- writable: RO/RW
- enumerable: no loops enumeration
- configurable: deletion prohibited
- all default set to True so watch out
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第21页

JS security recap – object properties
var obj = {}; obj.prop = "LOL";
// OR:
Object.defineProperty(obj, "prop", {
writable: true,
enumerable: true,
configurable: true,
value: "LOL"
})
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第22页

JS security recap – object properties
// RO & immutable property def:
var obj = {};
Object.defineProperty(obj, "prop", {
value: "LOL"
});
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第23页

JS security recap – static code analysis
- If not doing it already – just do
- Commit hooks in (D)VCSes
- JSHint / JSLint
- Create policy for static code analysis
- Update & check this policy regularly
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第24页

about node.js: what's up?
- current stable version 0.10.28
- who is using node?
https://github.com/joyent/node/wiki/Projects,-Applications,-and-Companies-Using-Node
- Operating Node.js in production/Bryan Cantrill (Joyent)
- Bill Scott,“Clash of the Titans: Kraken | Node.js @ paypal”
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25

第25页

about node.js: model
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第26页

about node.js: concurrency
- node.js is single threaded (let's say)
- multi – core? child processes (cluster.fork)
- Linux containers ftw!
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第27页

about node.js: SPA
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
(thx Sekurak.pl for this image)
Maciej Lasyk, node.js security

第28页

node.js sec: exploits anyone?
- http://seclists.org/bugtraq – 0 hits
- http://osvdb.org – 2 hits
- http://1337day.com, http://www.exploitdb.com – 1 hit
- http://nodesecurity.io/advisories – 4 hits
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第29页

node.js sec: exploits anyone?
- http://seclists.org/bugtraq – 0 hits
- http://osvdb.org – 2 hits
- http://1337day.com, http://www.exploitdb.com – 1 hit
- http://nodesecurity.io/advisories – 4 hits
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Such security big?
Maciej Lasyk, node.js security

第30页

node.js sec: exploits anyone?
- http://seclists.org/bugtraq – 0 hits
- http://osvdb.org – 2 hits
- http://1337day.com, http://www.exploitdb.com – 1 hit
- http://nodesecurity.io/advisories – 4 hits
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Such security big?

not exactly
Maciej Lasyk, node.js security

第31页

node.js sec: what's wrong?
node.js security is a blank page
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
http://www.slideshare.net/ASF-WS/asfws-2012-nodejs-security-old-vulnerabilities-in-new-dresses-par-sven-vetsch
Maciej Lasyk, node.js security

第32页

node.js sec: how does sec look like?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第33页

node.js sec: how does sec look like?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Such security..
Very fortress!!1
WOW :)
Maciej Lasyk, node.js security

第34页

node.js sec: exceptions / callbacks
callbacks Error object – remember to handle those
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var fs = require("fs");
fs.readFile("/some/file", "utf8", function (err, contents) {
// err will be null if no error occured

// ... otherwise there will be info about error
});
forget about handling and die debugging
Maciej Lasyk, node.js security

第35页

node.js sec: exceptions / eventemitter
EventEmitter: emitting events 4 async actions
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var http = require("http");
http.get("http://nodejs.org/", function (res) {
res.on("data", function (chunk) {
do_something_with_chunk;
});
res.on("error", function (err) {
// listener handling error
});
});
Attach listeners to errors events or
welcome unhandled exception!
Maciej Lasyk, node.js security

第36页

node.js sec: uncaught exceptions
- by default node.js will print stack trace and terminate thread
- EventEmitter / process / uncaughtException
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
// it looks like this by default:

process.on("uncaughtException", function (err) {
console.error(err);
console.trace();
process.exit();
});
Maciej Lasyk, node.js security

第37页

node.js sec: uncaught exceptions
- by default node.js will print stack trace and terminate thread
- EventEmitter / process / uncaughtException
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
// it looks like this by default:

process.on("uncaughtException", function (err) {
console.error(err);
console.trace();
process.exit();
});
So do you really want to comment out the 'process.exit()' line?
Maciej Lasyk, node.js security

第38页

node.js sec: clusters
scaling within multi-core envs
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var cluster = require('cluster');
var http = require('http');
var numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
  for (var i = 0; i < numCPUs; i++) {
    cluster.fork();
  }
  cluster.on('exit', function(worker, code, signal) {
    console.log(worker.process.pid + ' died');
  });
} else {
  http.createServer(function(req, res) {
    res.writeHead(200);
    res.end("hello world\n");
  }).listen(8000);
}
Maciej Lasyk, node.js security

第39页

node.js sec: domains
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Handling multiple different IO operations as a single group
// don't do that:

var d = require('domain').create();
d.on('error', function(er) {
  console.log('error, but oh well', er.message);
});
d.run(function() {
  require('http').createServer(function(req, res) {
    handleRequest(req, res);
  }).listen(PORT);
});
Maciej Lasyk, node.js security

第40页

node.js sec: domains
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Rather use cluster & forks and exit gently..:
create_cluster;
fork_workers;

if(worker){
var domain = require('domain');
var server = require('http').createServer(function(req, res) {
     var d = domain.create();
     d.on('error', function(er) {
       console.error('error', er.stack);
   try {
 // set timeout timer
 // update master && print err msg
 //  close server
        } catch (er2) { console.error('Error 500!', er2.stack); }
}
Maciej Lasyk, node.js security

第41页

node.js sec: domains
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Using Express take look at that:

https://github.com/brianc/node-domain-middleware

Assigning each Express request to a separate domain?
Maciej Lasyk, node.js security

第42页

node.js sec: npm modules
- npm install (-g)
- who creates modules?
- who verifies those?
- how to update?
- semantic versioning in package.json
- "connect":"~1.8.7" -> 1.8.7 - 1.9
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第43页

node.js sec: npm modules
--ignore-scripts
stop preinstall/prepublish scripts
- mods auditing: https://nodesecurity.io/
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第44页

node.js sec: npm modules
The scale of npm modules
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第45页

node.js sec: npm modules
Comparison to other langs (mods/day):
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第46页

node.js sec: npm modules
Remember:
- use strict?
- static analysis?
- does include some test suite?
- what is the dependency tree?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第47页

node.js.express: connect / express
Express – web dev framework
Built on top of connect
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第48页

node.js.express: auth.basic_auth
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var express = require('express'),
app = express();
app.use(express.basicAuth("user", "pwd"));
app.get("/", function (req, res) {
res.send('Hello World');
});
app.listen(8080);
Plain text and simple auth issues
Maciej Lasyk, node.js security

第49页

node.js.express: auth.basic_auth
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var users = {
admin: "admin123",
user: "user456"
};

app.use(express.basicAuth(function (user, pass) {
return users.hasOwnProperty(user) && users[user] === pass;
}));
Maciej Lasyk, node.js security

第50页

node.js.express: auth.SSL
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var express = require('express'), routes = require('./routes'), fs = require('fs')
var opts = {
key: fs.readFileSync('ssl/server/keys/server.key'),
cert: fs.readFileSync('ssl/server/certificates/server.crt'),
ca: fs.readFileSync('ssl/ca/ca.crt'),
crl: fs.readFileSync('ssl/ca/ca.crl'),
requestCert: true,
rejectUnauthorized: true
passphrase: "pwd" // <<<< really here?
};

var app = module.exports = express.createServer(opts);

app.configure(function(){
app.set('views', __dirname + '/views');
...
});

app.get('/', routes.index);
app.listen(8443);
Maciej Lasyk, node.js security

第51页

node.js.express: passport.js
- provides API for authentication and authorization
- authentication:
- LocalStrategy
- OpenIDStrategy
- OAuth / FacebookStrategy
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第52页

node.js.express: authorization
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var users = [
{ id: 1, name: "user1", role: "admin" },
{ id: 2, name: "user2", role: "common" },
];
function loadUser(req, res, next) {
req.userData = users[req.params.user];
return next();
}
function requireRole(role) {
return function (req, res, next) {
if (req.user.role === role) {
return next();
} else {
return next(new Error("Unauthorized"));
}
};}
Maciej Lasyk, node.js security

第53页

node.js.express: authorization
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
app.get("/users/:user", loadUser, function (req, res) {
res.send(req.user.name);
});

app.del("/users/:user", requireRole("admin"), loadUser, function (req,res) {
res.send("User deleted");
});
Maciej Lasyk, node.js security

第54页

node.js.express: logging
OWASP will tell you what should be logged :)
https://www.owasp.org/index.php/Logging_Cheat_Sheet
- authentication & authorisation
- session management
- errors & weirdo events
- events (startups, shutdowns, slowdowns etc)
- high risk functionalities (payments, privileges, admins)
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第55页

node.js.express: logging
Try Winston module (Github -> flatiron/winston)
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
- logging to console
- logging to file
- sending logs over HTTP
- CouchDB, Redis, MongoDB, Riak etc
Maciej Lasyk, node.js security

第56页

node.js.express: logging
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var winston = require('winston');
var logger = new (winston.Logger)({
transports: [
new (winston.transports.Console)(),
new (winston.transports.File)({
filename: 'application.log' })
]
});
Maciej Lasyk, node.js security

第57页

node.js.express: sessions
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var express = require('express');
var app = express();
var RedisStore = require('connect-redis')(express);

app.use(express.cookieParser());
app.use(express.session({
  store: new RedisStore({
    host: '127.0.0.2',
    port: 6379,
    db: 3,
    pass: 'pwd'
  }),
  secret: 'this-is-very-secret'
}));

app.get('/somewhere', function(req, res) {
  res.send('In the middle of nowhere');
});

app.listen(process.env.PORT || 8080);
Maciej Lasyk, node.js security

第58页

node.js.express: sessions
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
app.use(express.session({
secret: “very-secret”,
key: “sessionId”,
cookie: {
httpOnly: true,
secure: true
}
}));
Maciej Lasyk, node.js security

第59页

node.js.CSI: CSRF
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var express = require("express"),
app = express();
app.use(express.cookieParser());
app.use(express.bodyParser());
app.use(express.session({ secret: "very-secret" }));
app.use(express.csrf());
Maciej Lasyk, node.js security

第60页

node.js.CSI: CSRF
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
app.get("/valid", function (req, res) {
<input type="hidden" name="_csrf" value="+req.CsrfToken()+">
res.send(output);
});
app.get("/invalid", function (req, res) {
no_csrf_token_field
res.send(output);
});
Express CSRF ignores CSRF on HTTP, GET, OPTIONS, HEAD reqs
Maciej Lasyk, node.js security

第61页

node.js.CSI: input.validation
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
var express = require("express"),
app = module.exports = express();
app.use(express.bodyParser());
app.use(require("express-validator")());

app.get("/", function (req, res) {
res.sendfile(__dirname + "/tpls/validate.html");
});

app.post("/", function (req, res, next) {
// validation
req.checkBody("name").notEmpty().is(/\w+/);
// filtering
req.sanitize("name").trim();
...
}
Maciej Lasyk, node.js security

第62页

node.js.CSI: XSS
- XSS allows to access cookies, session tokens etc
- or even redirect user to malicious sites
- Myth: frameworks / tpls does the anti-XSS job
- always encode untrusted data for correct context
- OWASP ESAPI
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第63页

node.js.CSI: DoS
- Error handling
- Use streams / chunking
- Use monitoring
- Use domains / clusters
- Don't be afraid of SlowLoris :)
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第64页

node.js.CSI: ReDoS
- Regex could take exponential execution time
- Is regex executed in the event loop thread?
- Regex and user input?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
https://speakerdeck.com/ckarande/top-overlooked-security-threats-to-node-dot-js-web-applications
Maciej Lasyk, node.js security

第65页

node.js.CSI: HPP
HTTP Parameter Pollution
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
// POST firstName=John&firstName=John

req.body.color

//=> [“John”, “John”]
Maciej Lasyk, node.js security

第66页

node.js.CSI: HPP
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Modify app behavior:
Maciej Lasyk, node.js security

第67页

node.js.CSI: HPP
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
- TypeErrors, uncaught errs->DoS,

- Check the expected type in the input validation

- Input fuzzing / test suites

- try/catch, domains, clusters
Maciej Lasyk, node.js security

第68页

node.js.CSI: HTTP_headers.CSP
Content Security Policy
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Content-Security-Policy:
script-src 'self';
frame-src 'none';
object-src 'none';
report-uri /my_csp_report_parser;
Maciej Lasyk, node.js security

第69页

node.js.CSI: HTTP_headers.CSP
Content Security Policy
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Content-Security-Policy:
script-src 'self';
frame-src 'none';
object-src 'none';
report-uri /my_csp_report_parser;
app.use(helmet.csp.policy({
defaultPolicy: {
"script-src": [ "'self'" ],
"img-src": [ "'self'", "http://example.com/" ]
}
}));
Maciej Lasyk, node.js security

第70页

node.js.CSI: HTTP_headers.HSTS
HTTP Strict Transport Security
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
app.use(helmet.hsts(X, true));

Strict-Transport-Security: max-age=X; includeSubdomains
Requires HTTPS also on subdomains,
respects configuration for X seconds
Maciej Lasyk, node.js security

第71页

node.js.CSI: HTTP_headers.X-Frame-Options
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
X-Frame-Options: DENY
helmet.xframe('sameorigin');
helmet.xframe('allow-from', 'http://example.com');
Maciej Lasyk, node.js security

第72页

node.js.CSI: HTTP_headers.others
- X-Content-Type-Options
- Cache-Control
- X-Powered-By
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
X-Content-Type-Options: nosniff
app.use(helmet.contentTypeOptions());
app.use(helmet.cacheControl());
app.disable(“x-powered-by”);
Maciej Lasyk, node.js security

第73页

node.js.CSI: request_size
Just set limits
use streams instead of buffering
And request size:
app.use(express.limit("5mb"));
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第74页

node.js.CSI: environment.monitoring
- is app functional? :)
- is app overloaded?
- app should provide monitoring interface
- how many errors caught?
- are forks alive and OK?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第75页

node.js.CSI: environment.resources
- node.js will eat ;)
- use control groups || containers
- monitor resources usage
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第76页

node.js.CSI: environment.sandboxing
- running node.js within shared env?
- selinux sandbox?
- libvirt sandbox?
- LXC / Docker?
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第77页

node.js.CSI: environment.ACLs
Just...
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25

第78页

node.js.CSI: environment.ACLs
Just...
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Don't run as `root`!!!
Maciej Lasyk, node.js security

第79页

node.js.CSI: environment.ACLs
Just...
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Don't run as `root`!!!
And also maybe behind some LB?
Maciej Lasyk, node.js security

第80页

node.js.CSI: environment.tracing_execution
- SmartOS / Joyent: debugging
- Bunyan / Dtrace
- strace of course...
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第81页

node.js.testing: testing
- maybe some interface for white-box pentests?
- unit-testing 4 the sake!
- OWASP Zed Attack Proxy
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第82页

So what else?
sockets.io
node-webkit
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第83页

node.js.learning
- Node Security Book
- OWASP Node Goat (top10)
- nodesecurity.io (Twitter, RSS)
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第84页

node.js.hiring?
- does this guy contribute?
- NoSQL somehow?
- not only HTTP: socket.io?
- DevOps & infra?
- Security? :)
Maciej Lasyk, Ganglia & Nagios
 3/25
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security

第85页

Maciej Lasyk, node.js security
 1/25
Maciej Lasyk, node.js security
Infosec && meet.js meetups

第86页

http://maciek.lasyk.info/sysop

maciek@lasyk.info

@docent-net
node.js security
Thank you :)
Maciej Lasyk, node.js security
 1/25
Maciej Lasyk
SEConference
Kraków, 2014-05-09
Maciej Lasyk, node.js security
支持文件格式:*.pdf
上传最后阶段需要进行在线转换,可能需要1~2分钟,请耐心等待。