swift 如何上传图片到django 的后台服务器
2016-09-09 15:33
441 查看
本人用 django 做了一个后台,想作为移动端的后台使用,奈何一直被一个问题困扰,上传字符串很轻松的就实现了,但是上传文件或者图片总是失败,困扰了日之后终于解决了,原来一直以来方向都搞错了,一直认为是 django 的代码问题,后来才发现是 swift 方面的问题.不多说直接上代码.
swift :
let p1 = "p1"
let image : UIImage =UIImage(named:"屏幕快照
2016-09-02下午12.40.08.png")!
let imageData = UIImagePNGRepresentation(image)
//后台其他字段所需要的参数,要和后台一一对应
let parameters = [p1:"zhaobin"]
//fileName 可以自定义,显示在后台图片的名字
Alamofire.upload(.POST,"http://127.0.0.1:8000/polls/home",
multipartFormData: {
multipartFormData in
multipartFormData.appendBodyPart(data: imageData!, name:"p2", fileName:
"zhaobin.png", mimeType:"image/png")
for (key, value)in parameters {
multipartFormData.appendBodyPart(data: value.dataUsingEncoding(NSUTF8StringEncoding)!,
name: key )
}
}, encodingCompletion: {
encodingResult in
switch encodingResult {
case .Success(let upload,_,
_):
upload.responseJSON {
response in
debugPrint(response)
}
case .Failure(let encodingError):
print(encodingError)
}
})
django :
接收 html :
swift :
let p1 = "p1"
let image : UIImage =UIImage(named:"屏幕快照
2016-09-02下午12.40.08.png")!
let imageData = UIImagePNGRepresentation(image)
//后台其他字段所需要的参数,要和后台一一对应
let parameters = [p1:"zhaobin"]
//fileName 可以自定义,显示在后台图片的名字
Alamofire.upload(.POST,"http://127.0.0.1:8000/polls/home",
multipartFormData: {
multipartFormData in
multipartFormData.appendBodyPart(data: imageData!, name:"p2", fileName:
"zhaobin.png", mimeType:"image/png")
for (key, value)in parameters {
multipartFormData.appendBodyPart(data: value.dataUsingEncoding(NSUTF8StringEncoding)!,
name: key )
}
}, encodingCompletion: {
encodingResult in
switch encodingResult {
case .Success(let upload,_,
_):
upload.responseJSON {
response in
debugPrint(response)
}
case .Failure(let encodingError):
print(encodingError)
}
})
django :
def homeApp(request): p1 = request.POST.get('p1')
// 前台上传的文件 image = request.FILES.get('p2')
// ExamInfo model 中定义的 class test = ExamInfo() test.level = image test.name = p1 test.save()
接收 html :
class NormalUserForm(forms.Form): username = forms.CharField() headImg = forms.FileField() def registerNormalUser(request): if request.method == "POST": uf = NormalUserForm(request.POST,request.FILES) if uf.is_valid(): # get the info of the form cleaned_data :处理或得到的数据,让 username 和 uf 获得数据类型一致 username = uf.cleaned_data['username'] headImg = uf.cleaned_data['headImg'] # write in database normalUser = NormalUser() normalUser.username = username normalUser.headImg = headImg normalUser.save() return HttpResponse('Upload Succeed!') else: uf = NormalUserForm() return render(request,'polls/register.html',{'uf':uf})
相关文章推荐
- django 如何将用户上传的图片展示在后台(列表页),缩略图而不是地址
- 如何将含有大量图片或公式的word文档上传到web服务器
- iPhone SDK开发: 如何上传图片文件到服务器
- Ecshop如何把后台编辑器中商品详细描述中上传的图片分目录保存
- 如何使用http或httpClient向服务器上传图片 以及使用http上传图片时协议的描述
- android上传图片(及普通参数)到服务器(j2ee后台服务器,ssh框架)
- 如何将含有大量图片或公式的word文档上传到web服务器
- java上传图片到另一台服务器上,如何解决
- 关于android上传图片,视频,音频到rails后台服务器
- PHP服务端如何通过程序将图上传到指定的图片服务器与图片服务器的优化方案
- django/js 前后台对图片上传的处理
- 上传图片并保存到服务器上之后,如何得到该图片服务器路径(http://~)
- express(jade或ejs)如何实现上传图片到服务器并在客户端展示(在客户端可以删除)
- AFNetworking如何向服务器提交图片 ios中获取图片并上传图片
- Winform如何通过TextBox上传图片到服务器
- winform如何上传图片到服务器
- 关于如何把canvas中的内容转换为图片上传到服务器的操作过程
- Android如何实现压缩图片后再上传至服务器
- jsp中如何上传图片到服务器
- Android前段与后台服务器的图片上传与下载