ChatGPT解决这个技术问题 Extra ChatGPT

How to get past the login page with Wget?

I am trying to use Wget to download a page, but I cannot get past the login screen.

How do I send the username/password using post data on the login page and then download the actual page as an authenticated user?


9
9999years

Based on the manual page:

# Log in to the server.  This only needs to be done once.
wget --save-cookies cookies.txt \
     --keep-session-cookies \
     --post-data 'user=foo&password=bar' \
     --delete-after \
     http://server.com/auth.php

# Now grab the page or pages we care about.
wget --load-cookies cookies.txt \
     http://server.com/interesting/article.php

Make sure the --post-data parameter is properly percent-encoded (especially ampersands!) or the request will probably fail. Also make sure that user and password are the correct keys; you can find out the correct keys by sleuthing the HTML of the login page (look into your browser’s “inspect element” feature and find the name attribute on the username and password fields).


add --keep-session-cookies to the first command, or the second?
You don't need -p (--page-requisites) for this.
It's also worth adding --delete-after to the first retrieval so you don't end up saving the result page from logging in.
I am getting error WGET64: missing URL I put whole wget command in one line and removed `\`
--keep-session-cookies is needed for the first command only. It tells the first command to include session cookies when saving cookies to the file. The second command simply reads all cookies from the provided file.
u
user

You can log in via browser and copy the needed headers afterwards:

https://i.stack.imgur.com/DePbs.png

Use "Copy as cURL" in the Network tab of browser developer tools and replace curl's flag -H with wget's --header (and also --data with --post-data if needed).


Awesome! Also pointed me to the option of using curl instead of wget, since it can do the same thing and I don't even need to change the parameters.
This worked for me, whereas wget with the correct cookie did not; I suspect the web service checks for multiple different GET headers, even seemingly unimportant ones like "User-Agent" or "Cache-Control."
@Arthur for me this solution was the only one that worked. I tried to remove as much header data from the URL as possible and ended up with essentially the cookie data. So I suspect wget supplied the data in a wrong way.
g
galoget

I directly gave cookies of an existing connection to wget with --no-cookies and the Cookie HTTP request header. In my case it was a Moodle university login where logging in looks more complex (using multiple requests with a login ticket). I added --post-data because it was a POST request.

For example, get all Moodle users list:

wget --no-cookies --header "Cookie: <name>=<value>" --post-data 'tab=search&name=+&personsubmit=Rechercher&keywords=&keywordsoption=allmine' https://moodle.unistra.fr/message/index.php

Awesome tip. This is useful when you can access the cookie from your own machine and then use that from another headless machine from the command line. :)
You can set multiple cookies at the same time also, --header "Cookie: access_token=IKVYJ;XSRF-TOKEN=5e10521d"
G
GoTrained

I had the same problem. My solution was to do the login via Chrome and save the cookies data to a text file. This is easily done with this Chrome extension: Chrome cookie.txt export extension.

When you get the cookies data, there is also an example on how to use them with wget. A simple copy-paste command line is provided to you.


unfortunately not applicable in automated scripting
The question doesn't specify automated scripting. This solution allows 99% of the work to be automated.
Unfortunately, Google must be too smart for this trick. I still get a login page.
Of course, Google uses secret reCAPTCHAs... as I've seen so many places, using standard programmatic APIs is the most practical option in this case.
The link you posted is unfortunately down. This one works: chrome.google.com/webstore/detail/get-cookiestxt/… To use with wget: wget --load-cookies /path/to/cookies.txt
g
galoget

I wanted a one-liner that didn't download any files; here is an example of piping the cookie output into the next request. I only tested the following on Gentoo, but it should work in most *nix environments:

wget -q -O /dev/null --save-cookies /dev/stdout --post-data 'u=user&p=pass' 'http://example.com/login' | wget -q -O - --load-cookies /dev/stdin 'http://example.com/private/page'

(This is one line, though it likely wraps on your browser)

If you want the output saved to a file, change -O - to -O /some/file/name.ext


P
Peter Mortensen

You don't need cURL to do POSTed form data. --post-data 'key1=value1&key2=value2' works just fine. Note: you can also pass a file name to wget with the POST data in the file.


C
Community

If they're using basic authentication:

wget http://username:password@www.domain.com/page.html

If they're using POSTed form data, you'll need to use something like cURL instead.


I dont have access to change anything on the server, it is read only
So? None of this requires you to change anything on the server.
The Op asked for wget and clearly needs an answer with cookies.
@hiburn8 Just skipping past the "if they're using basic authentication", I see? If OP needs anything twelve years later they're probably in trouble.
a
alls0rts

A solution which uses lynx and wget.

Note: Lynx has to have been compiled with the --enable-persistent-cookies flag for this to work

When you want to use wget to download some file from a site which requires login, you just need a cookie file. In order to generate the cookie file, I choose lynx. lynx is a text web browser. First you need a configure file for lynx to save cookie. Create a file lynx.cfg. Write these configuration into the file.

SET_COOKIES:TRUE
ACCEPT_ALL_COOKIES:TRUE
PERSISTENT_COOKIES:TRUE
COOKIE_FILE:cookie.file

Then start lynx with this command:

lynx -cfg=lynx.cfg http://the.site.com/login

After you input the username and password, and select 'preserve me on this pc' or something similar. If login successfully, you will see a beautiful text web page of the site. And you logout. The in the current directory, you will find a cookie file named as cookie.file. This is what we need for wget.

Then wget can download file from the site with this command.

wget --load-cookies ./cookie.file http://the.site.com/download/we-can-make-this-world-better.tar.gz

what about if the login requires javascript? lynx does not seems to support javascript.
A
Alex Ivasyuv

Example to download with wget on server a big file link that can be obtained in your browser.

In example using Google Chrome.

Login where you need, and press download. Go to download and copy your link.

https://i.stack.imgur.com/4sCjR.png

Then open DevTools on a page where you where login, go to Console and get your cookies, by entering document.cookie

https://i.stack.imgur.com/7GAB7.png

Now, go to server and download your file: wget --header "Cookie: <YOUR_COOKIE_OUTPUT_FROM_CONSOLE>" <YOUR_DOWNLOAD_LINK>

https://i.stack.imgur.com/aGj8m.png


This answer does not seem to scale well to Google -- where there are two pages of cookies!
Of course, Google uses secret reCAPTCHAs... as I've seen so many places, using standard programmatic APIs is the most practical option in this case.
V
Vahid

I use this chrome extension. It'll give you the wget command for any download link you open.


a
ady

You can install this plugin in Firefox: https://addons.mozilla.org/en-US/firefox/addon/cliget/?src=cb-dl-toprated Start downloading what you want and click on the plugin. It gives you the whole command either for wget or curl to download the file on the serer. Very easy!