2

这是我的原始代码

import urllib, urllib2
from xml.dom import minidom

base_url = 'test.com:8000'
username = 'MyId'
password = 'passwd'
search_query = 'search error | head 10'

# Login and get the session key
request = urllib2.Request(base_url + '/servicesNS/MyId/search/auth/login', 
data = urllib.urlencode({'username': username, 'password': password}))

server_content = urllib2.urlopen(request)

session_key = minidom.parseString(server_content.read()).\
getElementsByTagName('sessionKey')[0].childNodes[0].nodeValue
print "Session Key: %s" % session_key 

# Perform a search
request = urllib2.Request(base_url + '/servicesNS/MyId/search/search/jobs/export', 
data = urllib.urlencode({'search': search_query,'output_mode': 'json'}),
headers = { 'Authorization': ('Splunk %s' %session_key)})
search_results = urllib2.urlopen(request)
print search_results.read()

它会导致 404 错误,所以我决定使用 Curl。

我有这个卷曲推荐

  curl -k -u myID:Passwd -d 'search="google.com | head 10"' -d "output_mode=json" https://test.com:8089/servicesNS/myId/search/search/jobs/export

我正在尝试使用 pycurl 来调用 Joson。

如何将其转换为 pycurl?

先感谢您。

4

1 回答 1

7

将 curl 命令行转换为使用libcurl(如pycurl或其他绑定)的任何内容的最佳方法是运行附加了“ --libcurl output.c”的命令行,然后检查创建的胚胎为然后它显示 curl 必须做什么。

将该 C 代码转换为 pycurl 代码通常很简单。

于 2013-05-29T07:09:08.550 回答