今天下午来到,运行了curl -i url:port ,然后返回的信息,用json.loads()解析,出报一下错误:
Traceback (most recent call last):
File "test1.py", line 12, in <module>
decodejson = json.loads(str1)
File "/usr/lib/python3.4/json/__init__.py", line 318, in loads
return _default_decoder.decode(s)
File "/usr/lib/python3.4/json/decoder.py", line 343, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python3.4/json/decoder.py", line 361, in raw_decode
raise ValueError(errmsg("Expecting value", s, err.value)) from None
ValueError: Expecting value: line 1 column 1 (char 0)
测试1:原来以为是python不能解析json的null,试着把json的null换成其他的字符串,发现还是报这个错。。。。后来查了一下 ,loads()可以将json的null转换成None的。。没毛病!
测试2:后来怀疑,运维传过来的字符串不是json格式。使用eval()函数判别返回数据类型,判断方式:
try
:
eval
(jsonStr)
except
Exception,e :
print
"不是json字符串"
发现,怀疑有理!,果然不是json,一步一步往上走;
测试3:既然不是json,那么要么是后台数据有问题,要么我调取的命令不对。。和后台的人一起测试,发现:果然是curl命令的问题。。。。。
curl -i XXXXX 返回的是整个http的内容。。。包括请求行。请求体。请求头。。。
而curl XXXX 返回的则只有http请求体。。。
总结一下:1、写代码,一定要写个逻辑判断,或者try。。catch。。 要不然bug真的很难找
2、有时间看一下curl,功能强大的一笔啊!