from urllib.request import Request, urlopen
import base64
import logging
import urllib
import urllib.request
import requests
def run(file_path,password):
if file_path:
try:
request = Request(file_path)
base64string = base64.b64encode('{}:{}'.format('', password).encode())
#input_file = tempfile.NamedTemporaryFile()
request.add_header("Authorization", "Basic %s" % base64string)
result = urlopen(request)
print (result)
ur = result.geturl()
a = ur.split("/")[:-1]
print (a)
', '.join(a[0:])
url = '/'.join(a)
print (url)
b = ur + "/download"
filename = "myfile"
input_file = requests.get(b,filename)
except Exception as e:
print(e)
l = run("https://cloud.abc.co.uk/s/523aX3O8B5uOWlP","test123")
print (l)
这是受密码保护的URL https://cloud.abc.co.uk/s/523aX3O8B5uOWlP。 我尝试使用urllib和base64进行身份验证。 这给了我https://cloud.abc.co.uk/s/523aX3O8B5uOWlP/authenticate。 该URL重定向到可以从中下载文件的https://cloud.abc.co.uk/s/523aX3O8B5uOWlP/download。
request = Request(file_path)
base64string = base64.b64encode('{}{}'.format('',password).encode())
request.add_header("Authorization", "Basic %s" % base64string)
result = urlopen(request)
我要绕过身份验证凭据下载文件。
答案 0 :(得分:0)
几个星期前,我在使用JSON文件时遇到了同样的问题。尝试过这样的事情。希望它也对您有用。
import urllib2
url = "url"
password_mgr = HTTPPasswordMgrWithDefaultRealm()
password_mgr.add_password(None, url, 'username', 'password')
handler = HTTPBasicAuthHandler(password_mgr)
opener = build_opener(handler)
response = opener.open(url)