iOS程序猿如何快速掌握 PHP,化身"全栈攻城狮"?
这是一篇以 iOS 开发人员的视角写给广大iOS 程序猿的 PHP 入门指南.在这篇文章里我努力去发掘 objectiv-c 与 php 之间的共性,来帮助有一定 iOS 开发经验的攻城狮来快速上手一门后台开发语言.后台开发语言,就是以"数据接口"的形式出现在我们的开发文档的那个东西!掌握PHP,无论对自己目前的iOS开发工作还是以后个人职场生涯的长久发展,都会大有裨益!最重要的是,PHP本身不是一个玩具语言,而是目前相当一部分公司仍然在用的后台开发语言,甚至包括你目前的公司;这篇文章,也不是一个简单的基础手册,而是以一种更适合 iOS 开发人员理解的方式来系统讲解 PHP 中最核心最重要最常用的概念和功能.阅读并有效实践本文,将有助于你拥有独立编写后台数据接口的能力.
必要的准备与说明
首先,你需要下载最新版 XAMPP软件,以在本地搭建一个 php 服务器.下载地址: https://www.apachefriends.org/download.html.
下载完成后,双击安装.安装成功后,选择 Mange Servers-->Start All启动本地服务器.启动成功后,在浏览器中输入 http://localhost,就可以看到一个默认的PHP页面.
你的php服务器文件默认放在: 应用程序-->XAMPP-->htdocs 目录下.
然后你还需要下载一款PHP编辑器,此时我使用Github的Atom编辑器.个人感觉界面很舒适,代码高亮看着也很舒服,你可以到这里下载: https://atom.io.下载完成后,点击安装即可.
最后要说明的是:PHP版本很多,下面的讲解支持目前最常用的 php 5.3.0 及其以上版本.
Hello World!
下面编写最简单的 Hello World 程序,请在以下步骤执行.
1.在 应用程序-->XAMPP-->htdocs 目录下新建目录 find_php.
没有特别的意思,纯碎是为了演示方便,同时不干扰默认存在的php文件.
2.打开Atom编辑器,使用 cmd+N
新建文件,并输入以下代码,并 cmd+S
保存到 find_php目录,文件命名为 index.php.
<?php
echo 'Hello World';
?>
如果PHP无法如中一样高亮显示,可能就需要点击文件右下角,以手动指定当前问文件的语法高亮方式.
3.在浏览器地址栏输入: http://localhost/find_php/index.php,即可看到用PHP写的Hello World.
AppDelegate 入口文件
iOS应用通常是以 AppDelegate 文件作为编码的起始(准确说的是 main.m,在此不细究).在PHP中,你可以使用一个 index.php 文件作为你的 php 程序的唯一入口.你的所有的php页面间的访问与跳转,都将是由此处开始.下面的代码可以先先复制到你的 index.php种,它实现了一个基本的页面访问与控制的框架:
<?php
$controller = '';
$model = array();
if (isset($_GET['viewController'])) {
$controller = $_GET['viewController'];
}
if (isset($_GET['model'])) {
$model = $_GET['model'];
}
echo '控制器:'.$controller.'<br />';
echo '数据模型:<br />';
foreach ($model as $key => $value) {
echo $key.':'.$value.'<br />';
}
?>
然后在浏览器地址栏,输入: http://localhost/find_php/index.php?viewController=HomeViewController&model[id]=42&model[name]=iOS122&model[age]=25
页面输入:
控制器:HomeViewController
数据模型:
id:42
name:iOS122
age:25
viewController=
后面跟的是你你的表示你的视图控制器, model
是一个字典,用于存储数据模型,支持输入多个键值对.id
,name
,age
等都是自定义的键,用于表示你想要传给新页面的数据,如果没有可以不写.
注意: 此处暂仅考虑简单的GET请求,至于其他变体可在熟悉PHP语法后,自行书写.学习新语言的初期,努力寻找新东西与已经掌握的东西的共通之处,总是可以事半功倍!
MVC 设计模式
我们仍然从常用的MVC模式来开始更进一步的讨论.M,即Model数据模型,对应于我们在地址栏输入的model;V,即视图View,更直接地说是显示数据,为了简化讨论,我们此处仅对移动端开发常用的JSON格式数据的显示作一实现;C,即Controller控制器,也就是我们常说的视图控制器,下面会具体讨论如何在PHP中定义视图控制器.
注意: 移动端数据接口只是PHP的应用场景之一.其实你日常接触的绝对部分网站都是由 PHP 驱动的,要想写出布局优美的网站,你需要学习HTML和JS相关的知识.如果有兴趣,建议去这个网站: http://www.w3school.com.cn
改进后的 index.php
<?php // index.php
/* 实现类文件的自动加载 */
function __autoload($className) {
if (file_exists($className . '.php')) {
require_once $className . '.php';
return true;
}
return false;
}
// --------------------------------
/* 获取用户想要访问的页面的相关信息. */
$controllerName = '';
$model = array();
if (isset($_GET['viewController'])) {
$controllerName = $_GET['viewController'];
}
if (isset($_GET['model'])) {
$model = $_GET['model'];
}
/* 跳转到指定页面. */
if ('' !== $controllerName) {
/* 我们约定每个控制器都至少有一个$model属性和 show方法 */
$controller = new $controllerName();
$controller->model = $model;
$controller->show();
}
?>
这个方法可以实现根据用户输入自动跳转至对应的界面.你直接把代码复制到index.php中即可,因为它暂时不再需要做变更了.一些说明的技术点是:
- 实现了 魔术方法 __autoload,以实现自动加载相关的类文件.这有些类似于我们在 .pch中全局引入某个头文件,然后整个工程处处可用一样.
- php 是一种弱类型语言,你定义变量时不必声明类型,但是变量要以 美元符号 $开头.
- php 使用 new 函数来创建一个对象,语法是
new 类名()
,这不禁让我想起 oc 中的 new函数,它的语法是: [类名 new]; - php 中的函数,看起来更像是C语言函数,也许说更像 oc 中的block,可能更好理解些.
- php 访问属性,使用的是
->
,而不是.
;另一种 php 访问属性的方式是使用obj['属性名']
,如$controller['model'].
此时你访问 http://localhost/find_php/index.php?viewController=HomeViewController&model[id]=42&model[name]=iOS122&model[age]=25
,应该会报错:
syntax error, unexpected '>' in /Applications/XAMPP/xamppfiles/htdocs/find_php/HomeViewController.php on line 38
因为你还没有定义视图控制器
Controller:定义视图控制器
在find_php文件夹新建 HomeViewController.php 文件,并把下面的代码复制进去:
<?php // HomeViewController.php
/* 建议一个文件中只有一个 与文件同名的类.
如果需要继承自其他类,可以使用关键字 extends,如 */
class HomeViewController
{
/*
定义属性,允许定义时,给属性一个默认值,这一点比OC灵活.
public 关键字用于指定外部可访问;
类似的还有 private(仅允许内部访问),protected(仅允许自身及其子类访问);
属性前必须有关键字 public/private/protected 中的一个.
*/
public $model = array(); // 定义允许外部访问的属性.
/* 构造函数,相当于init初始化方法;
当调用New 函数新建对象时,此方法会被自动调用;
array 指明参数类型, $model是实参, $model = array(),用于指定默认参数;
指定了默认参数的参数,在调用时,可以不传;
public 关键字作用等同于属性的关键字,默认可以不传,不传则为public;
*/
public function __construct(array $model = array())
{
/* 在实例方法内部访问对象的属性,使用 $this 关键字,且属性名前没有美元符号$;
类似于 oc 中的self,但是使用的是 `->` 而不是 `.` */
$this->model = $model;
}
/*
析构函数,作用和 oc 中的dealloc很像.
*/
public function __destruct()
{
$this->model = NULL;
}
/* 获取内容,用于输出显示. */
protected function getContent()
{
/* 默认把用户输入以JSON格式返回 */
$content = json_encode($this->model);
return $content;
}
/*
定义实例方法:show;
定义方法使用的是关键字 function,且无法指定返回值,这点不如 oc 方便;
*/
public function show()
{
/* 使用$this关键字来调用另一个实例方法. */
$content = $this->getContent();
echo $content;
}
}
此时你访问 http://localhost/find_php/index.php?viewController=HomeViewController&model[id]=42&model[name]=iOS122&model[age]=25
,输出应该是:
{"id":"42","name":"iOS122","age":"25"}
说明,页面的确跳转到了 HomeViewController控制器,并有效输出;而且输出的是我们移动端开发最常接触的 json 格式的数据.
以上的代码,充分展示了php作为一门面向对象(OOP)语言最常用的几个功能,如定义属性,定义实例方法,在示例方法内访问属性与实例方法等.PHP作为一门弱类型的OOP语言,也有一些非常强大的特性,推荐阅读:
Model: 关于数据模型的几点说明.
- 网上关于MVC中M的讨论,此处我选取的是最基本的一种: M专指用于存储某种数据的类的实例.它可以用于数据的格式化存储和传递,但不应包含发起网络请求和读写数据库等操作;
- 在本文讨论的Model中,我们进一步简化了Model,允许且只允许用于通过URL来定义某个控制器的Model;
- PHP 是一本弱类型的语言,所以不必专门为某种控制器指定某种类型的Model.
- "PHP 中的数组实际上是一个有序映射。映射是一种把 values 关联到 keys 的类型。此类型在很多方面做了优化,因此可以把它当成真正的数组,或列表(向量),散列表(是映射的一种实现),字典,集合,栈,队列以及更多可能性。由于数组元素的值也可以是另一个数组,树形结构和多维数组也是允许的。"
View: 一个显示HTML的实例.
返回 JSON 格式的数据,已经达到了做移动端开发的需要,但此处仍然使用HTML语法来显示数据,以便于更好地理解.用下面的代码替换 HomeViewController.php 文件的 getContent 方法:
/* 获取内容,用于输出显示. */
protected function getContent()
{
$content = '<html><body><ul>';
foreach ($this->model as $key => $value) {
$content .= "<li>$key:$value</li>";
}
$content .= '</ul></body></html>';
return $content;
}
此时你访问 http://localhost/find_php/index.php?viewController=HomeViewController&model[id]=42&model[name]=iOS122&model[age]=25
,输出应该是:
- id:42
- name:iOS122
- age:25
浏览器中会被自动解析为一个列表.对应的HTML代码如下:
<html>
<head></head>
<body>
<ul>
<li>id:42</li>
<li>name:iOS122</li>
<li>age:25</li>
</ul>
</body></html>
此处使用了简单的HTML标签.
小结
本文通过模拟实现 iOS 的MVC的设计模式,来概要性地讲解了PHP中的对应的各个概念.熟悉以上操作,可以使你具备自定义服务器接口的基本能力.参与讨论,参见:http://www.ios122.com/tag/php/ 更全面地信息,参见PHP官方中文文档: http://ua2.php.net/manual/zh/langref.php.