OC实现连接服务器

以OC作为终端调用PHP代码操作服务器和数据库:

OC部分代码:

+ (void)requestService:(NSString *)url

            parameters:(NSDictionary *)parameter

             onSuccess:(void (^)(NSDictionary *))successHandler

             onFailure:(void (^)(NSError *))failureHandler

{

    __block NSData *httpBody = nil;

    NSError *error;

    httpBody = [NSJSONSerialization dataWithJSONObject:parameter options:NSJSONWritingPrettyPrinted error:&error];

    NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:url]

                                                           cachePolicy:NSURLRequestUseProtocolCachePolicy

                                                       timeoutInterval:10];//请求这个地址, timeoutInterval:10 设置为10s超时:请求时间超过10s会被认为连接不上,连接超时

    [request setHTTPMethod:@"POST"];//POST请求

    [request setHTTPBody:httpBody];//body 数据

    [request setValue:[NSString stringWithFormat:@"application/x-www-form-urlencoded"] forHTTPHeaderField:@"Content-type"];//请求头  //application/json

    

    NSOperationQueue *queue=[NSOperationQueue mainQueue];

    [NSURLConnection sendAsynchronousRequest:request queue:queue completionHandler:^(NSURLResponse * _Nullable response, NSData * _Nullable data, NSError * _Nullable connectionError) {

        if (data)

        {

            NSError *jsonError = nil;

            NSString *string = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];

            NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:data

                                                                options:kNilOptions

                                                                  error:&jsonError];

            NSLog(@"dic: %@, string: %@", dic, string);

            if (dic)

            {

                successHandler(dic);

            }

            else

            {

                failureHandler(jsonError);

            }

        }

    }];

}

 

服务器部分代码:

<?php
header("Content-Type: application/x-www-form-urlencoded;charset=utf-8");

// $info = file_get_contents('php://input', 'r');

// if (strlen($info) < 1)
// {
// echo 'error';
// echo '<br/>';
// # code...
// }
// else
// {
// $infoArray = json_decode($info, true);
// if (!$infoArray)
// {
// die('数据格式错误');
// # code...
// }
// else
// {
// $infoJson = json_encode($infoArray);
// echo $infoJson;
// }
// }

// die();

// echo "this is a test</br>";
// echo "helloWorld!</br><br>";
$mysql_server_name = "127.0.0.1:3306";
$mysql_username = "root";
$mysql_password = "123";
$mysql_database = "fb";

$connect = mysql_connect($mysql_server_name, $mysql_username, $mysql_password);

$strsql = "select * from MyTable";
$result = mysql_db_query($mysql_database, $strsql, $connect);

$row = mysql_fetch_row($result);

for ($i=0; $i < mysql_num_fields($result); $i++)
{
//显示列名
$name = mysql_field_name($result, $i);
}

//将 data 参数指定的 MySQL 结果内部的行指针移动到指定的行号。

mysql_data_seek($result, 0);

$arr = array();
while ($row = mysql_fetch_array($result))
{
$userinfo = array('id'=>$row['id'], 'name'=>$row['name'], 'sex'=>$row['sex']);
$arr[] = $userinfo;
}
$data = json_encode($arr);
echo $data;

mysql_free_result($result);
mysql_close($connect);
?>

(注:PHP接收Json数据时,当时使用了$GLOBALS['HTTP_RAW_POST_DATA'],虽然能获取到所有的数据内容,但是无法识别数据内容,就将数据原样地填入变量$http_raw_post_data,可以参考http://jingyan.baidu.com/article/455a9950a88eaca16627788e.html,所以最后选择使用file_get_contents('php://input', 'r'),上面例子中直接返回了访问数据库的内容,连接服务器数据库建议初学者使用mamp,操作略微简单,不用配置环境)

posted @ 2015-11-24 11:09  老茶叶  阅读(601)  评论(0)    收藏  举报