文章目的简单的介绍一下客户端如何和后台交互,以简单的注册为例;
PHP代码编写可以使用PhpStorm,mac环境下这个开发工具还是很好用的,本地环境的搭建使用XAMPP(XAMPP 是一个把Apache网页服务器与PHP、Perl及MySQL集合在一起的安装包,允许用户可以在自己的电脑上轻易的建立网页服务器。使用 XAMPP 您可以轻松的在本机调试您的 PHP 程序、CMS以及 wordpress 博客程序),那么关于XAMPP的使用大家可以百度一下,教程很多,在此我就不过多的介绍XAMPP的使用了,附一张XAMPP的界面图;
接下来简单的搭建一个iOS注册界面,xib快速拖拽
iOS发送注册请求代码,当让注册这部分在实际项目中有所不同,刚入门的朋友们以实际项目为准
- (IBAction)registerClick:(id)sender
{
NSString *user = [self.username.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];
NSString *pass = [self.password.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];
NSString *repass = [self.repassword.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
if([pass isEqualToString:repass] && user.length == 11){
NSDictionary *par = @{@"username":user,@"password":pass};
[[netTool shareDL]postDataFromUrlString:@"http://192.168.1.102/myphp/register.php" parameter:par progress:^(NSProgress * _Nonnull downloadProgress) {
} success:^(NSURLSessionDataTask * _Nonnull task, id _Nullable responseObject) {
NSLog(@"成功:%@",responseObject);
} fail:^(NSURLSessionDataTask * _Nullable task, NSError * _Nonnull error) {
NSLog(@"失败");
}];
}
}
请求类是对AFNetworking进行的二次封装,便于以后的代码整理修改;
接下来是PHP的代码:
$username = $_POST['username'];
$password = $_POST['password'];
$mysqli = new mysqli("127.0.0.1","root","","demo");
if($mysqli->connect_error){
echo "连接失败".$mysqli->connect_error;
}
$mysqli->query("set names utf8");
if(isset($username) && isset($password)){
$sql = "select username from myuser where username='$username'";
$res=$mysqli->query($sql);
if($res->num_rows){
$result = array();
$result['code']="-1";
$result["des"]="该用户名已存在";
echo json_encode($result);
return;
}else{
$sql = "insert into myuser values ('$username','$password')";
$b=$mysqli->query($sql);
if($b){
$result=array();
$result['code']=1;
$result['des']="注册成功";
$list=array();
$list['username']=$username;
$list['password']=$password;
$result['list']=$list;
echo json_encode($result);
}else{
$result=array();
$result['code']="0";
$result['des']="注册失败";
echo json_encode($result);
}
}
}
对于PHP数据库操作有三种形式:mysql,mysqli,PDO;
PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extension 而言,本身也增加了安全性。而 PDO (PHP Data Object) 则是提供了一个 Abstraction Layer 来操作资料库。
在此我使用的是mysqli,mysqli既有面相对象又有面相过程,例子中使用的是面相对象,会使用一种即可;
测试:
code=1注册成功;
再次以相同用户名注册:
code=-1用户名已经存在