使用IOS进行身份验证的Restful API调用

时间:2012-10-03 08:32:48

标签: ios api rest authentication prestashop

我正在开发一个使用prestashop API使用restful API调用的应用程序。我是IOS的新手我在android中编写了相同的方法:

    InputStream is = null;
try {

 DefaultHttpClient client = new DefaultHttpClient();  

    /* adding credentials as it is RESTful call */
    String username = "xyz";
    String password = "";
    client.getCredentialsProvider().setCredentials(new AuthScope(AuthScope.ANY_HOST, AuthScope.ANY_PORT),new UsernamePasswordCredentials(username, password));  
// HTTP get request       
HttpGet get = new HttpGet("http://www.example.com/api/");
HttpResponse responseGet;
responseGet = client.execute(get);
is = responseGet.getEntity().getContent();
} catch (ClientProtocolException e) {
    Log.e("HTTP Request","Client Protocol exception" );
} catch (IOException e) {
    Log.e("HTTP Request","IO exception" );
}

它适用于Android。对于IOS,我使用了这种编码,但我没有从服务器获取数据。

NSString *userName = @"XYZ";
NSString *password = @"";
//setting the string of the url taking from appliance IP.

NSString *urlString = @"http://www.example.com/api/";

NSMutableURLRequest *request= [[NSMutableURLRequest alloc] init];

[request setURL:[NSURL URLWithString:urlString]];

[request setHTTPMethod:@"GET"];

NSString *str1 = [NSString stringWithFormat:@"%@:%@",userName,password];

NSLog(@" str1 %@", str1);

[request addValue:[NSString stringWithFormat:@"Basic %@",str1] forHTTPHeaderField:@"Authorization"];

NSData *returnData = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];

NSString *str = [[NSString alloc] initWithData:returnData encoding:NSUTF8StringEncoding];
NSLog(@"str: %@", str);

请告诉我我做错了什么并提供任何解决方案。

谢谢!

3 个答案:

答案 0 :(得分:5)

您可以通过这种方式构建URL字符串,它应该可以工作: -

NSString *str1 = [NSString stringWithFormat:@"http://%@:%@@www.example.com/api",userName,password];

无需使用我认为的HTTP标头字段

答案 1 :(得分:3)

使用基本HTTP身份验证时,需要使用Base64编码对用户名和密码进行编码。

来自Wikipedia's Article on that subject

  

客户端

     

当用户代理想要发送服务器身份验证时   凭证可以使用授权标题。

     

Authorization标头的构造如下:[6]用户名和   密码组合成一个字符串“username:password”

     

然后使用Base64

对生成的字符串文字进行编码      

然后提出授权方法和空格,即“基本”   编码的字符串。例如,如果用户代理使用'Aladin'作为   用户名和'sesam open'作为密码然后标题是   形成如下:

Authorization: Basic QWxhZGluOnNlc2FtIG9wZW4=

请参阅此更正后的代码:

[...]
NSString *str1 = [NSString stringWithFormat:@"%@:%@",userName,password];
NSString *encodedString = [self stringByBase64EncodingWithString:str1];
[request addValue:[NSString stringWithFormat:@"Basic %@",encodedString] forHTTPHeaderField:@"Authorization"];
[...]


- (NSString *)stringByBase64EncodingWithString:(NSString *)inString
{
    NSData *data = [NSData dataWithBytes:[inString UTF8String] 
                                  length:[inString lengthOfBytesUsingEncoding:NSUTF8StringEncoding]];
    NSUInteger length = [data length];
    NSMutableData *mutableData = [NSMutableData dataWithLength:((length + 2) / 3) * 4];

    uint8_t *input = (uint8_t *)[data bytes];
    uint8_t *output = (uint8_t *)[mutableData mutableBytes];

    for (NSUInteger i = 0; i < length; i += 3) 
    {
        NSUInteger value = 0;
        for (NSUInteger j = i; j < (i + 3); j++) 
        {
            value <<= 8;
            if (j < length) 
            {
                value |= (0xFF & input[j]); 
            }
        }

        static uint8_t const base64EncodingTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";

        NSUInteger idx = (i / 3) * 4;
        output[idx + 0] = base64EncodingTable[(value >> 18) & 0x3F];
        output[idx + 1] = base64EncodingTable[(value >> 12) & 0x3F];
        output[idx + 2] = (i + 1) < length ? base64EncodingTable[(value >> 6)  & 0x3F] : '=';
        output[idx + 3] = (i + 2) < length ? base64EncodingTable[(value >> 0)  & 0x3F] : '=';
    }
    return [[NSString alloc] initWithData:mutableData encoding:NSASCIIStringEncoding];
}

答案 2 :(得分:0)

    -(void)getApiCall:(NSString *)urlString response:(NSMutableArray *)response{

    NSString *url= urlString;

    NSURL * serviceUrl = [NSURL URLWithString:url];

    NSMutableURLRequest * serviceRequest = [NSMutableURLRequest requestWithURL:serviceUrl cachePolicy:nil timeoutInterval:10.0];

    [serviceRequest setValue:@"Application/json" forHTTPHeaderField:@"Content-type"];

    [serviceRequest setHTTPMethod:@"GET"];

    NSURLResponse *serviceResponse;

    NSError *serviceError;

    NSData *responseData = [NSURLConnection sendSynchronousRequest:serviceRequest returningResponse:&serviceResponse error:&serviceError];

    NSLog(@"REQUEST  ==== >>>>  %@",serviceUrl);

    NSLog(@"RESPONSE ==== >>>>  %@",responseData);
    if (responseData != nil){
        [self parseGetData:responseData responseArray:response];
    }
    else{

    }
}


-(void)parseGetData:(NSData *)response responseArray:(NSMutableArray *)responseArray
{
    id jsonObject = Nil;
    NSString *charlieSendString = [[NSString alloc] initWithData:response encoding:NSUTF8StringEncoding];
    NSLog(@"ResponseString ==== >>>> %@",charlieSendString);

    if (response==nil) {

        NSLog(@"ERROR IN GET API....!!!!");

    }else{

        NSError *error = nil;
        jsonObject =[NSJSONSerialization JSONObjectWithData:response options:kNilOptions error:&error];


        if (error)
        {
            NSLog(@"%@",error);
        }
        else
        {
            NSError *error = Nil;
            jsonObject =[NSJSONSerialization JSONObjectWithData:response options:kNilOptions error:&error];

            if ([jsonObject isKindOfClass:[NSArray class]]) {
                NSLog(@"Probably An Array");
            }
            else
            {
                NSLog(@"Probably A Dictionary");
                NSDictionary *jsonDictionary=(NSDictionary *)jsonObject;
                NSLog(@"jsonDictionary %@",[jsonDictionary description]);
                if (jsonDictionary) {
                    [responseArray addObject:jsonDictionary];
                }
            }

        }

    }

}