-
Notifications
You must be signed in to change notification settings - Fork 853
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
HttpProxyMiddleware [ERR_STREAM_WRITE_AFTER_END] when using agent #1021
Comments
I found the same problem onstackoverflow |
This code fails in the following circumstances: const express = require(`express`)
const { createProxyMiddleware, fixRequestBody } = require(`http-proxy-middleware`)
const app = express()
const defaultConfig = {
ws: true,
secure: false,
changeOrigin: true,
onProxyReq: (proxyReq, req, res) => {
// https://github.com/chimurai/http-proxy-middleware/pull/492
fixRequestBody(proxyReq, req)
},
logLevel: `silent`,
pathRewrite: { '^/amap/': `https://restapi.amap.com/` },
// proxyTimeout: 60 * 1000,
// timeout: 60 * 1000,
}
app.use(`/amap/`, createProxyMiddleware({ ...defaultConfig, target: `https://restapi.amap.com/`}))
app.listen(8840) Visit the following link: :8840/amap/v3/geocode/regeo?key=******&location=37.09024%2C-95.712891&extensions=all&appname=***** An error occurs under Linux: events.js:292
throw er; // Unhandled 'error' event
^
Error [ERR_STREAM_WRITE_AFTER_END]: write after end
at writeAfterEnd (_http_outgoing.js:668:15)
at write_ (_http_outgoing.js:680:5)
at ServerResponse.write (_http_outgoing.js:661:15)
at IncomingMessage.ondata (internal/streams/readable.js:719:22)
at IncomingMessage.emit (events.js:315:20)
at IncomingMessage.Readable.read (internal/streams/readable.js:519:10)
at flow (internal/streams/readable.js:992:34)
at resume_ (internal/streams/readable.js:973:3)
at processTicksAndRejections (internal/process/task_queues.js:80:21)
Emitted 'error' event on ServerResponse instance at:
at writeAfterEndNT (_http_outgoing.js:727:7)
at processTicksAndRejections (internal/process/task_queues.js:81:21) {
code: 'ERR_STREAM_WRITE_AFTER_END'
} Same code and same version number, no problem under Windows. If you use [email protected] and replace with the following code, the problem can be solved. const express = require(`express`)
const { createProxyMiddleware, legacyCreateProxyMiddleware, fixRequestBody } = require(`http-proxy-middleware`)
const app = express()
const defaultConfig = {
ws: true,
secure: false,
changeOrigin: true,
on: {
proxyReq: (proxyReq, req, res) => {
fixRequestBody(proxyReq, req)
},
// Without this function, another error will occur
// Without this function, another error will occur
// Without this function, another error will occur
error: (err, req, res) => {
console.log(err)
},
},
logLevel: `silent`,
// proxyTimeout: 60 * 1000,
// timeout: 60 * 1000,
}
app.use(`/amap/`, createProxyMiddleware({ ...defaultConfig, target: `https://restapi.amap.com/`}))
app.listen(8840) Note: The above information may only apply to my use case. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Checks
http-proxy-middleware
.Describe the bug (be clear and concise)
I'm using HttpProxyMiddleware, with those options:
I know that the body is empty since I read the stream with express.raw which using bodyParser behind the scenes, but how can I write it back again before its sent? I cant make any request changes on 'onProxyReq', since I get errors like the above, and if I try to change any headers I get [ERR_HTTP_HEADERS_SENT]
I want to write the request body back before I send it to the server
Step-by-step reproduction instructions
Expected behavior (be clear and concise)
i can to write body when proxyReq event is triggered( use agent option)
How is http-proxy-middleware used in your project?
What http-proxy-middleware configuration are you using?
What OS/version and node/version are you seeing the problem?
Additional context (optional)
No response
The text was updated successfully, but these errors were encountered: