首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >基于Django类的视图返回一个空的帖子字典

基于Django类的视图返回一个空的帖子字典
EN

Stack Overflow用户
提问于 2013-07-03 03:26:09
回答 2查看 1K关注 0票数 0

我有一个定义如下的django视图。

代码语言:javascript
运行
复制
class SomeView(View):

    def post(self, request, *args, **kwargs):
        print "###############################"
        print request.POST
        print "###############################"
        return HttpResponse(json.dumps(kwargs), mimetype='application/json')

当我发出任意的curl请求时,比如

代码语言:javascript
运行
复制
 curl -X POST -H "Content-Type: application/json"  '{"hello":"world"}' http://localhost:8000/blog/

我得到了一个空字典作为响应,控制台输出如下

代码语言:javascript
运行
复制
###############################
<QueryDict: {}>
###############################

为什么此视图不接受任何数据?另外,还应该注意的是,我注释掉了

代码语言:javascript
运行
复制
'django.middleware.csrf.CsrfViewMiddleware',

当我调用self.request时,我得到以下输出

代码语言:javascript
运行
复制
#################################
<WSGIRequest
path:/blog/,
GET:<QueryDict: {}>,
POST:<QueryDict: {}>,
COOKIES:{},
META:{'CCACHE_HASHDIR': '',
 'COLORTERM': 'gnome-terminal',
 'CONTENT_LENGTH': '16',
 'CONTENT_TYPE': 'application/json',
 'CVS_RSH': 'ssh',
 'DBUS_SESSION_BUS_ADDRESS': 'unix:abstract=/tmp/dbus-FukIqsBHiS,guid=2bc53020b746b1753871d45a51ce0be2',
 'DESKTOP_SESSION': 'gnome',
 'DISPLAY': ':0',
 'DJANGO_SETTINGS_MODULE': 'mongoblog.settings',
 'GATEWAY_INTERFACE': 'CGI/1.1',
 'GDMSESSION': 'gnome',
 'GJS_DEBUG_OUTPUT': 'stderr',
 'GJS_DEBUG_TOPICS': 'JS ERROR;JS LOG',
 'GNOME_DESKTOP_SESSION_ID': 'this-is-deprecated',
 'GNOME_KEYRING_CONTROL': '/run/user/1000/keyring-wmgVNG',
 'GNOME_KEYRING_PID': '1262',
 'GPG_AGENT_INFO': '/run/user/1000/keyring-wmgVNG/gpg:0:1',
 'HISTCONTROL': 'ignoredups',
 'HISTSIZE': '1000',
 'HOME': '/home/username',
 'HOSTNAME': 'localhost.localdomain',
 'HTTP_ACCEPT': '*/*',
 'HTTP_HOST': 'localhost:8000',
 'HTTP_USER_AGENT': 'curl/7.27.0',
 'IMSETTINGS_INTEGRATE_DESKTOP': 'yes',
 'IMSETTINGS_MODULE': 'none',
 'KRB5CCNAME': 'DIR:/run/user/1000/krb5cc_a3b7d843fdc5b71dcc827ae551ce0bd1',
 'LANG': 'en_US.UTF-8',
 'LESSOPEN': '||/usr/bin/lesspipe.sh %s',
 'LOGNAME': 'username',
 'LS_COLORS': 'rs=0:di=38;5;27:ln=38;5;51:mh=44;38;5;15:pi=40;38;5;11:so=38;5;13:do=38;5;5:bd=48;5;232;38;5;11:cd=48;5;232;38;5;3:or=48;5;232;38;5;9:mi=05;48;5;232;38;5;15:su=48;5;196;38;5;15:sg=48;5;11;38;5;16:ca=48;5;196;38;5;226:tw=48;5;10;38;5;16:ow=48;5;10;38;5;21:st=48;5;21;38;5;15:ex=38;5;34:*.tar=38;5;9:*.tgz=38;5;9:*.arj=38;5;9:*.taz=38;5;9:*.lzh=38;5;9:*.lzma=38;5;9:*.tlz=38;5;9:*.txz=38;5;9:*.zip=38;5;9:*.z=38;5;9:*.Z=38;5;9:*.dz=38;5;9:*.gz=38;5;9:*.lz=38;5;9:*.xz=38;5;9:*.bz2=38;5;9:*.tbz=38;5;9:*.tbz2=38;5;9:*.bz=38;5;9:*.tz=38;5;9:*.deb=38;5;9:*.rpm=38;5;9:*.jar=38;5;9:*.war=38;5;9:*.ear=38;5;9:*.sar=38;5;9:*.rar=38;5;9:*.ace=38;5;9:*.zoo=38;5;9:*.cpio=38;5;9:*.7z=38;5;9:*.rz=38;5;9:*.jpg=38;5;13:*.jpeg=38;5;13:*.gif=38;5;13:*.bmp=38;5;13:*.pbm=38;5;13:*.pgm=38;5;13:*.ppm=38;5;13:*.tga=38;5;13:*.xbm=38;5;13:*.xpm=38;5;13:*.tif=38;5;13:*.tiff=38;5;13:*.png=38;5;13:*.svg=38;5;13:*.svgz=38;5;13:*.mng=38;5;13:*.pcx=38;5;13:*.mov=38;5;13:*.mpg=38;5;13:*.mpeg=38;5;13:*.m2v=38;5;13:*.mkv=38;5;13:*.ogm=38;5;13:*.mp4=38;5;13:*.m4v=38;5;13:*.mp4v=38;5;13:*.vob=38;5;13:*.qt=38;5;13:*.nuv=38;5;13:*.wmv=38;5;13:*.asf=38;5;13:*.rm=38;5;13:*.rmvb=38;5;13:*.flc=38;5;13:*.avi=38;5;13:*.fli=38;5;13:*.flv=38;5;13:*.gl=38;5;13:*.dl=38;5;13:*.xcf=38;5;13:*.xwd=38;5;13:*.yuv=38;5;13:*.cgm=38;5;13:*.emf=38;5;13:*.axv=38;5;13:*.anx=38;5;13:*.ogv=38;5;13:*.ogx=38;5;13:*.aac=38;5;45:*.au=38;5;45:*.flac=38;5;45:*.mid=38;5;45:*.midi=38;5;45:*.mka=38;5;45:*.mp3=38;5;45:*.mpc=38;5;45:*.ogg=38;5;45:*.ra=38;5;45:*.wav=38;5;45:*.axa=38;5;45:*.oga=38;5;45:*.spx=38;5;45:*.xspf=38;5;45:',
 'MAIL': '/var/spool/mail/username',
 'OLDPWD': '/home/username/Programming/Python/Django/MongoRest/mongoblog/blog',
 'PATH': '/usr/lib64/qt-3.3/bin:/usr/lib64/ccache:/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/home/username/.local/bin:/home/username/bin',
 'PATH_INFO': u'/blog/',
 'PWD': '/home/username/Programming/Python/Django/MongoRest/mongoblog',
 'QTDIR': '/usr/lib64/qt-3.3',
 'QTINC': '/usr/lib64/qt-3.3/include',
 'QTLIB': '/usr/lib64/qt-3.3/lib',
 'QT_GRAPHICSSYSTEM_CHECKED': '1',
 'QT_IM_MODULE': 'ibus',
 'QUERY_STRING': '',
 'REMOTE_ADDR': '127.0.0.1',
 'REMOTE_HOST': '',
 'REQUEST_METHOD': 'POST',
 'RUN_MAIN': 'true',
 'SCRIPT_NAME': u'',
 'SERVER_NAME': 'localhost.localdomain',
 'SERVER_PORT': '8000',
 'SERVER_PROTOCOL': 'HTTP/1.1',
 'SERVER_SOFTWARE': 'WSGIServer/0.1 Python/2.7.3',
 'SESSION_MANAGER': 'local/unix:@/tmp/.ICE-unix/1264,unix/unix:/tmp/.ICE-unix/1264',
 'SHELL': '/bin/bash',
 'SHLVL': '2',
 'SSH_AUTH_SOCK': '/run/user/1000/keyring-wmgVNG/ssh',
 'TERM': 'xterm-256color',
 'TZ': 'America/Denver',
 'USER': 'username',
 'USERNAME': 'username',
 'WINDOWID': '35702123',
 'WINDOWPATH': '1',
 'XAUTHORITY': '/var/run/gdm/auth-for-username-jI22V1/database',
 'XDG_MENU_PREFIX': 'gnome-',
 'XDG_RUNTIME_DIR': '/run/user/1000',
 'XDG_SEAT': 'seat0',
 'XDG_SESSION_ID': '2',
 'XDG_VTNR': '1',
 'XMODIFIERS': '@im=ibus',
 '_': '/usr/bin/python',
 'wsgi.errors': <open file '<stderr>', mode 'w' at 0x7f9dba515270>,
 'wsgi.file_wrapper': <class wsgiref.util.FileWrapper at 0x2b7fe20>,
 'wsgi.input': <socket._fileobject object at 0x7f9da84e6250>,
 'wsgi.multiprocess': False,
 'wsgi.multithread': True,
 'wsgi.run_once': False,
 'wsgi.url_scheme': 'http',
 'wsgi.version': (1, 0)}>
#################################

此外,这是我的应用程序中的urls.py文件

代码语言:javascript
运行
复制
urlpatterns = patterns('',
url(r'^$',SomeView.as_view()),
)

而全局urls.py文件是

代码语言:javascript
运行
复制
urlpatterns = patterns('',
    url(r'^blog/', include('blog.urls')),
)

此外,我还添加了打印kwargs和args的调用,并获取

代码语言:javascript
运行
复制
#################################
<QueryDict: {}>
{}
()
#################################
EN

回答 2

Stack Overflow用户

发布于 2013-07-03 05:43:01

request.POST属性用于表单编码数据。您正在发布json编码的数据,因此请改用request.BODY

有关更多信息,请参阅http request objects上的文档。

最后,are和kwargs与过去的数据无关。它们是空的,因为你没有匹配你的url中的任何模式。

票数 2
EN

Stack Overflow用户

发布于 2013-07-03 04:04:38

下面的几点纠正至少应该给你指明正确的方向:

当使用基于类的视图时,可以通过self.request

  • Use

  • 从curl手册页访问请求参数:

-d,--data ( HTTP )在POST请求中将指定的数据发送到HTTP服务器,这与浏览器在用户填写HTML表单并按下submit按钮时所做的操作相同。这将导致curl使用内容类型application/x-www-form-urlencoded将数据传递到服务器。与-F相比,--form。数据,-d与--data-ascii相同。要发布纯二进制数据,您应该使用-- data -binary选项。要对表单字段的值进行URL编码,可以使用--data-urlencode。如果在同一命令行中多次使用这些选项中的任何一个,则指定的数据片段将与分隔符&-合并在一起。因此,使用'-d name=daniel -d skill=lousy‘将生成一个类似于'name=daniel&skill=lousy’的post块。如果数据以字母@开头,其余部分应该是要从中读取数据的文件名,或者-如果您希望curl从标准输入中读取数据。文件的内容必须已经是URL编码的。还可以指定多个文件。因此,可以使用--data @foobar从名为'foobar‘的文件中发布数据。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17434149

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档