zoukankan      html  css  js  c++  java
  • Python

    #-*-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"}
  • 相关阅读:
    XML 浏览器支持
    浏览器中的XML
    C/C++中判断某一文件或目录是否存在
    C/C++程序员必须熟练应用的开源项目 -- 转
    VC 中窗口的销毁
    sql proc触发异常处理回滚
    为Array 添加indexOf
    Js的两种post方式
    sql 针对多个id或名称的分割和组合
    sql 查看语句的性能
  • 原文地址:https://www.cnblogs.com/BlueSkyyj/p/7594533.html
Copyright © 2011-2022 走看看