NodeJS http server response headers are blank when headers are set for a request
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}
So I'm sending a request via ajax and I'm setting the headers there and I can log and see that the headers are indeed being set
$.ajax({
headers: {
Authorization: localStorage.getItem('t')
},
type: 'GET',
dataType: 'json',
url: `/updatebackground?b=${bg}`,
success: function(data) {
console.log('yay');
},
complete: function() {
console.log(this.headers)
}
});
But when I try to log the headers in node they come back as blank
http.createServer(async (req, res) => {
console.log(JSON.stringify(res._headers));
});
logs "{}"
I'm unsure as to why this happens and any help would be appreciated
node.js http
add a comment |
So I'm sending a request via ajax and I'm setting the headers there and I can log and see that the headers are indeed being set
$.ajax({
headers: {
Authorization: localStorage.getItem('t')
},
type: 'GET',
dataType: 'json',
url: `/updatebackground?b=${bg}`,
success: function(data) {
console.log('yay');
},
complete: function() {
console.log(this.headers)
}
});
But when I try to log the headers in node they come back as blank
http.createServer(async (req, res) => {
console.log(JSON.stringify(res._headers));
});
logs "{}"
I'm unsure as to why this happens and any help would be appreciated
node.js http
add a comment |
So I'm sending a request via ajax and I'm setting the headers there and I can log and see that the headers are indeed being set
$.ajax({
headers: {
Authorization: localStorage.getItem('t')
},
type: 'GET',
dataType: 'json',
url: `/updatebackground?b=${bg}`,
success: function(data) {
console.log('yay');
},
complete: function() {
console.log(this.headers)
}
});
But when I try to log the headers in node they come back as blank
http.createServer(async (req, res) => {
console.log(JSON.stringify(res._headers));
});
logs "{}"
I'm unsure as to why this happens and any help would be appreciated
node.js http
So I'm sending a request via ajax and I'm setting the headers there and I can log and see that the headers are indeed being set
$.ajax({
headers: {
Authorization: localStorage.getItem('t')
},
type: 'GET',
dataType: 'json',
url: `/updatebackground?b=${bg}`,
success: function(data) {
console.log('yay');
},
complete: function() {
console.log(this.headers)
}
});
But when I try to log the headers in node they come back as blank
http.createServer(async (req, res) => {
console.log(JSON.stringify(res._headers));
});
logs "{}"
I'm unsure as to why this happens and any help would be appreciated
node.js http
node.js http
edited Nov 23 '18 at 20:40
Henry Woody
5,09541127
5,09541127
asked Nov 23 '18 at 20:33
LilwiggyLilwiggy
31
31
add a comment |
add a comment |
3 Answers
3
active
oldest
votes
On the server, you're trying to access the headers on the response object, not the request object. Since the client set the headers on the request the desired headers would be on the request, or req
.
If you change that server-side code to:
http.createServer(async (req, res) => {
console.log(req.headers);
});
You will see the request headers
add a comment |
Apparenly it works with req.headers.authorization Doesn't really make sense as to why it's lowercase but eh whatever. I'll keep this here for anyone else with the same issue.
add a comment |
This is because you are logging the res headers and not the req headers.
the proper code for logging the request headers is:
http.createServer(async (req, res) => {
console.log(JSON.stringify(req.headers));
});
res._headers is for setting the headers for the response that is sent by the server to client as the request's answer.
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53452667%2fnodejs-http-server-response-headers-are-blank-when-headers-are-set-for-a-request%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
3 Answers
3
active
oldest
votes
3 Answers
3
active
oldest
votes
active
oldest
votes
active
oldest
votes
On the server, you're trying to access the headers on the response object, not the request object. Since the client set the headers on the request the desired headers would be on the request, or req
.
If you change that server-side code to:
http.createServer(async (req, res) => {
console.log(req.headers);
});
You will see the request headers
add a comment |
On the server, you're trying to access the headers on the response object, not the request object. Since the client set the headers on the request the desired headers would be on the request, or req
.
If you change that server-side code to:
http.createServer(async (req, res) => {
console.log(req.headers);
});
You will see the request headers
add a comment |
On the server, you're trying to access the headers on the response object, not the request object. Since the client set the headers on the request the desired headers would be on the request, or req
.
If you change that server-side code to:
http.createServer(async (req, res) => {
console.log(req.headers);
});
You will see the request headers
On the server, you're trying to access the headers on the response object, not the request object. Since the client set the headers on the request the desired headers would be on the request, or req
.
If you change that server-side code to:
http.createServer(async (req, res) => {
console.log(req.headers);
});
You will see the request headers
answered Nov 23 '18 at 20:59
Henry WoodyHenry Woody
5,09541127
5,09541127
add a comment |
add a comment |
Apparenly it works with req.headers.authorization Doesn't really make sense as to why it's lowercase but eh whatever. I'll keep this here for anyone else with the same issue.
add a comment |
Apparenly it works with req.headers.authorization Doesn't really make sense as to why it's lowercase but eh whatever. I'll keep this here for anyone else with the same issue.
add a comment |
Apparenly it works with req.headers.authorization Doesn't really make sense as to why it's lowercase but eh whatever. I'll keep this here for anyone else with the same issue.
Apparenly it works with req.headers.authorization Doesn't really make sense as to why it's lowercase but eh whatever. I'll keep this here for anyone else with the same issue.
answered Nov 23 '18 at 20:51
LilwiggyLilwiggy
31
31
add a comment |
add a comment |
This is because you are logging the res headers and not the req headers.
the proper code for logging the request headers is:
http.createServer(async (req, res) => {
console.log(JSON.stringify(req.headers));
});
res._headers is for setting the headers for the response that is sent by the server to client as the request's answer.
add a comment |
This is because you are logging the res headers and not the req headers.
the proper code for logging the request headers is:
http.createServer(async (req, res) => {
console.log(JSON.stringify(req.headers));
});
res._headers is for setting the headers for the response that is sent by the server to client as the request's answer.
add a comment |
This is because you are logging the res headers and not the req headers.
the proper code for logging the request headers is:
http.createServer(async (req, res) => {
console.log(JSON.stringify(req.headers));
});
res._headers is for setting the headers for the response that is sent by the server to client as the request's answer.
This is because you are logging the res headers and not the req headers.
the proper code for logging the request headers is:
http.createServer(async (req, res) => {
console.log(JSON.stringify(req.headers));
});
res._headers is for setting the headers for the response that is sent by the server to client as the request's answer.
answered Nov 23 '18 at 20:59
ATheCoderATheCoder
1051110
1051110
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53452667%2fnodejs-http-server-response-headers-are-blank-when-headers-are-set-for-a-request%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown