iOS开发之结合asp.net webservice实现文件上传下载

简介:

iOS开发中会经常用到文件上传下载的功能,这篇文件将介绍一下使用asp.net webservice实现文件上传下载。

首先,让我们看下文件下载。

这里我们下载cnblogs上的一个zip文件。使用NSURLRequest+NSURLConnection可以很方便的实现这个功能。

同步下载文件:

复制代码
        NSString *urlAsString =@"http://files.cnblogs.com/zhuqil/UIWebViewDemo.zip";
NSURL
*url = [NSURL URLWithString:urlAsString];
NSURLRequest
*request = [NSURLRequest requestWithURL:url];
NSError
*error = nil;
NSData
*data = [NSURLConnection sendSynchronousRequest:request
returningResponse:nil
error:
&error];
/* 下载的数据 */
if (data != nil){
NSLog(
@"下载成功");
if ([data writeToFile:@"UIWebViewDemo.zip" atomically:YES]) {
NSLog(
@"保存成功.");
}
else
{
NSLog(
@"保存失败.");
}
}
else {
NSLog(
@"%@", error);
}
复制代码

异步下载文件:

复制代码
- (void)viewDidLoad
{
[super viewDidLoad];
//文件地址
NSString *urlAsString =@"http://files.cnblogs.com/zhuqil/UIWebViewDemo.zip";
NSURL
*url = [NSURL URLWithString:urlAsString];
NSURLRequest
*request = [NSURLRequest requestWithURL:url];
NSMutableData
*data = [[NSMutableData alloc] init];
self.connectionData
= data;
[data release];
NSURLConnection
*newConnection = [[NSURLConnection alloc]
initWithRequest:request
delegate:self
startImmediately:YES];
self.connection
= newConnection;
[newConnection release];
if (self.connection != nil){
NSLog(
@"Successfully created the connection");
}
else {
NSLog(
@"Could not create the connection");
}
}




- (void) connection:(NSURLConnection *)connection
didFailWithError:(NSError
*)error{
NSLog(
@"An error happened");
NSLog(
@"%@", error);
}
- (void) connection:(NSURLConnection *)connection
didReceiveData:(NSData
*)data{
NSLog(
@"Received data");
[self.connectionData appendData:data];
}
- (void) connectionDidFinishLoading
:(NSURLConnection
*)connection{
/* 下载的数据 */

NSLog(
@"下载成功");
if ([self.connectionData writeToFile:@"UIWebViewDemo.zip" atomically:YES]) {
NSLog(
@"保存成功.");
}
else
{
NSLog(
@"保存失败.");
}

/* do something with the data here */
}
- (void) connection:(NSURLConnection *)connection
didReceiveResponse:(NSURLResponse
*)response{
[self.connectionData setLength:
0];
}

- (void) viewDidUnload{
[super viewDidUnload];
[self.connection cancel];
self.connection
= nil;
self.connectionData
= nil;
}
复制代码

从上面两段代码中可以看到同步与异步下载的区别,大部分时候我们使用异步下载文件。在asp.net webservice中可以将文件的地址返回到iOS系统,iOS系统在去请求下载该文件。

上传文件

我们先使用VB.Net写一个webservice方法,用于接收上传上来的文件数据,代码如下。

     <WebMethod(Description:= "上传文件!" )> _
Public  Function  UploadFile() As  XmlDocument
         Dim  doc As  XmlDocument = New  XmlDocument()
         Try
             Dim  postCollection As  HttpFileCollection = Context.Request.Files
             Dim  aFile As  HttpPostedFile = postCollection( "media" )
             aFile.SaveAs(Server.MapPath( "." ) + "/"  + Path.GetFileName(aFile.FileName))
             doc.LoadXml( "<xml>ok</xml>" )
             Return  doc
         Catch  ex As  Exception
             doc.LoadXml( "<xml>fail</xml>" )
             Return  doc
         End  Try
     End  Function

文件上传接口

定义一个类PicOperation用于处理上传图片:

@interface PicOperation : NSOperation
{
     UIImage *theImage;
}
@property (retain) UIImage *theImage;
@end
//
//  PicOperation.m
//  DownLoading
//
//  Created by skylin zhu on 11-7-30.
//  Copyright 2011年 mysoft. All rights reserved.
//
 
#import "PicOperation.h"
 
#define NOTIFY_AND_LEAVE(X) {[self cleanup:X]; return;}
#define DATA(X) [X dataUsingEncoding:NSUTF8StringEncoding]
 
// Posting constants
#define IMAGE_CONTENT @"Content-Disposition: form-data; name=\"%@\"; filename=\"image.jpg\"\r\nContent-Type: image/jpeg\r\n\r\n"
#define STRING_CONTENT @"Content-Disposition: form-data; name=\"%@\"\r\n\r\n"
#define MULTIPART @"multipart/form-data; boundary=------------0x0x0x0x0x0x0x0x"
 
@implementation  PicOperation
@synthesize  theImage;
 
//创建postdata
- ( NSData *)generateFormDataFromPostDictionary:( NSDictionary *)dict
{
     id  boundary = @ "------------0x0x0x0x0x0x0x0x" ;
     NSArray * keys = [dict allKeys];
     NSMutableData * result = [ NSMutableData  data];
     
     for  ( int  i = 0; i < [keys count]; i++)
     {
         id  value = [dict valueForKey: [keys objectAtIndex:i]];
         [result appendData:[[ NSString  stringWithFormat:@ "--%@\r\n" , boundary] dataUsingEncoding: NSUTF8StringEncoding ]];
         
         if  ([value isKindOfClass:[ NSData  class ]])
         {
             // handle image data
             NSString  *formstring = [ NSString  stringWithFormat:IMAGE_CONTENT, [keys objectAtIndex:i]];
             [result appendData: DATA(formstring)];
             [result appendData:value];
         }
         else
         {
             // all non-image fields assumed to be strings
             NSString  *formstring = [ NSString  stringWithFormat:STRING_CONTENT, [keys objectAtIndex:i]];
             [result appendData: DATA(formstring)];
             [result appendData:DATA(value)];
         }
         
         NSString  *formstring = @ "\r\n" ;
         [result appendData:DATA(formstring)];
     }
     
     NSString  *formstring =[ NSString  stringWithFormat:@ "--%@--\r\n" , boundary];
     [result appendData:DATA(formstring)];
     return  result;
}
//上传图片
- ( NSString  *) UpLoading
{
     if  (! self .theImage)
         NOTIFY_AND_LEAVE(@ "Please set image before uploading." );
     
     
     NSMutableDictionary * post_dict = [[ NSMutableDictionary  alloc] init];
     
     [post_dict setObject:@ "Posted from iPhone"  forKey:@ "message" ];
     [post_dict setObject:UIImageJPEGRepresentation( self .theImage, 0.75f) forKey:@ "media" ];
     
     NSData  *postData = [ self  generateFormDataFromPostDictionary:post_dict];
     [post_dict release];
     
     NSString  *baseurl = @ "http://10.5.23.121:7878/WorkflowService.asmx/UploadFile" ;
     NSURL  *url = [ NSURL  URLWithString:baseurl];
     NSMutableURLRequest  *urlRequest = [ NSMutableURLRequest  requestWithURL:url];
     if  (!urlRequest) NOTIFY_AND_LEAVE(@ "Error creating the URL Request" );
     
     [urlRequest setHTTPMethod: @ "POST" ];
     [urlRequest setValue:MULTIPART forHTTPHeaderField: @ "Content-Type" ];
     [urlRequest setHTTPBody:postData];
     
     // Submit & retrieve results
     NSError  *error;
     NSURLResponse  *response;
     NSLog (@ "Contacting TwitPic...." );
     NSData * result = [ NSURLConnection  sendSynchronousRequest:urlRequest returningResponse:&response error:&error];
     if  (!result)
     {
         [ self  cleanup:[ NSString  stringWithFormat:@ "Submission error: %@" , [error localizedDescription]]];
         return ;
     }
     
     // Return results
     NSString  *outstring = [[[ NSString  alloc] initWithData:result encoding: NSUTF8StringEncoding ] autorelease];
     return  outstring;
}
@end

这里我主要定义了两个方法,一个是generateFormDataFromPostDictionary用于创建post form data,一个是UpLoading供调用的类上传图片,这个类需要一个UIimage的对象。

类定义好了,上传图片就非常方便了,看下面代码:

PicOperation *pic = [[PicOperation alloc] init];
pic.theImage=[UIImage imageNamed:@ "meinv4.jpg" ];;
NSString  *result = [pic UpLoading];
NSLog (result);

总结:这篇文章讲述了如何在iOS中结合asp.net webservice实现文件的上传和下载功能。

 





本文转自麒麟博客园博客,原文链接:http://www.cnblogs.com/zhuqil/archive/2011/07/30/2122019.html,如需转载请自行联系原作者

相关文章
|
7天前
|
前端开发 Android开发 iOS开发
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
【4月更文挑战第30天】Flutter 框架实现跨平台移动应用,通过一致的 UI 渲染(Skia 引擎)、热重载功能和响应式框架提高开发效率和用户体验。然而,Android 和 iOS 的系统差异、渲染机制及编译过程影响性能。性能对比显示,iOS 可能因硬件优化提供更流畅体验,而 Android 更具灵活性和广泛硬件支持。开发者可采用代码、资源优化和特定平台优化策略,利用性能分析工具提升应用性能。
【Flutter前端技术开发专栏】Flutter在Android与iOS上的性能对比
|
7天前
|
存储 Swift iOS开发
使用Swift开发一个简单的iOS应用的详细步骤。
使用Swift开发iOS应用的步骤包括:创建Xcode项目,设计界面(Storyboard或代码),定义数据模型,实现业务逻辑,连接界面和逻辑,处理数据存储(如Core Data),添加网络请求(必要时),调试与测试,根据测试结果优化改进,最后提交至App Store或其它平台发布。
20 0
|
7天前
|
安全 Swift iOS开发
【Swift 开发专栏】Swift 与 UIKit:构建 iOS 应用界面
【4月更文挑战第30天】本文探讨了Swift和UIKit在构建iOS应用界面的关键技术和实践方法。Swift的简洁语法、类型安全和高效编程模型,加上与UIKit的紧密集成,使开发者能便捷地创建用户界面。UIKit提供视图、控制器、布局、动画和事件处理等功能,支持灵活的界面设计。实践中,遵循设计原则,合理组织视图层次,运用布局和动画,以及实现响应式设计,能提升界面质量和用户体验。文章通过登录、列表和详情界面的实际案例展示了Swift与UIKit的结合应用。
|
7天前
|
存储 安全 Swift
【Swift 开发专栏】使用 Swift 开发一个简单的 iOS 应用
【4月更文挑战第30天】本文介绍了使用 Swift 开发简单 iOS 待办事项应用的步骤。首先,阐述了 iOS 开发的吸引力及 Swift 语言的优势。接着,详细说明了应用的需求和设计,包括添加、查看和删除待办事项的功能。开发步骤包括创建项目、界面搭建、数据存储、功能实现,并提供了相关代码示例。最后,强调了实际开发中需注意的细节和优化,旨在帮助初学者掌握 Swift 和 iOS 开发基础。
|
8天前
|
人工智能 量子技术 C#
【专栏】.NET 开发:开启数字化新时代
【4月更文挑战第29天】.NET开发在数字化新时代中发挥关键作用,借助跨平台能力、高性能和现代编程语言支持,如C#,助力企业实现数字化转型。通过企业级应用开发、移动应用和云计算集成,.NET加速业务流程和提升用户体验。未来,.NET将涉足AI、ML、MR/AR及量子计算,持续推动技术创新和数字化转型。开发者应提升技能,适应高性能需求,把握发展机遇。
|
8天前
|
缓存 监控 算法
【专栏】.NET 开发:实现卓越性能的途径
【4月更文挑战第29天】本文探讨了.NET开发中的性能优化,强调了理解性能问题根源和使用分析工具的重要性。基础优化包括代码优化(如减少计算、避免内存泄漏)、资源管理及选择合适算法。高级策略涉及并行编程、缓存策略、预编译(AOT)和微服务架构。持续性能测试与监控是关键,包括性能测试、监控分析和建立优化反馈循环。开发者应持续学习和实践性能优化,以构建高性能应用。
|
8天前
|
开发框架 .NET C#
【专栏】理解.NET 技术,提升开发水平
【4月更文挑战第29天】本文介绍了.NET技术的核心概念和应用,包括其跨平台能力、性能优化、现代编程语言支持及Web开发等特性。文章强调了深入学习.NET技术、关注社区动态、实践经验及学习现代编程理念对提升开发水平的重要性。通过这些,开发者能更好地利用.NET构建高效、可维护的多平台应用。
|
8天前
|
机器学习/深度学习 vr&ar 开发者
【专栏】.NET 技术:引领开发新方向
【4月更文挑战第29天】本文探讨了.NET技术如何引领软件开发新方向,主要体现在三方面:1) 作为跨平台开发的先锋,.NET Core支持多操作系统和移动设备,借助.NET MAUI创建统一UI,适应物联网需求;2) 提升性能和开发者生产力,采用先进技术和优化策略,同时更新C#语言特性,提高代码效率和可维护性;3) 支持现代化应用架构,包括微服务、容器化,集成Kubernetes和ASP.NET Core,保障安全性。此外,.NET还不断探索AI、ML和AR/VR技术,为软件开发带来更多创新可能。
|
8天前
|
物联网 vr&ar 开发者
【专栏】.NET 技术:为开发注入活力
【4月更文挑战第29天】本文探讨了.NET技术的创新,主要体现在三个方面:1) .NET Core实现跨平台开发革命,支持多种操作系统和硬件,如.NET MAUI用于多平台UI;2) 性能提升与生产力飞跃,C#新特性简化编程,JIT和AOT优化提升性能,Roslyn提供代码分析工具;3) 引领现代化应用架构,支持微服务、容器化,内置安全机制。未来,.NET 7将带来更多新特性和前沿技术整合,如量子计算、AI,持续推动软件开发创新。开发者掌握.NET技术将赢得竞争优势。
|
8天前
|
人工智能 前端开发 Cloud Native
【专栏】洞察.NET 技术的开发趋势
【4月更文挑战第29天】本文探讨了.NET技术的三大发展趋势:1) 跨平台与云原生技术融合,通过.NET Core支持轻量级、高性能应用,适应云计算和微服务;2) 人工智能与机器学习的集成,如ML.NET框架,使开发者能用C#构建AI模型;3) 引入现代化前端开发技术,如Blazor,实现前后端一致性。随着.NET 8等新版本的发布,期待更多创新技术如量子计算、AR/VR的融合,.NET将持续推动软件开发的创新与进步。

相关实验场景

更多