我尝试编写python 2.7脚本将文件上传到我的个人google驱动器文件夹中。
经过几次问题后我才知道。这是我当前的错误:
NotImplementedError:PyCrpto库不支持PKCS12格式。尝试转换为“PEM”(openssl pkcs12 -in xxxxx.p12 -nodes -nocerts> privatekey.pem)或使用PyOpenSSL(如果本机代码是一个选项)。
我已经尝试过运行此命令,例如question和answer中的mentiod。
openssl pkcs12 -in privatekey.p12 -nodes -nocerts > privatekey.pem
openssl pkcs8 -nocrypt -in privatekey.pem -passin pass:notasecret -topk8 -out pk.pem
从新的现代花式谷歌开发者控制台下载的我的privatekey.p12原始名为something-0123eed.json
,看起来像 1 :
{
"private_key_id": "9ced108fe72345373b75b03d7e967a3f8c0084ca",
"private_key": "-----BEGIN PRIVATE KEY-----\nxe91Tr6RHs57LKX2HivFmOQwcFoJkUPrbB6Gwy8prE...Pc9jNExo5Krp1kLrkJYxAOmUWxWwPJ4pCx7Lxc6uQQnAlKyRmnfVpdS2I0\n-----END PRIVATE KEY-----\n",
"client_email": "0KsVeSAa91UtEGvY9lil@developer.gserviceaccount.com",
"client_id": "0KsVeSAa91UtEGvY9lil.apps.googleusercontent.com",
"type": "service_account"
}
我的python代码如下所示:
#!/bin/env python2.7
from apiclient.discovery import build
from apiclient.http import MediaFileUpload
import httplib2
from oauth2client.client import SignedJwtAssertionCredentials
credentials = SignedJwtAssertionCredentials(
service_account_name='0KsVeSAa91UtEGvY9lil@developer.gserviceaccount.com',
private_key=key,
scope = [
'https://www.googleapis.com/auth/drive',
'https://www.googleapis.com/auth/drive.file',
'https://www.googleapis.com/auth/drive.appdata',
'https://www.googleapis.com/auth/drive.apps.readonly'
]
)
http = httplib2.Http()
http = credentials.authorize(http)
drive_folder_id = 'jhIKHOG6supMhpjPJFHffZarwxP6'
service = build('drive', 'v2', http=http)
media_body = MediaFileUpload('/path/to/superfile.gpg'), mimetype='application/pgp-encrypted')
body = {
'title': 'superfile.gpg',
'description': '',
'mimeType': 'application/pgp-encrypted',
'parents': [{'id': drive_folder_id}]
}
file = service.files().insert(
body=body,
media_body=media_body).execute()
1 :(当然,我用垃圾更改了值)
答案 0 :(得分:4)
我找到了answer in this gist:
openssl pkcs12 -passin pass:notasecret -in privatekey.p12 -nocerts -passout pass:notasecret -out key.pem
openssl pkcs8 -nocrypt -in key.pem -passin pass:notasecret -topk8 -out privatekey.pem
rm key.pem
但在此之前,我不得不重新生成一个新的私钥,但是采用P12格式。