Skip to content
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

Adding the protocol to the URL causes the help page to appear #238

Closed
AgentJay opened this issue May 16, 2020 · 2 comments
Closed

Adding the protocol to the URL causes the help page to appear #238

AgentJay opened this issue May 16, 2020 · 2 comments
Labels

Comments

@AgentJay
Copy link

Hello,

Thanks for this! I am plagued by cors issues all the time.

So it's handy to be able to specify the protocol since I would like to have mixed content (http and https) being delivered to my https page.

While adding the protocol in your demo seems to work great I'm having issues.

These are the 2 tests that I'm hoping will eventually both work:
https://proxy.biopama.org/www.google.com (works)
https://proxy.biopama.org/https://www.google.com (gives the help page)

@Rob--W
Copy link
Owner

Rob--W commented May 16, 2020

This is an issue of your server configuration. You apparently have another server in front of the CORS Anywhere proxy, which normalizes the URL.

In 0.4.1 and before, the proxy would attempt to connect to the invalid host, and end up with errors like Not found because of proxy error: Error: getaddrinfo ENOTFOUND (e.g. #167 and many other reported issues on this issue tracker). In #239, you mentioned the use of Apache. See #201 for instructions on properly configuring Apache to direct requests to CORS Anywhere.

As of 0.4.2, the URL validation is more strict, and invalid URLs are mapped to the homepage instead of an error page.

Since this is a common error and a very frequently asked question from people who try to self-host CORS Anywhere, I should probably consider catching the special case and show a specialized error page instead...

@Rob--W
Copy link
Owner

Rob--W commented Mar 22, 2021

I changed the code to spit out a more descriptive error message when this happens.

@Rob--W Rob--W closed this as completed Mar 22, 2021
DiegoFleitas added a commit to DiegoFleitas/cors-anywhere that referenced this issue May 26, 2022
* Extend supported Node.js from <=9 to <=14

* test-memory: destroy response to free socket

Starting from Node 12, the test started to fail because of
intermittent socket errors, such as ECONNRESET and "socket hang up".

Destroying the response before triggering a new request resolves it.

* Explicit early out for invalid URLs

* Version 0.4.2

- Reject invalid URLs earlier instead of trying to continue with the
  request (and failing anyway).
- Explicitly close the response when an error occurs for Node 13+.
- Update tests to cover up to Node 14 (was up to 9).

* Update test expectation for Node 12.x

* test-memory: fix test by passing --max-http-header-size

The test broke because Node lowered the maximum header size to defend
against large headers ( CVE-2018-12121 ).

In the test, we do actually want to pass large headers, because all
processing in CORS Anywhere is based on headers (the request body would
just be forwarded to the destination server).

The test failed intermittently with ECONNRESET or "socket hang up"
because the server (under test) would close the socket upon receiving
a request with too large request headers.

* Pass --max-http-header-size in supported versions only

* Reject invalid redirects

Fixes Rob--W#234.

* Version 0.4.3

- Reject invalid URLs in redirects (fixes regression from 0.4.2) (Rob--W#234)
- Update memory tests for recent Node versions.

* only send Access-Control-Max-Age if preflight request, not POST/GET

-Access-Control-Max-Age header only has meaning for preflights, not
 POST or GET, saves wire bytes by excluding it from POST/GET/etc,
 and future problems if ACMA on a content HTTP method is given
 meaning by W3C or a browser vendor

-fix expectNoHeader() test helper func ,this was a no-op before by
 accident and would NEVER fail,
 supertest/test.js:Test.prototype._assertFunction requires an retval of
 class type Error if test fail, not a string or a number or Object

* remove Heroku specific Req headers from being sent to Origin

-saves bytes, and avoids triggering IDS/WAF alarms since browser finger
 printing will prove these headers are unnatural and on SSL must be a MITM
 attack

-leave x-forwarded-* intact since they can be used to block CORS proxy
 abuse if the not-CORS origin webmaster really has to block the proxy
 and they are not unique to Heroku platform

* Remove obsolete values from server.js's removeHeaders

`X-Heroku-Dynos-In-Use`, `X-Heroku-Queue-Depth` and
`X-Heroku-Queue-Wait-Time` have already been dropped in 2013:
https://devcenter.heroku.com/changelog-items/218

* Add handleInitialRequest option to support Rob--W#301

The custom filtering logic is not part of the public repository, to
keep the project clean.

* Expand handleInitialRequest documentation Rob--W#335

* Add note about availability of public demo server

Referencing Rob--W#301

* Update gTLD list

* Version 0.4.4

- Omit unnecessary `Access-Control-Max-Age` (Rob--W#277)
- Remove more Heroku-specific headers (Rob--W#278)
- Add `handleInitialRequest` option (Rob--W#335)
- Document access requirements for public demo (Rob--W#301)
- Update gTLD list

* Support NODE_TLS_REJECT_UNAUTHORIZED=0 to ignore client errors Rob--W#341

Apparently `NODE_TLS_REJECT_UNAUTHORIZED` is only effective if
`rejectUnauthorized` was not overridden by the code:
https://github.com/nodejs/node/blob/85e6089c4db4da23dd88358fe0a12edefcd411f2/lib/_tls_wrap.js#L1583-L1591

But the underlying library does override it:
https://github.com/http-party/node-http-proxy/blob/v1.11.1/lib/http-proxy/common.js#L53-L55

Fix this by overriding the option via the library's "secure" option.

* Fix test expectation for old node

* Migrate travis-ci from .org to .com

* Add Node 15.x to Travis

* Show "400 Missing slash" when needed Rob--W#238

* Add LICENSE file based on README.md Rob--W#297

* Fix typo

Co-authored-by: Rob Wu <[email protected]>
Co-authored-by: bulk88 <[email protected]>
Co-authored-by: Noodles <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants