nghttpd: Fix the bug that 304 response has non-empty body

This commit is contained in:
Tatsuhiro Tsujikawa 2015-07-24 23:25:10 +09:00
parent 9b63fc011e
commit abce7c7210
1 changed files with 2 additions and 6 deletions

View File

@ -1102,7 +1102,7 @@ void prepare_response(Stream *stream, Http2Handler *hd,
if (last_mod_found && static_cast<time_t>(buf.st_mtime) <= last_mod) { if (last_mod_found && static_cast<time_t>(buf.st_mtime) <= last_mod) {
close(file); close(file);
prepare_status_response(stream, hd, 304); hd->submit_response("304", stream->stream_id, nullptr);
return; return;
} }
@ -1111,7 +1111,7 @@ void prepare_response(Stream *stream, Http2Handler *hd,
path, FileEntry(path, buf.st_size, buf.st_mtime, file)); path, FileEntry(path, buf.st_size, buf.st_mtime, file));
} else if (last_mod_found && file_ent->mtime <= last_mod) { } else if (last_mod_found && file_ent->mtime <= last_mod) {
sessions->release_fd(file_ent->path); sessions->release_fd(file_ent->path);
prepare_status_response(stream, hd, 304); hd->submit_response("304", stream->stream_id, nullptr);
return; return;
} }
@ -1630,7 +1630,6 @@ FileEntry make_status_body(int status, uint16_t port) {
enum { enum {
IDX_200, IDX_200,
IDX_301, IDX_301,
IDX_304,
IDX_400, IDX_400,
IDX_404, IDX_404,
}; };
@ -1639,7 +1638,6 @@ HttpServer::HttpServer(const Config *config) : config_(config) {
status_pages_ = std::vector<StatusPage>{ status_pages_ = std::vector<StatusPage>{
{"200", make_status_body(200, config_->port)}, {"200", make_status_body(200, config_->port)},
{"301", make_status_body(301, config_->port)}, {"301", make_status_body(301, config_->port)},
{"304", make_status_body(304, config_->port)},
{"400", make_status_body(400, config_->port)}, {"400", make_status_body(400, config_->port)},
{"404", make_status_body(404, config_->port)}, {"404", make_status_body(404, config_->port)},
}; };
@ -1884,8 +1882,6 @@ const StatusPage *HttpServer::get_status_page(int status) const {
return &status_pages_[IDX_200]; return &status_pages_[IDX_200];
case 301: case 301:
return &status_pages_[IDX_301]; return &status_pages_[IDX_301];
case 304:
return &status_pages_[IDX_304];
case 400: case 400:
return &status_pages_[IDX_400]; return &status_pages_[IDX_400];
case 404: case 404: