我想将文件上传到网络服务器,我已经为此编写了一个简单的客户端文件。
client.py
import requests
def main():
url_link = "http://localhost:8000/Home/UploadFile/"
fileObj= open('VOI-0204.zip', 'rb')
r=requests.post(url_link, files={'docfile': fileObj})
print r.text
if __name__ == '__main__':
main()
django url映射器声明如下:
urls.py
url(r'^Home/UploadFile/$', 'WebApp.views.uploadZip', name='uploadZip'),
每次我运行client.py时都会给出403这样的错误。
[29/Aug/2015 10:28:02] "POST /Home/UploadFile/ HTTP/1.1" 403 2282
但是如果我像这样更改客户端文件中的url_link
url_link = "http://localhost:8000/Home/UploadFile"
现在它显示像这样的服务器错误[500]
[29/Aug/2015 10:33:32] "POST /Home/UploadFile HTTP/1.1" 500 63766
任何想法??
答案 0 :(得分:2)
Django期望每个POST请求都有一个CSRF令牌。由csrf_exempt
装饰器装饰您的视图,以便允许此脚本成功运行。检查this。虽然我不建议走这条路。 CSRF令牌是为了您的保护。
from django.views.decorators.csrf import csrf_exempt
@csrf_exempt
def upload_zip(request):
...
答案 1 :(得分:0)
您需要在视图中添加csrf标记,如果您使用的是表单,请添加{%csrf_token%}。 如果您需要执行ajax请求,则需要实现一些javascript代码。 Django官方文档有一些关于它的好文章,你可以看到https://docs.djangoproject.com/en/1.7/ref/contrib/csrf/