一般把APP接口分为三类,普通接口,表单接口,会员接口;本文重点讨论会员接口
普通接口
一般为GET请求,比如获取新闻列表 GET http://Example.com/index.PHP?module=news&action=list,为了防止采集或者暴力查询,我们PC端一般做如下处理:
防止本站被它站file_get_contents,所以要识别user_agent,如果不是通过浏览器来访问的话直接不给看。
如果别人通过伪造user_agent来访问的话,就通过单位时间ip的访问量来控制抓取方,可以写一套算法,如果再一个ip在前后一分钟多于多少次访问量来处理。但是,会有一种情况,即某个小区或公司内都是使用某一个IP的外网的话,这样搞就会自寻死路,所以还要配合浏览器中的cookie来处理
总结: 请求头可以伪造,IP地址可以变更,cookie可以清空,基本上PC端是很难防这个问题的,比如淘宝,点评等大站的数据我也是经常去采的。
很多时候我们都会用到referer地址,通过判断上一页是从哪里来的,我们可以了解很多信息,但是现在referer并不是那么可靠的数据了,因为我们可以伪造referer地址。这里分别介绍CURL、SOCKET、file_get_contents实现方法,详细代码如下:
如果你想用这个函数,请参考我的另外一篇文章。http://www.shangzh.com/21.html PHP对二维数组的排序
原理是先排序之后,再根据某个键来删除,下面看代码
/**
* 根据某个键给二维数组去重,这个必须是排序的
* @param array $array
* @param string $keyid
* @return array
* @example array_unique_two($array,’id’);
*/
function array_unique_two($array, $key) {
if (is_array($array)) {
$first = reset($array); //获取第一个
array_shift($array); //删除第一个
$temp = $first[$key];//第一个值
if($array){
$res = [];
foreach($array as $val) {
if($val[$key] != $temp){
$res[] = $val;
$temp = $val[$key];
}
}
$data=[];
$data[] = $first;
$array = array_merge($data,(array)$res);
}else{
$array = $first;
}
}
return $array;
}
安装memcached
wget http://memcached.org/files/memcached-1.4.24.tar.gz
tar -zxvf memcached-1.4.24.tar.gz
cd memcached-1.4.24
./configure && make && make test && sudo make install
memcached启动
/usr/local/bin/memcached -d -m 50 -u root -p 11211 -c 1024 -P /tmp/memcached.pid
memcached终止
kill `cat /tmp/memcached.pid`
http://www.cppblog.com/kefeng/archive/2010/10/11/129422.html
安装 memcached扩展
wget https://sourceforge.net/projects/levent/files/libevent/libevent-2.0/libevent-2.0.22-stable.tar.gz
tar -zxvf libevent-2.0.22-stable.tar.gz
cd libevent-2.0.22-stable
./configure
make
make install
wget https://launchpad.net/libmemcached/1.0/1.0.18/+download/libmemcached-1.0.18.tar.gz
tar -zxvf libmemcached-1.0.18.tar.gz
cd libmemcached-1.0.18
./configure
make
make install
libmemcached 默认安装在/usr/local/,头文件安装在/usr/local/include/libmemcachde/,动态库默认安装在/usr/local/lib/下。
wget pecl.php.net/get/memcached-2.2.0.tgz
tar -zxvf memcached-2.2.0.tgz
cd memcached-2.2.0
whereis phpize
/usr/bin/phpize && ./configure –with-php-config=/usr/local/php/bin/php-config –enable-memcache=/usr/local/include/libmemcached –disable-memcached-sasl && make && make install
[memcache]
extension_dir=/usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/
extension=”memcache.so”
yaf没有自带的orm,所以必须自己集成orm。今天我就介绍自己喜欢的wedoo数据库操作类
目前使用的版本是0.9.8.3 yaf目录
1.修改public/index.php,在第一句写上
static $_db = NULL;//数据库静态变量
2.修改配置文件conf/application.ini
application.library = APP_PATH “/library”
;数据库加载
database.database_type = “mysql”
database.database_name = “yourdb”
database.server = “localhost”
database.username = “root”
database.password = “”
database.charset = “utf8”
database.port = 3306
数据库连接部分
3.修改library/medoo.php
use Yaf\Bootstrap_Abstract;
class medoo extends Bootstrap_Abstract
{
…. 省略
}
这里是继承Bootstrap_Abstract;
在构造方法中使用
public function __construct($options = null)
{
global $_db;//静态db
$dbConfig=\Yaf\Registry::get(“config”)->database->toarray();
$dbConfig[‘option’]=array(PDO::ATTR_CASE => PDO::CASE_NATURAL);
$options = $dbConfig;
。。。。省略N行
//以上是连接数据库的,这就是为什么要继承Bootstrap_Abstract的原因
//然后把$this->pdo = new PDO($dsn, $this->username, $this->password, $this->option);改成
if(!$_db){
$_db=$this->pdo = new PDO($dsn, $this->username, $this->password, $this->option);
}else{
$this->pdo=$_db;
}
}
配置完毕。这里解释一下为什么要用$_db。简单来说就是单例模式。
使用medoo类。我们可以在模型中这样用 Application/models/SampleModel.php
<?php
class SampleModel extends medoo{
private $_table=’mytable’;
public function show(){
$list=$this->select($this->_table,’*’, array(
‘LIMIT’=>5
));
return $list;
}
}
?>
在Application/controllers/Index.php 这样用
<?php
use Yaf\Controller_Abstract;
class IndexController extends Controller_Abstract {
public function indexAction(){
header(‘content-type:text/html;charset=utf-8’);
$model = new SampleModel();//第一次new
echo ‘<pre>’;
print_r($model->show());
echo ‘</pre>’;
$mo = new SampleModel();//第二次new
}
}
?>
用static $_db 实现单例模式,无论你new多少次模型,数据库只连接一次