论坛首页 编程语言技术论坛

关于Django-1.3版本的bug说明

浏览 3363 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2011-10-11  
  近期将Django-1.3用于生产环境,偶然发现在自定义爬虫请求时候报错:

Request Method: POST
Request URL: 
Django Version: 1.3
Exception Type: AttributeError
Exception Value: 'NoneType' object has no attribute 'startswith'
Exception Location: /usr/local/lib/python2.6/site-packages/django/http/__init__.py in _load_post_and_files, line 269

仔细检查django源码,发现在/site-packages/django/http/__init__.py 文件的269行
self.META.get('CONTENT_TYPE', '')没有做空值判断所以产生此空指针异常

如果用1.3版本的同学 遇到此问题

解决方法:在客户端请求接口处增加'CONTENT_TYPE' Header信息即可

最好的解决方法:
把269行
if self.META.get('CONTENT_TYPE', '').startswith('multipart'):

换成以下三行(主要做一个None值的处理)
rose_change = self.META.get('CONTENT_TYPE', '')
if rose_change == None: rose_change = ''
if rose_change.startswith('multipart'):

   发表时间:2011-10-27  
不对吧
self.META.get('CONTENT_TYPE', '')

这句话本身的作用就是取CONTENT_TYPE的值,取不到则默认给他第二个参数也就是''
0 请登录后投票
   发表时间:2011-10-31  
zhoulei984623 写道
不对吧
self.META.get('CONTENT_TYPE', '')

这句话本身的作用就是取CONTENT_TYPE的值,取不到则默认给他第二个参数也就是''

你可以试一下然后看看,我这边反正是None 版本是1.3的
0 请登录后投票
   发表时间:2011-11-04  
qyhdt 写道
zhoulei984623 写道
不对吧
self.META.get('CONTENT_TYPE', '')

这句话本身的作用就是取CONTENT_TYPE的值,取不到则默认给他第二个参数也就是''

你可以试一下然后看看,我这边反正是None 版本是1.3的

难道是 self.META 里面有 "CONTENT_TYPE" : None 这样的数据存在?
0 请登录后投票
   发表时间:2011-11-07  
tonyseek 写道
qyhdt 写道
zhoulei984623 写道
不对吧
self.META.get('CONTENT_TYPE', '')

这句话本身的作用就是取CONTENT_TYPE的值,取不到则默认给他第二个参数也就是''

你可以试一下然后看看,我这边反正是None 版本是1.3的

难道是 self.META 里面有 "CONTENT_TYPE" : None 这样的数据存在?


看清楚问题 “偶然发现在自定义爬虫请求时候报错:”
你自己模拟http请求 不写CONTENT_TYPE当然就为None了
0 请登录后投票
论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics