我正在学习如何使用Dropbox Python SDK。但是,当我尝试生成请求令牌时遇到问题。这是我正在使用的代码(请注意,我已经在这里用APP_KEY和APP_SECRET替换了我的实际应用密钥和秘密,但是在我试用时我使用了我的实际应用密钥和秘密。)
from dropbox import client, rest, session
APP_KEY = 'APP_KEY'
APP_SECRET = 'APP_SECRET'
ACCESS_TYPE = 'app_folder'
print 'Creating session object'
sess = session.DropboxSession(APP_KEY, APP_SECRET, ACCESS_TYPE)
print 'Session created!\nCreating request token'
request_token = sess.obtain_request_token()
print 'Created request token!'
url = sess.build_authorize_url(request_token)
print url
raw_input()
access_token = sess.obtain_access_token(request_token)
client1 = client.DropboxClient(sess)
print client1.account_info()
我让程序打印出消息,因为它创建了不同的对象,以便我可以看到错误发生的位置。这是输出:
aaron@Aarons-Ubuntu-Computer:~/Twisted$ python example.py
Creating session object
Session created!
Creating request token
Traceback (most recent call last):
File "example.py", line 8, in <module>
request_token = sess.obtain_request_token()
File "/usr/local/lib/python2.7/dist-packages/dropbox-1.4-py2.7.egg/dropbox/session.py", line 160, in obtain_request_token
response = rest.RESTClient.POST(url, headers=headers, params=params, raw_response=True)
File "/usr/local/lib/python2.7/dist-packages/dropbox-1.4-py2.7.egg/dropbox/rest.py", line 140, in POST
return cls.request("POST", url, post_params=params, headers=headers, raw_response=raw_response)
File "/usr/local/lib/python2.7/dist-packages/dropbox-1.4-py2.7.egg/dropbox/rest.py", line 64, in request
conn = ProperHTTPSConnection(host, 443)
File "/usr/local/lib/python2.7/dist-packages/dropbox-1.4-py2.7.egg/dropbox/rest.py", line 214, in __init__
self.cert_reqs = ssl.CERT_REQUIRED
AttributeError: 'module' object has no attribute 'CERT_REQUIRED'
之前我曾尝试使用此代码,但我没有遇到此问题。我还删除了Dropbox SDK并重新安装它,没有结果。是什么导致了这个问题,我该如何解决?
更新
添加Kannan代码后,输出如下所示:
Ready
Generating session
Session Generated!
Generating request token
['Certificate', 'CertificateOptions', 'CertificateRequest', 'Client', 'ClientContextFactory', 'Connector', 'ContextFactory', 'DN', 'DefaultOpenSSLContextFactory', 'DistinguishedName', 'KeyPair', 'Port', 'PrivateCertificate', 'SSL', 'Server', '__all__', '__builtins__', '__doc__', '__file__', '__name__', '__package__', 'implementedBy', 'implements', 'implementsOnly', 'interfaces', 'supported', 'tcp']
然后我得到了错误。我试过没有运气重新创建我的SSL证书。
答案 0 :(得分:3)
我收到同样的错误。我尝试了你的建议,结果证明ssl模块没有属性' file ',只有['strong> doc ',' loader ','名称','包']。另外值得注意的是,当我在谷歌应用引擎中尝试打印str(ssl)时,我看到: module'sssl'(内置) 但是当我从命令行运行python时,我看到: 模块'ssl'来自'/ Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/ssl.pyc' 并且命令行中的ssl具有文件属性。
不确定ssl是如何被劫持的......但我很确定它是。
编辑:加载程序是google.appengine.tools.dev_appserver_import_hook.HardenedModulesHook对象,位于0x1142684d0
编辑:在此处发现了一个相关问题:SSLError on Google App Engine (local dev-server)
答案 1 :(得分:1)
这很奇怪。 Python 2.7文档明确提到ssl.CERT_REQUIRED
。
尝试修改SDK,并在失败的行之前添加
print dir(ssl)
print ssl.__file__
这可能会帮助你弄清楚出了什么问题。