BaiduController.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. <?php
  2. /**
  3. * BaiduController.php UTF-8
  4. * 百度信息流对接
  5. *
  6. * @date : 2018/7/6 11:46
  7. *
  8. * @license 这不是一个自由软件,未经授权不许任何使用和传播。
  9. * @author : ouzhongfu <ozf@huosdk.com>
  10. * @version : HUOSDK 7.2
  11. */
  12. namespace api\promotion\controller\v8;
  13. use Think\Config;
  14. //use api\promotion\controller\v8\BaseController;
  15. use think\Db;
  16. use Think\Log;
  17. class BaiduController extends BaseController {
  18. protected $logtable = 'promotion_baidu_log';
  19. protected $usertable = 'promotion_baidu_user';
  20. public $baidu_conf
  21. = array(
  22. 'baidu_key' => '', /* key */
  23. );
  24. function _initialize() {
  25. parent::_initialize();
  26. }
  27. private function baiduReturn($status = '0') {
  28. return parent::hs_api_responce($status);
  29. }
  30. /**
  31. * 点击数据记录
  32. */
  33. public function start() {
  34. $_rs = $this->checkLogTable();
  35. if (false == $_rs) {
  36. return false;
  37. }
  38. /* 1 查询是否具有访问权限 */
  39. $_urldata = $this->request->param();
  40. if (empty($_urldata)) {
  41. $this->baiduReturn(300);
  42. }
  43. /*验证渠道信息*/
  44. $_pmt_id = $this->request->param('pmtid');
  45. $_pmt_data = $this->getPmtData($_pmt_id);
  46. if (!$_pmt_data) {
  47. $this->baiduReturn(301);
  48. }
  49. /*1 查看参数是否配置*/
  50. $_rs = $this->check($_pmt_data['app_id'], $_pmt_data['agent_id']);
  51. if (!$_rs) {
  52. $this->baiduReturn(302);
  53. }
  54. /*sign 验证*/
  55. $_rrs = $this->varifySign($_urldata);
  56. if (!$_rrs) {
  57. $this->baiduReturn(303);
  58. }
  59. $_data['agent_id'] = $_pmt_data['agent_id'];
  60. $_data['app_id'] = $_pmt_data['app_id'];
  61. $_data['imei_md5'] = get_val($_urldata, 'imei_md5', '');
  62. $_data['idfa'] = get_val($_urldata, 'idfa', '');
  63. $_data['os'] = get_val($_urldata, 'os', '');
  64. $_data['ip'] = get_val($_urldata, 'ip', '');
  65. $_data['ua'] = get_val($_urldata, 'ua', '');
  66. $_data['ts'] = get_val($_urldata, 'ts', '');
  67. $_data['userid'] = get_val($_urldata, 'userid', '');
  68. $_data['pid'] = get_val($_urldata, 'pid', '');
  69. $_data['uid'] = get_val($_urldata, 'uid', '');
  70. $_data['aid'] = get_val($_urldata, 'aid', '');
  71. $_data['click_id'] = get_val($_urldata, 'click_id', '');
  72. $_data['sign'] = get_val($_urldata, 'sign', '');
  73. $_data['create_time'] = time();
  74. $_data['callback_url'] = get_val($_urldata, 'callback_url', '');
  75. /*保存数据*/
  76. if (empty($_data)) {
  77. $this->baiduReturn(304);
  78. } else {
  79. $_rs = Db::name($this->logtable)->insert($_data);
  80. if ($_rs) {
  81. $_user_table_check = $this->checkUserTable();
  82. if (false == $_user_table_check) {
  83. return false;
  84. }
  85. $_rs = $this->userInsert($_data);
  86. $this->baiduReturn();
  87. }
  88. }
  89. return false;
  90. }
  91. /**插入promotion_toutiao_user表中
  92. *
  93. * @param $data
  94. *
  95. * @return bool|int|string
  96. */
  97. public function userInsert($data) {
  98. //$_check_map['agent_id'] = $data['agent_id'];
  99. $_check_map['app_id'] = $data['app_id'];
  100. $_check_map['os'] = $data['os'];
  101. if (2 == $data['os']) {
  102. $_check_map['imei_md5'] = $data['imei_md5'];
  103. $_from = 3;
  104. } elseif (1 == $data['os']) {
  105. $_check_map['idfa'] = $data['idfa'];
  106. $_from = 4;
  107. } else {
  108. $_check_map['imei_md5'] = $data['imei_md5'];
  109. $_from = 3;
  110. }
  111. $_is_md5 = true;
  112. $_check = Db::name($this->usertable)->where($_check_map)->find();
  113. $_base_class = new \huolib\promotion\Base();
  114. $_base_class->entVisitLog($data['agent_id'], $data['app_id']);
  115. $_baidu_class = new \huolib\promotion\Baidu();
  116. $_is_while = $_baidu_class->isWhile($_from, $data['imei_md5'], $data['idfa'], $_is_md5);
  117. $_rs = false;
  118. if (empty($_check) || $_is_while) {
  119. $_data['agent_id'] = $data['agent_id'];
  120. $_data['app_id'] = $data['app_id'];
  121. $_data['os'] = $data['os'];
  122. $_data['imei_md5'] = $data['imei_md5'];
  123. $_data['idfa'] = $data['idfa'];
  124. $_data['create_time'] = $data['create_time'];
  125. $_data['update_time'] = $data['create_time'];
  126. $_data['status'] = 1;
  127. $_data['callback_url'] = $data['callback_url'];
  128. if ($_is_while) {
  129. $_data['is_test'] = 1;
  130. } else {
  131. $_data['is_test'] = 2;
  132. }
  133. $_rs = Db::name($this->usertable)->insert($_data);
  134. }
  135. if (empty($_check)) {
  136. $is_distinct = 1;
  137. $_rs = $_base_class->entVisitLog($data['agent_id'], $data['app_id'], $is_distinct);
  138. }
  139. return $_rs;
  140. }
  141. /**
  142. * 通过pmt_id获取agent_id跟app_id
  143. *
  144. * @param $pmt_id
  145. *
  146. * @return array|bool|false|\PDOStatement|string|\think\Model
  147. */
  148. public function getPmtData($pmt_id = 0) {
  149. if (empty($pmt_id)) {
  150. return false;
  151. }
  152. $_map['id'] = $pmt_id;
  153. $_data = Db::name('promotion_detail')->where($_map)->find();
  154. if (empty($_data)) {
  155. return false;
  156. }
  157. if (is_object($_data)) {
  158. $_data = $_data->toArray();
  159. }
  160. return $_data;
  161. }
  162. /**验证是否配置
  163. *
  164. * @param int $app_id
  165. * @param int $agent_id
  166. *
  167. * @return bool
  168. * @internal param array $params
  169. *
  170. */
  171. public function check($app_id = 0, $agent_id = 0) {
  172. if (empty($app_id) || empty($agent_id)) {
  173. return false;
  174. }
  175. $_map['app_id'] = $app_id;
  176. $_map['agent_id'] = $agent_id;
  177. $_key = Db::name('promotion_detail')->where($_map)->value('toutiao_key');
  178. if (empty($_key)) {
  179. return false;
  180. }
  181. $this->baidu_conf['baidu_key'] = $_key;
  182. return true;
  183. }
  184. /**sign验证
  185. *
  186. * @param $urldata
  187. *
  188. * @return bool
  189. */
  190. public function varifySign($urldata) {
  191. $_url = $this->request->server('REQUEST_SCHEME').'://'.$this->request->server('HTTP_HOST')
  192. .$this->request->server('REQUEST_URI');
  193. $_check = stripos($_url, "&sign=");
  194. if (!$_check) {
  195. return false;
  196. }
  197. $_check_string = substr($_url, 0, $_check).$this->baidu_conf['baidu_key'];
  198. $_sign = $urldata['sign'];
  199. $_check_sign = md5($_check_string);
  200. if ($_sign == $_check_sign) {
  201. return true;
  202. }
  203. }
  204. /**
  205. * @return bool
  206. */
  207. private function checkLogTable() {
  208. $_table_name = Config::get('database.prefix').$this->logtable;
  209. $_sql = '';
  210. $_sql .= "CREATE TABLE IF NOT EXISTS `".$_table_name."` (";
  211. $_sql .= " `id` int(11) NOT NULL AUTO_INCREMENT,";
  212. $_sql .= " `app_id` INT(11) NOT NULL DEFAULT 0 COMMENT '游戏id',";
  213. $_sql .= " `agent_id` INT(11) NOT NULL DEFAULT 0 COMMENT '子渠道id',";
  214. $_sql .= " `imei_md5` VARCHAR(64) NOT NULL COMMENT '用户终端的IMEI码md5后的值',";
  215. $_sql .= " `idfa` VARCHAR(64) NOT NULL COMMENT 'iOS 手机广告唯一标识',";
  216. $_sql .= " `os` VARCHAR(10) NOT NULL DEFAULT '' COMMENT '客户端操作系统的类型,1–iOS;2–Android',";
  217. $_sql .= " `ip` VARCHAR(32) NOT NULL DEFAULT '未知ip' COMMENT '百度信息流返回玩家ip',";
  218. $_sql .= " `ua` VARCHAR(518) NOT NULL DEFAULT '' COMMENT 'userua信息', ";
  219. $_sql .= " `android_id` VARCHAR(64) NOT NULL DEFAULT '' COMMENT '用户终端的AndroidID',";
  220. $_sql .= " `ts` VARCHAR(32) NOT NULL DEFAULT '' COMMENT '百度信息流返回时间戳',";
  221. $_sql .= " `userid` VARCHAR(32) NOT NULL DEFAULT '' COMMENT '账户ID',";
  222. $_sql .= " `pid` VARCHAR(32) NOT NULL DEFAULT '' COMMENT '计划ID',";
  223. $_sql .= " `uid` VARCHAR(32) NOT NULL DEFAULT '' COMMENT '单元ID',";
  224. $_sql .= " `aid` VARCHAR(32) NOT NULL DEFAULT '' COMMENT '创意ID',";
  225. $_sql .= " `click_id` VARCHAR(64) NOT NULL DEFAULT '' COMMENT '点击唯一标识',";
  226. $_sql .= " `callback_url` VARCHAR(1000) NOT NULL DEFAULT '' COMMENT '回调地址',";
  227. $_sql .= " `sign` VARCHAR(32) NOT NULL DEFAULT '' COMMENT '验证sign',";
  228. $_sql .= " `create_time` INT(11) NOT NULL DEFAULT 0 COMMENT '创建时间戳',";
  229. $_sql .= " PRIMARY KEY (`id`)";
  230. $_sql .= ")ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='百度点击数据记录';";
  231. try {
  232. $_rs = db()->execute($_sql);
  233. if (false === $_rs) {
  234. Log::write("baidu_log create table ".$_table_name." failed1", 'error');
  235. return false;
  236. }
  237. return true;
  238. } catch (Exception $_e) {
  239. Log::write("baidu_log create table ".$_table_name." failed2", 'error');
  240. return false;
  241. }
  242. }
  243. /**
  244. * @return bool
  245. */
  246. private function checkUserTable() {
  247. $_table_name = Config::get('database.prefix').$this->usertable;
  248. $_sql = '';
  249. $_sql .= "CREATE TABLE IF NOT EXISTS `".$_table_name."` (";
  250. $_sql .= " `id` int(11) NOT NULL AUTO_INCREMENT,";
  251. $_sql .= " `app_id` INT(11) NOT NULL DEFAULT 0 COMMENT '游戏id',";
  252. $_sql .= " `agent_id` INT(11) NOT NULL DEFAULT 0 COMMENT '子渠道id',";
  253. $_sql .= " `imei_md5` VARCHAR(64) NOT NULL COMMENT '用户终端的IMEI码md5后的值',";
  254. $_sql .= " `idfa` VARCHAR(64) NOT NULL COMMENT 'iOS 手机广告唯一标识',";
  255. $_sql .= " `os` VARCHAR(10) NOT NULL DEFAULT '' COMMENT '客户端操作系统的类型,1–iOS;2–Android',";
  256. $_sql .= " `callback_url` VARCHAR(1000) NOT NULL DEFAULT '' COMMENT '回调地址',";
  257. $_sql .= " `create_time` INT(11) NOT NULL DEFAULT 0 COMMENT '创建时间戳',";
  258. $_sql .= " `update_time` INT(11) NOT NULL DEFAULT 0 COMMENT '更新时间戳',";
  259. $_sql .= " `status` TINYINT(2) NOT NULL DEFAULT 1 COMMENT '状态,1为待激活,2为已激活',";
  260. $_sql .= " `is_test` TINYINT(2) NOT NULL DEFAULT 2 COMMENT '是否测试数据,1是,2不是',";
  261. $_sql .= " PRIMARY KEY (`id`)";
  262. $_sql .= ")ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='百度点击用户';";
  263. try {
  264. $_rs = db()->execute($_sql);
  265. if (false === $_rs) {
  266. Log::write("baidu_log create table ".$_table_name." failed1", 'error');
  267. return false;
  268. }
  269. return true;
  270. } catch (Exception $_e) {
  271. Log::write("baidu_log create table ".$_table_name." failed2", 'error');
  272. return false;
  273. }
  274. }
  275. }