requests 是一个非常小巧全面的库,应用它可以很容易写出与服务器进行交互的程序,今天遇到了一个问题,与服务器交互时,url都是https开头的,都进行了ssl加密处理,这样一来,就不能像之前那样访问http开头的url那样进行处理了。
查了一些资料,可以配置ssl进行验证的文件,方式如下
1
|
res = requests.get( 'https://127.0.0.1:5503/login' ,cert = ( './server.crt' , './server.key.unsecure' )) |
可运行后,验证不成功,我的key文件是 server.key.unsecure,这个文件是为了防止输入密码而特地生成的,生成方法可参考这篇帖子点击打开链接
如果我将key文件改成server.key,那么虽然验证通过,却需要手动输入密码,这显然是我不希望的。
最后采用了一个很丑陋但是很有效的方法,不验证
1
2
3
|
session = requests.session() data = { 'username' : 'admin' , 'password' : 'admin' } res = session.post( 'https://127.0.0.1:5503/login' ,verify = False ,data = data) |
将verify设置为False,算是把这个问题给绕过去了
总结
以上本文关于python中requests和https使用简单示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/kwsy2008/article/details/52354254