/LxFTPRequest

A convenient FTP request library for iOS and Mac OS X using Objective-C programming language. Support progress tracking, Breakpoint continuingly etc.

Primary LanguageObjective-CApache License 2.0Apache-2.0

LxFTPRequest

Installation

Only need add LxFTPRequest.h and LxFTPRequest.m to your project.

Introduction

    A convenient FTP Request library. Support progress tracking, Breakpoint continuingly etc.
    Support FTP get resource list, download file, update file, 
    create directory or file, delete directory or file etc.
    Support progress tracking, Breakpoint continuingly, 
    auto check legitimacy of ftp address and local file path functions and so on.

Support

    Both support iOS and Mac OS X platforms.
    Minimum support iOS version: iOS 5.0
    Minimum support OS X version: Mac OS X 10.7

Podfile

    pod 'LxFTPRequest', '~> 1.1.1'

How to use

    #import "LxFTPRequest.h"

Get resource list:

    LxFTPRequest * request = [LxFTPRequest resourceListRequest];
    request.serverURL = [[NSURL URLWithString:FTP_SCHEME_HOST]URLByAppendingPathComponent:SUB_DIRECTORY];
    request.username = USERNAME;
    request.password = PASSWORD;
    request.progressAction = ^(NSInteger totalSize, NSInteger finishedSize, CGFloat finishedPercent) {
        NSLog(@"totalSize = %ld, finishedSize = %ld, finishedPercent = %f", totalSize, finishedSize, finishedPercent); 
    };
    request.successAction = ^(Class resultClass, id result) {
        NSArray * resultArray = (NSArray *)result;
        NSLog(@"resultArray = %@", resultArray);  
    };
    request.failAction = ^(CFStreamErrorDomain domain, NSInteger error, NSString *errorMessage) {
        NSLog(@"domain = %ld, error = %ld", domain, error);
    };
    [request start];

Download resource:

    /**
        To implement breakpoint continuingly, you only need to guarantee
        the file downloaded part has not been modified in any way, 
        the ftp server support breakpoint continuingly
        and the file on server not change. 
        The download will continue from the last time progress.
        If you want to download resource from begin, you should delete the local downloaded part.
        [[NSFileManager defaultManager]removeItemAtPath:LOCAL_FILE_PATH error:&error];
    */

    LxFTPRequest * request = [LxFTPRequest downloadRequest];
    request.serverURL = [NSURL URLWithString:FTP_RESOURCE_ADDRESS];
    request.localFileURL = [NSURL fileURLWithPath:LOCAL_FILE_PATH];
    request.username = USERNAME;
    request.password = PASSWORD;
    request.progressAction = ^(NSInteger totalSize, NSInteger finishedSize, CGFloat finishedPercent) {
        NSLog(@"totalSize = %ld, finishedSize = %ld, finishedPercent = %f", totalSize, finishedSize, finishedPercent); 
    };
    request.successAction = ^(Class resultClass, id result) {
        NSLog(@"resultClass = %@, result = %@", resultClass, result);  
    };
    request.failAction = ^(CFStreamErrorDomain domain, NSInteger error, NSString *errorMessage) {
        NSLog(@"domain = %ld, error = %ld", domain, error);
    };
    [request start];

Upload resource:

    LxFTPRequest * request = [LxFTPRequest uploadRequest];
    request.serverURL = [NSURL URLWithString:FTP_SCHEME_HOST]URLByAppendingPathComponent:FILE_PATH];
    request.localFileURL = [NSURL fileURLWithPath:LOCAL_FILE_SAVE_PATH];
    request.username = USERNAME;
    request.password = PASSWORD;
    request.progressAction = ^(NSInteger totalSize, NSInteger finishedSize, CGFloat finishedPercent) {
        NSLog(@"totalSize = %ld, finishedSize = %ld, finishedPercent = %f", totalSize, finishedSize, finishedPercent); 
    };
    request.successAction = ^(Class resultClass, id result) {
        NSLog(@"resultClass = %@, result = %@", resultClass, result);
    };
    request.failAction = ^(CFStreamErrorDomain domain, NSInteger error, NSString *errorMessage) {
        NSLog(@"domain = %ld, error = %ld", domain, error);
    };
    [request start];

Create file or directory on ftp server:

    LxFTPRequest * request = [LxFTPRequest createResourceRequest];
    request.serverURL = [NSURL URLWithString:FTP_RESOURCE_PATH];    // directory path should be end up with '/'
    request.username = USERNAME;
    request.password = PASSWORD;
    request.successAction = ^(Class resultClass, id result) {
        NSLog(@"resultClass = %@, result = %@", resultClass, result);
    };
    request.failAction = ^(CFStreamErrorDomain domain, NSInteger error, NSString *errorMessage) {
        NSLog(@"domain = %ld, error = %ld", domain, error);
    };
    [request start];

Delete file or directory on ftp server:

    /**
        CANNOT DELETE EMPTY DIRECTORY!!!
    */
    LxFTPRequest * request = [LxFTPRequest destoryResourceRequest];
    request.serverURL = [NSURL URLWithString:FTP_RESOURCE_PATH];
    request.username = USERNAME;
    request.password = PASSWORD;
    request.successAction = ^(Class resultClass, id result) {
        NSLog(@"resultClass = %@, result = %@", resultClass, result);
    };
    request.failAction = ^(CFStreamErrorDomain domain, NSInteger error, NSString *errorMessage) {
        NSLog(@"domain = %ld, error = %ld", domain, error);
    };
    [request start];

Be careful

Demo must config FTP address, username, password correctly.

License

LxFTPRequest is available under the Apache License 2.0. See the LICENSE file for more info.