16

我对objective-c 相当陌生,并且希望使用POST 将一些键值对传递给PHP 脚本。我正在使用以下代码,但数据似乎没有被发布。我也尝试通过使用 NSData 发送东西,但似乎都没有工作。

 NSDictionary* data = [NSDictionary dictionaryWithObjectsAndKeys:
    @"bob", @"sender",
    @"aaron", @"rcpt",
    @"hi there", @"message",
    nil];

 NSURL *url = [NSURL URLWithString:@"http://myserver.com/script.php"];
 NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:url];

 [request setHTTPMethod:@"POST"];
 [request setHTTPBody:[NSData dataWithBytes:data length:[data count]]];

  NSURLResponse *response;
  NSError *err;
  NSData *responseData = [NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&err];
  NSLog(@"responseData: %@", content);

这将被发送到这个简单的脚本以执行数据库插入:

<?php $sender = $_POST['sender'];
      $rcpt = $_POST['rcpt'];
      $message = $_POST['message'];

      //script variables
      include ("vars.php");

      $con = mysql_connect($host, $user, $pass);
      if (!$con)
      {
        die('Could not connect: ' . mysql_error());
      }

      mysql_select_db("mydb", $con);

      mysql_query("INSERT INTO php_test (SENDER, RCPT, MESSAGE) 
      VALUES ($sender, $rcpt, $message)");

      echo "complete"
?>

有任何想法吗?

4

6 回答 6

35

谢谢大家的建议。最后我设法通过使用这里给出的东西解决了这个问题。

代码:

NSString *myRequestString = @"sender=my%20sender&rcpt=my%20rcpt&message=hello";
NSData *myRequestData = [ NSData dataWithBytes: [ myRequestString UTF8String ] length: [ myRequestString length ] ];
NSMutableURLRequest *request = [ [ NSMutableURLRequest alloc ] initWithURL: [ NSURL URLWithString: @"http://people.bath.ac.uk/trs22/insert.php" ] ]; 
[ request setHTTPMethod: @"POST" ];
[ request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"content-type"];
[ request setHTTPBody: myRequestData ];
NSURLResponse *response;
NSError *err;
NSData *returnData = [ NSURLConnection sendSynchronousRequest: request returningResponse:&response error:&err];
NSString *content = [NSString stringWithUTF8String:[returnData bytes]];
NSLog(@"responseData: %@", content);
于 2010-03-31T10:24:55.207 回答
4

这是错误的:

[NSData dataWithBytes:[post UTF8String] length:[post length]]

长度应以字节表示,而不是 UTF8 字符数。而不是这一行,你应该使用:

NSData *data = [post dataUsingEncoding: NSUTF8StringEncoding]; 
于 2010-10-22T13:27:56.307 回答
2

这条线[request setHTTPBody:[NSData dataWithBytes:data length:[data count]]];在我看来是错误的。

我想你想要:[request setAllHTTPHeaderFields:data];

其次,您会发现 Cocoa 框架在发送字段名称之前将其首字母大写(令人讨厌)。您可能需要进行一些更改以应对这种情况。

于 2010-03-30T15:50:48.503 回答
2

如果您要进行大量表单发布,我建议您跳过 NSURLRequest 并改用ASIHTTPRequest。恕我直言,它有据可查,并提供了一种与 Web 服务交互的直接方式。

于 2010-03-30T20:52:57.800 回答
1

这适用于 IOS 5.o 表单发布和获取数据:

self.requestFor = serviceNameT;

responseData = [[NSMutableData data] retain];

SharedResponsedObject* sharedResponsedObject = [SharedResponsedObject returnSharedInstance];
LoginInfo* loginInfo = (LoginInfo*)sharedResponsedObject.loginInfo;

NSLog(@"DEVICE_TOKEN: %@, loginInfo.sessionId: %@, itemIdT: %@", DEVICE_TOKEN, loginInfo.sessionId, itemIdT);

NSString* requestStr = [NSString stringWithFormat:@"Token=%@&SessionId=%@&ItemId=%@", DEVICE_TOKEN, loginInfo.sessionId, itemIdT];


NSData *myRequestData = [ NSData dataWithBytes: [ requestStr UTF8String ] length: [ requestStr length ] ];

NSMutableURLRequest *request = [[ NSMutableURLRequest alloc ] initWithURL: [ NSURL URLWithString:@"http://menca.com:1500/DownloadContent.aspx"]]; 

[request setHTTPMethod: @"POST" ];
[request setValue:@"application/x-www-form-urlencoded" forHTTPHeaderField:@"content-type"];
[ request setHTTPBody: myRequestData ];


NSURLResponse *response;
NSError *err;
NSData *returnData = [ NSURLConnection sendSynchronousRequest: request returningResponse:&response error:&err];
NSString *content = [NSString stringWithUTF8String:[returnData bytes]];
NSLog(@"ServerRequestResponse::responseData: %@", content);

谢谢和问候, 阿伦·德瓦吉

于 2012-05-18T06:49:41.443 回答
0

编辑:已在 OP 中修复。


这可能不是您唯一的问题(我不知道如何绕过objective-c),但这里有:

mysql_query("INSERT INTO php_test (SENDER, RCPT, MESSAGE) 
VALUES ($sender, $rcpt, $message)");

你不是用引号括起来你的字符串——MySQL 肯定会对此感到厌烦。

mysql_query("INSERT INTO php_test (SENDER, RCPT, MESSAGE) 
VALUES ('$sender', '$rcpt', '$message')");

除此之外,通常,即使您的脚本无法从外部访问,您也不应该信任用户输入,并且在mysql_real_escape_string()将值插入 SQL 语句之前使用转义值以防止 SQL 注入,或者使用准备好的语句(首选) - 否则合法数据中的单引号会破坏 SQL 语句的语法。

完全不优雅的例子供参考:

mysql_query("INSERT INTO php_test (SENDER, RCPT, MESSAGE) 
VALUES ('" . mysql_real_escape_string($sender) ."',"
." '" . mysql_real_escape_string($rcpt) ."',"
." '" . mysql_real_escape_string($message) ."')");
于 2010-03-30T11:25:34.037 回答