#-*-coding:utf-8-*- # Time:2017/9/25 20:41 # Author:YangYangJun import requests import ssl from requests.auth import HTTPBasicAuth def post_login(): url = "https://www.url" values = {} values['username'] = 'username' values['password'] = 'password' response = requests.post(url,values) print response.text def get_login(): url = "https://www.url" values = {} values['username'] = 'username' values['password'] = 'password' #geturl = url + '?' + values response = requests.get(url, values) print response.content def post_loginHttps1(): url = "https://www.url" values = {} values['username'] = 'username' values['password'] = 'password' #臨時解決https的方法1 response = requests.post(url,values,verify=False) print response.text def post_loginHttps2(): #解決https方法2 ssl._create_default_https_context = ssl._create_unverified_context url = "https://www.url" values = {} values['username'] = 'username' values['password'] = 'password' #臨時解決https的問題 response = requests.post(url,values,verify=True) print response.text if __name__ == '__main__': post_login() #get_login() post_loginHttps1() # post_loginHttps2() #出現下面錯誤的原因主要是因為打開了fiddler,關閉fiddler即可。 # raise SSLError(e, request=request) # requests.exceptions.SSLError: HTTPSConnectionPool(host='www.yiyao.cc', port=443): Max retries exceeded with url: /user/loginWeb (Caused by SSLError(SSLError(1, u'[SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:661)'),)) #
知乎:https://www.zhihu.com/question/40025043 有介紹解決的辦法,如上代碼,方法一:關閉校驗,方法二:導入其他庫,定義ssl._create_default_https_context = ssl._create_unverified_context。
其實根本原因是打開了fiddler,關閉即可,如果不關閉,方法一也可以,方法二還是不好使。故執行時要關閉 fiddler是最保險的。
同時如果打開了fiddler,訪問https網站時,頁面可能會提示不信任無法加載的提示,這是fiddler證書不受信任的問題。解決辦法如下。
然后選擇export root .....
然后桌面會生成一個
然后通過 不同瀏覽器的證書導入即可
選擇證書執行導入。
最新遇到的坑
服務報錯:status 401,info 登錄狀態過期, 需要重新登錄
代碼除了 token 變更為最新外,其他沒做任何修改, 且之前都可以順利執行
后來發現是 user-agent 變更導致的,從瀏覽器復制最新的即可。
"user-agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.61 Safari/537.36"}