在Swift&中调用Web API致命错误:字典文字包含重复的键

时间:2014-11-29 10:46:34

标签: ios objective-c iphone swift ios8

我使用了swift& amp; Objective-C使用它的参数调用API,我已经在Objective C中成功完成了但是我在Swift中面临一个问题,即用它的参数调用API。

我在两个参数中使用了相同的键,即“密码”。它不适用于Swift但它在Objective C中工作正常。

请指导我&更新我的Swift代码。

由于

Swift Code

var params: [String: String] = ["FirstName":name, "ContactNumber":contact, "Email":email, "password": password,"password":repassword,"Rd_UserType":type]


    var request = NSMutableURLRequest(URL: NSURL(string: "http://local.in/api/AccountApi")!)
    var session = NSURLSession.sharedSession()
    request.HTTPMethod = "POST"

    var err: NSError?
    request.HTTPBody = NSJSONSerialization.dataWithJSONObject(params, options: nil, error: &err)
    request.addValue("application/json", forHTTPHeaderField: "Content-Type")
    request.addValue("application/json", forHTTPHeaderField: "Accept")

var task = session.dataTaskWithRequest(request, completionHandler: {data, response, error -> Void in
        println("Response: \(response)")

错误

fatal error: dictionary literal contains duplicate keys

目标C代码工作正常。

Objective-C代码

        NSString *post =[[NSString alloc] initWithFormat:@"FirstName=%@&ContactNumber=%@&Email=%@&password=%@&password=%@&Rd_UserType=%@",Name.text,ContactNumber.text,EmailAddress.text,Password.text,ReTypePassword.text,type];


        NSLog(@"PostData: %@",post);

        NSURL *url=[NSURL URLWithString:@"http://local.in/api/AccountApi"];



        NSLog(@"%@",url);


        NSData *postData = [post dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES];

        NSString *postLength = [NSString stringWithFormat:@"%lu", (unsigned long)[postData length]];

        NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init];
        [request setURL:url];
        [request setHTTPMethod:@"POST"];
        [request setValue:postLength forHTTPHeaderField:@"Content-Length"];
        [request setValue:@"application/json" forHTTPHeaderField:@"Accept"];
        [request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"Content-Type"];
        [request setHTTPBody:postData];

        //[NSURLRequest setAllowsAnyHTTPSCertificate:YES forHost:[url host]];

        NSError *error = [[NSError alloc] init];
        NSHTTPURLResponse *response = nil;
        NSData *urlData=[NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error];

        NSLog(@"Response code: %ld", (long)[response statusCode]);

        if ([response statusCode] >= 200 && [response statusCode] < 300)
        {
            NSString *responseData = [[NSString alloc]initWithData:urlData encoding:NSUTF8StringEncoding];
            NSLog(@"Response ==> %@", responseData);
        }

2 个答案:

答案 0 :(得分:3)

您的Swift代码与Obj-C代码根本不同。 Swift相当于 到

NSString *post =[[NSString alloc] initWithFormat:@"FirstName=%@&ContactNumber=%@&Email=%@&password=%@&password=%@&Rd_UserType=%@",Name.text,ContactNumber.text,EmailAddress.text,Password.text,ReTypePassword.text,type];
NSData *postData = [post dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES];
NSString *postLength = [NSString stringWithFormat:@"%lu", (unsigned long)[postData length]];

会像

let post = "FirstName=\(Name.text)&ContactNumber=\(ContactNumber.text)&..."
let postData = post.dataUsingEncoding(NSASCIIStringEncoding, allowLossyConversion: true)!
let postLength = "\(postData.length)"

您正在创建一个JSON字典作为发布数据。那失败是因为a 字典不能有相同键的两个值。 JSON可能也不是 服务器期望的是什么。

答案 1 :(得分:1)

我已经解决了我的问题&amp;我使用过这段代码。

感谢。

    let post = String(format: "FirstName=%@&ContactNumber=%@&Email=%@&password=%@&password=%@&Rd_UserType=%@",name,contact,email,password,repassword,type)

    NSLog("PostData: %@",post);

    var url1:NSURL = NSURL(string: "http://local.in/api/AccountApi")!

    var postData:NSData = post.dataUsingEncoding(NSASCIIStringEncoding)!

    var postLength:NSString = String( postData.length )

    var request:NSMutableURLRequest = NSMutableURLRequest(URL: url1)


    request.HTTPMethod = "POST"
    request.HTTPBody = postData
    request.setValue(postLength, forHTTPHeaderField: "Content-Length")
    request.setValue("application/x-www-form-urlencoded", forHTTPHeaderField: "Content-Type")
    request.setValue("application/json", forHTTPHeaderField: "Accept")


    var reponseError: NSError?
    var response: NSURLResponse?

    var urlData: NSData? = NSURLConnection.sendSynchronousRequest(request, returningResponse:&response, error:&reponseError)

    if ( urlData != nil ) {
        let res = response as NSHTTPURLResponse!;

        NSLog("Response code: %ld", res.statusCode);

        if (res.statusCode >= 200 && res.statusCode < 300)
        {
            var responseData:NSString  = NSString(data:urlData!, encoding:NSUTF8StringEncoding)!

            NSLog("Response ==> %@", responseData);

            var error: NSError?

            let jsonData:NSDictionary = NSJSONSerialization.JSONObjectWithData(urlData!, options:NSJSONReadingOptions.MutableContainers , error: &error) as NSDictionary


            let success:NSInteger = jsonData.valueForKey("error") as NSInteger

            //[jsonData[@"success"] integerValue];

            NSLog("Success: %ld", success);

        }

    }