多图片上传

最近在弄多文件上传,在网上找了些代码,只是单文件的,折腾了两天,终于改成多文件上传的了。
xcode 6.1
iOS 8.0测试成功
希望别的人不要像我一样花时间在修改上。时间就是生命啊。。
[objc]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. +(NSString *)PostImagesToServer:(NSString *) strUrl dicPostParams:(NSMutableDictionary *)params dicImages:(NSMutableDictionary *) dicImages{  
  2.     NSString * res;  
  3.       
  4.       
  5.     //分界线的标识符  
  6.     NSString *TWITTERFON_FORM_BOUNDARY = @"AaB03x";  
  7.     //根据url初始化request  
  8.     //NSMutableURLRequest* request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:strUrl] cachePolicy:NSURLRequestReloadIgnoringLocalCacheData timeoutInterval:10];  
  9.       
  10.     NSURL *url = [NSURL URLWithString:strUrl];  
  11.     NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];  
  12.     //分界线 --AaB03x  
  13.     NSString *MPboundary=[[NSString alloc]initWithFormat:@"--%@",TWITTERFON_FORM_BOUNDARY];  
  14.     //结束符 AaB03x--  
  15.     NSString *endMPboundary=[[NSString alloc]initWithFormat:@"%@--",MPboundary];  
  16.     //要上传的图片  
  17.     UIImage *image;//=[params objectForKey:@"pic"];  
  18.     //得到图片的data  
  19.     //NSData* data = UIImagePNGRepresentation(image);  
  20.     //http body的字符串  
  21.     NSMutableString *body=[[NSMutableString alloc]init];  
  22.     //参数的集合的所有key的集合  
  23.     NSArray *keys= [params allKeys];  
  24.       
  25.     //遍历keys  
  26.     for(int i=0;i<[keys count];i++) {  
  27.         //得到当前key  
  28.         NSString *key=[keys objectAtIndex:i];  
  29.         //如果key不是pic,说明value是字符类型,比如name:Boris  
  30.         //if(![key isEqualToString:@"pic"]) {  
  31.             //添加分界线,换行  
  32.             [body appendFormat:@"%@\r\n",MPboundary];  
  33.             //添加字段名称,换2行  
  34.             [body appendFormat:@"Content-Disposition: form-data; name=\"%@\"\r\n\r\n",key];  
  35.             //[body appendString:@"Content-Transfer-Encoding: 8bit"];  
  36.             //添加字段的值  
  37.             [body appendFormat:@"%@\r\n",[params objectForKey:key]];  
  38.         //}  
  39.     }  
  40.     添加分界线,换行  
  41.     //[body appendFormat:@"%@\r\n",MPboundary];  
  42.       
  43.     //声明myRequestData,用来放入http body  
  44.     NSMutableData *myRequestData=[NSMutableData data];  
  45.     //将body字符串转化为UTF8格式的二进制  
  46.     [myRequestData appendData:[body dataUsingEncoding:NSUTF8StringEncoding]];  
  47.       
  48.     //循环加入上传图片  
  49.     keys = [dicImages allKeys];  
  50.     for(int i = 0; i< [keys count] ; i++){  
  51.         //要上传的图片  
  52.         image = [dicImages objectForKey:[keys objectAtIndex:i ]];  
  53.         //得到图片的data  
  54.         NSData* data =  UIImageJPEGRepresentation(image, 0.0);  
  55.         NSMutableString *imgbody = [[NSMutableString alloc] init];  
  56.         //此处循环添加图片文件  
  57.         //添加图片信息字段  
  58.         //声明pic字段,文件名为boris.png  
  59.         //[body appendFormat:[NSString stringWithFormat: @"Content-Disposition: form-data; name=\"File\"; filename=\"%@\"\r\n", [keys objectAtIndex:i]]];  
  60.           
  61.         添加分界线,换行  
  62.         [imgbody appendFormat:@"%@\r\n",MPboundary];  
  63.         [imgbody appendFormat:@"Content-Disposition: form-data; name=\"File%d\"; filename=\"%@.jpg\"\r\n", i, [keys objectAtIndex:i]];  
  64.         //声明上传文件的格式  
  65.         [imgbody appendFormat:@"Content-Type: application/octet-stream; charset=utf-8\r\n\r\n"];  
  66.           
  67.         NSLog(@"上传的图片:%d  %@", i, [keys objectAtIndex:i]);  
  68.           
  69.         //将body字符串转化为UTF8格式的二进制  
  70.         //[myRequestData appendData:[body dataUsingEncoding:NSUTF8StringEncoding]];  
  71.         [myRequestData appendData:[imgbody dataUsingEncoding:NSUTF8StringEncoding]];  
  72.         //将image的data加入  
  73.         [myRequestData appendData:data];  
  74.         [myRequestData appendData:[ @"\r\n" dataUsingEncoding:NSUTF8StringEncoding]];  
  75.     }  
  76.     //声明结束符:--AaB03x--  
  77.     NSString *end=[[NSString alloc]initWithFormat:@"%@\r\n",endMPboundary];  
  78.     //加入结束符--AaB03x--  
  79.     [myRequestData appendData:[end dataUsingEncoding:NSUTF8StringEncoding]];  
  80.       
  81.     //设置HTTPHeader中Content-Type的值  
  82.     NSString *content=[[NSString alloc]initWithFormat:@"multipart/form-data; boundary=%@",TWITTERFON_FORM_BOUNDARY];  
  83.     //设置HTTPHeader  
  84.     [request setValue:content forHTTPHeaderField:@"Content-Type"];  
  85.     //[request setValue:@"keep-alive" forHTTPHeaderField:@"connection"];  
  86.     //[request setValue:@"UTF-8" forHTTPHeaderField:@"Charsert"];  
  87.     //设置Content-Length  
  88.     [request setValue:[NSString stringWithFormat:@"%lu", (unsigned long)[myRequestData length]] forHTTPHeaderField:@"Content-Length"];  
  89.     //设置http body  
  90.     [request setHTTPBody:myRequestData];  
  91.     //http method  
  92.     [request setHTTPMethod:@"POST"];  
  93.       
  94.     //建立连接,设置代理  
  95.     //NSURLConnection *conn = [[NSURLConnection alloc] initWithRequest:request delegate:self];  
  96.       
  97.     //设置接受response的data  
  98.          NSData *mResponseData;  
  99.     NSError *err = nil;  
  100.     mResponseData = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:&err];  
  101.       
  102.     if(mResponseData == nil){  
  103.         NSLog(@"err code : %@", [err localizedDescription]);  
  104.     }  
  105.     res = [[NSString alloc] initWithData:mResponseData encoding:NSUTF8StringEncoding];  
  106.     /* 
  107.     if (conn) { 
  108.         mResponseData = [NSMutableData data]; 
  109.         mResponseData = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:&err]; 
  110.          
  111.         if(mResponseData == nil){ 
  112.             NSLog(@"err code : %@", [err localizedDescription]); 
  113.         } 
  114.         res = [[NSString alloc] initWithData:mResponseData encoding:NSUTF8StringEncoding]; 
  115.     }else{ 
  116.         res = [[NSString alloc] init]; 
  117.     }*/  
  118.     NSLog(@"服务器返回:%@", res);  
  119.     return res;  
  120. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用以下代码来实现jQuery多图片上传: 首先,在HTML文件的<head>标签中引入jQuery库和相关的CSS和JS文件 。 然后,在<body>标签中创建一个<div>容器,用于显示上传的图片 。 接下来,在<script>标签中定义一个全局变量fileArr,用于保存选择的图片数组 。 然后,编写一个名为multipleFiles的函数,用于上传多个图片。在这个函数中,首先判断是否选择了需要上传的图片,如果没有则提示用户选择图片并返回 。然后,创建一个FormData对象fu,用于存储要上传的文件。接下来,使用一个循环将每个选择的文件添加到FormData对象中。最后,使用ajax将FormData对象发送到后台,并处理成功和失败的回调函数 。 最后,在页面加载完成后,调用上述的multipleFiles函数来实现多图片上传功能 。 请注意,您可以根据需要自定义相关参数,例如限制上传个数、像素限制等 。 以下是实现jQuery多图片上传的代码示例: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <link href="imgfileupload.css" rel="stylesheet"> </head> <body> <div class="imgupBox"></div> <script src="jquery.min.js"></script> <script type="text/javascript" src="imgFileupload.js"></script> <script type="text/javascript"> var fileArr = []; function multipleFiles() { var files = fileArr; var length = files.length; if (length == 0) { alert("请选择需要上传的图片!"); return; } var fu = new FormData(); for (var i = 0; i < files.length; i++) { fu.append("file", files[i]); } $.ajax({ type: "post", url: "/uploadimgs", data: fu, cache: false, contentType: false, processData: false, success: function(data, status) { alert("图片上传成功!"); }, error: function(data) { alert("图片上传失败!"); }, complete: function() {} }); } var imgFile = new ImgUploadeFiles('.imgupBox', function(e) { this.init({ MAX: 3, MH: 5800, MW: 5900, callback: function(arr) { fileArr = arr; console.log(arr); // 可以在这里调用multipleFiles函数来实现图片上传 } }); }); </script> </body> </html> ``` 请注意,上述代码仅为示例代码,您需要根据实际情况进行修改和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值