Merge branch 'develop' of git.dev.yoho.cn:web/yohobuy into develop
Conflicts: template/m.yohobuy.com/actions/channel/newsale/new.phtml
Showing
14 changed files
with
189 additions
and
35 deletions
@@ -59,6 +59,22 @@ class AbstractAction extends Controller_Abstract | @@ -59,6 +59,22 @@ class AbstractAction extends Controller_Abstract | ||
59 | } | 59 | } |
60 | 60 | ||
61 | /** | 61 | /** |
62 | + * 使用Memcache缓存 | ||
63 | + * | ||
64 | + * @param string $node | ||
65 | + * @param string $childNode | ||
66 | + * @return object | ||
67 | + */ | ||
68 | + protected function memcache($node = null, $childNode = 'hosts') | ||
69 | + { | ||
70 | + if (PATH_SEPARATOR === '\\') { | ||
71 | + return Cache::memcache($node, $childNode); | ||
72 | + } else { | ||
73 | + return Cache::memcached($node, $childNode); | ||
74 | + } | ||
75 | + } | ||
76 | + | ||
77 | + /** | ||
62 | * 关闭模板自动渲染 | 78 | * 关闭模板自动渲染 |
63 | * | 79 | * |
64 | * @return void | 80 | * @return void |
@@ -69,19 +85,42 @@ class AbstractAction extends Controller_Abstract | @@ -69,19 +85,42 @@ class AbstractAction extends Controller_Abstract | ||
69 | } | 85 | } |
70 | 86 | ||
71 | /** | 87 | /** |
72 | - * 使用Memcache缓存 | 88 | + * 输出JSON数据到浏览器 |
73 | * | 89 | * |
74 | - * @param string $node | ||
75 | - * @param string $childNode | ||
76 | - * @return object | 90 | + * @return void |
77 | */ | 91 | */ |
78 | - protected function memcache($node = null, $childNode = 'hosts') | 92 | + protected function echoJson($json) |
79 | { | 93 | { |
80 | - if (PATH_SEPARATOR === '\\') { | ||
81 | - return Cache::memcache($node, $childNode); | ||
82 | - } else { | ||
83 | - return Cache::memcached($node, $childNode); | 94 | + headers_sent() || header('Content-Type: application/json; charset=utf-8;'); |
95 | + | ||
96 | + echo $json; | ||
84 | } | 97 | } |
98 | + | ||
99 | + /** | ||
100 | + * 返回JSON数据 | ||
101 | + * | ||
102 | + * @param int $code 状态编码 | ||
103 | + * @param string $message 提示信息 | ||
104 | + * @param mixed $data 数据内容 | ||
105 | + * @return json | ||
106 | + */ | ||
107 | + protected function returnJson($code, $message, $data) | ||
108 | + { | ||
109 | + return json_encode(array( | ||
110 | + 'code' => $code, | ||
111 | + 'message' => $message, | ||
112 | + 'data' => $data, | ||
113 | + )); | ||
114 | + } | ||
115 | + | ||
116 | + /** | ||
117 | + * 判断是不是AJAX请求 | ||
118 | + * | ||
119 | + * @return bool | ||
120 | + */ | ||
121 | + protected function isAjax() | ||
122 | + { | ||
123 | + return $this->_request->isXmlHttpRequest(); | ||
85 | } | 124 | } |
86 | 125 | ||
87 | } | 126 | } |
@@ -87,10 +87,11 @@ class Yohobuy | @@ -87,10 +87,11 @@ class Yohobuy | ||
87 | * | 87 | * |
88 | * @param string $url 接口URL | 88 | * @param string $url 接口URL |
89 | * @param array $data 参数列表 | 89 | * @param array $data 参数列表 |
90 | + * @param bool $returnJson 控制是否返回json格式数据 | ||
90 | * @param int $timeout 超时时间 | 91 | * @param int $timeout 超时时间 |
91 | * @return mixed | 92 | * @return mixed |
92 | */ | 93 | */ |
93 | - public static function get($url, $data = array(), $timeout = 5) | 94 | + public static function get($url, $data = array(), $returnJson = false, $timeout = 5) |
94 | { | 95 | { |
95 | if (isset($data['private_key'])) { | 96 | if (isset($data['private_key'])) { |
96 | unset($data['private_key']); | 97 | unset($data['private_key']); |
@@ -104,7 +105,7 @@ class Yohobuy | @@ -104,7 +105,7 @@ class Yohobuy | ||
104 | curl_setopt($ch, CURLOPT_TIMEOUT, $timeout); | 105 | curl_setopt($ch, CURLOPT_TIMEOUT, $timeout); |
105 | curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); | 106 | curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); |
106 | $result = curl_exec($ch); | 107 | $result = curl_exec($ch); |
107 | - if (!empty($result)) { | 108 | + if (!$returnJson && !empty($result)) { |
108 | $result = json_decode($result, true); | 109 | $result = json_decode($result, true); |
109 | } | 110 | } |
110 | curl_close($ch); | 111 | curl_close($ch); |
@@ -118,12 +119,13 @@ class Yohobuy | @@ -118,12 +119,13 @@ class Yohobuy | ||
118 | * | 119 | * |
119 | * @param string $url 接口URL | 120 | * @param string $url 接口URL |
120 | * @param array $data 参数列表 | 121 | * @param array $data 参数列表 |
122 | + * @param bool $returnJson 控制是否返回json格式数据 | ||
121 | * @param int $timeout 超时时间 | 123 | * @param int $timeout 超时时间 |
122 | * @param array $header | 124 | * @param array $header |
123 | * @param array $cookie | 125 | * @param array $cookie |
124 | * @return mixed | 126 | * @return mixed |
125 | */ | 127 | */ |
126 | - public static function post($url, $data = array(), $timeout = 5, $header = array(), $cookie = array()) | 128 | + public static function post($url, $data = array(), $returnJson = false, $timeout = 5, $header = array(), $cookie = array()) |
127 | { | 129 | { |
128 | $ch = curl_init($url); | 130 | $ch = curl_init($url); |
129 | 131 | ||
@@ -151,7 +153,7 @@ class Yohobuy | @@ -151,7 +153,7 @@ class Yohobuy | ||
151 | curl_setopt($ch, CURLOPT_POSTFIELDS, $data); | 153 | curl_setopt($ch, CURLOPT_POSTFIELDS, $data); |
152 | } | 154 | } |
153 | $result = curl_exec($ch); | 155 | $result = curl_exec($ch); |
154 | - if (!empty($result)) { | 156 | + if (!$returnJson && !empty($result)) { |
155 | $result = json_decode($result, true); | 157 | $result = json_decode($result, true); |
156 | } | 158 | } |
157 | curl_close($ch); | 159 | curl_close($ch); |
@@ -238,4 +240,22 @@ class Yohobuy | @@ -238,4 +240,22 @@ class Yohobuy | ||
238 | return $result; | 240 | return $result; |
239 | } | 241 | } |
240 | 242 | ||
243 | + /** | ||
244 | + * rpc调用远程服务(YAR) | ||
245 | + * | ||
246 | + * @see http://php.net/manual/zh/yar-client.setopt.php | ||
247 | + * @return array | ||
248 | + */ | ||
249 | + public static function yarClient($uri, $method, $data = array(), $timeout = 3000) | ||
250 | + { | ||
251 | + $client = new \Yar_Client($uri); | ||
252 | + $client->SetOpt(YAR_OPT_PACKAGER, 'php'); | ||
253 | + $client->SetOpt(YAR_OPT_TIMEOUT, $timeout); | ||
254 | + $client->SetOpt(YAR_OPT_CONNECT_TIMEOUT, $timeout); | ||
255 | + | ||
256 | + $result = $client->$method($data); | ||
257 | + | ||
258 | + return $result; | ||
259 | + } | ||
260 | + | ||
241 | } | 261 | } |
1 | <?php | 1 | <?php |
2 | + | ||
2 | namespace LibModels\Wap\Product; | 3 | namespace LibModels\Wap\Product; |
3 | 4 | ||
4 | use Api\Sign; | 5 | use Api\Sign; |
@@ -15,8 +16,9 @@ use Api\Yohobuy; | @@ -15,8 +16,9 @@ use Api\Yohobuy; | ||
15 | */ | 16 | */ |
16 | class RecomData | 17 | class RecomData |
17 | { | 18 | { |
19 | + | ||
18 | /** | 20 | /** |
19 | - * 你可能喜欢的商品列表 | 21 | + * 你可能喜欢的BOYS或GIRLS的商品列表 |
20 | * | 22 | * |
21 | * @param string $gender "1,3"表示男, "2,3"表示女 | 23 | * @param string $gender "1,3"表示男, "2,3"表示女 |
22 | * @param string $channel 1表示男, 2表示女 | 24 | * @param string $channel 1表示男, 2表示女 |
@@ -34,8 +36,45 @@ class RecomData | @@ -34,8 +36,45 @@ class RecomData | ||
34 | $param['yh_channel'] = $channel; | 36 | $param['yh_channel'] = $channel; |
35 | $param['client_secret'] = Sign::getSign($param); | 37 | $param['client_secret'] = Sign::getSign($param); |
36 | 38 | ||
37 | - return Yohobuy::get(Yohobuy::API_URL, $param); | 39 | + return Yohobuy::get(Yohobuy::API_URL, $param, true); |
38 | } | 40 | } |
39 | 41 | ||
40 | -} | 42 | + /** |
43 | + * 你可能喜欢的潮童的商品列表 | ||
44 | + * | ||
45 | + * @param int $page 分页第几页, 默认第1页 | ||
46 | + * @param int $limit 查询返回的最大限制数, 默认为50 | ||
47 | + * @return array | ||
48 | + */ | ||
49 | + public static function mayLikeKids($page = 1, $limit = 50) | ||
50 | + { | ||
51 | + $param = Yohobuy::param(); | ||
52 | + $param['method'] = 'app.search.kids'; | ||
53 | + $param['page'] = $page; | ||
54 | + $param['limit'] = $limit; | ||
55 | + $param['yh_channel'] = '3'; | ||
56 | + $param['client_secret'] = Sign::getSign($param); | ||
57 | + | ||
58 | + return Yohobuy::get(Yohobuy::API_URL, $param, true); | ||
59 | + } | ||
41 | 60 | ||
61 | + /** | ||
62 | + * 你可能喜欢的创意生活的新品到着和人气单品列表 | ||
63 | + * | ||
64 | + * @param int $page 分页第几页, 默认第1页 | ||
65 | + * @param int $limit 查询返回的最大限制数, 默认为50 | ||
66 | + * @return array | ||
67 | + */ | ||
68 | + public static function mayLikeLifestyle($page = 1, $limit = 50) | ||
69 | + { | ||
70 | + $param = Yohobuy::param(); | ||
71 | + $param['method'] = 'app.search.lifeStyle'; | ||
72 | + $param['page'] = $page; | ||
73 | + $param['limit'] = $limit; | ||
74 | + $param['yh_channel'] = '4'; | ||
75 | + $param['client_secret'] = Sign::getSign($param); | ||
76 | + | ||
77 | + return Yohobuy::get(Yohobuy::API_URL, $param, true); | ||
78 | + } | ||
79 | + | ||
80 | +} |
@@ -49,14 +49,14 @@ class Bootstrap extends Bootstrap_Abstract | @@ -49,14 +49,14 @@ class Bootstrap extends Bootstrap_Abstract | ||
49 | Loader::getInstance()->registerLocalNameSpace(explode(',', $this->_config->application->namespaces)); | 49 | Loader::getInstance()->registerLocalNameSpace(explode(',', $this->_config->application->namespaces)); |
50 | } | 50 | } |
51 | 51 | ||
52 | - /** | ||
53 | - * 初始化插件 | ||
54 | - * @param Yaf_Dispatcher $dispatcher | ||
55 | - */ | ||
56 | - public function _initPlugin(Dispatcher $dispatcher) | ||
57 | - { | ||
58 | - | ||
59 | - } | 52 | +// /** |
53 | +// * 初始化插件 | ||
54 | +// * @param Yaf_Dispatcher $dispatcher | ||
55 | +// */ | ||
56 | +// public function _initPlugin(Dispatcher $dispatcher) | ||
57 | +// { | ||
58 | +// | ||
59 | +// } | ||
60 | 60 | ||
61 | /** | 61 | /** |
62 | * 初始化路由 | 62 | * 初始化路由 |
@@ -87,15 +87,15 @@ class Bootstrap extends Bootstrap_Abstract | @@ -87,15 +87,15 @@ class Bootstrap extends Bootstrap_Abstract | ||
87 | } | 87 | } |
88 | } | 88 | } |
89 | 89 | ||
90 | - /** | ||
91 | - * 初始化第三方包 | ||
92 | - * @param Dispatcher $dispatcher | ||
93 | - */ | ||
94 | - public function _initPackage(Dispatcher $dispatcher) | ||
95 | - { | ||
96 | - if ($this->_config->composer->autoload == 1) { | ||
97 | - require $this->_config->composer->path . '/vendor/autoload.php'; | ||
98 | - } | ||
99 | - } | 90 | +// /** |
91 | +// * 初始化第三方包 | ||
92 | +// * @param Dispatcher $dispatcher | ||
93 | +// */ | ||
94 | +// public function _initPackage(Dispatcher $dispatcher) | ||
95 | +// { | ||
96 | +// if ($this->_config->composer->autoload == 1) { | ||
97 | +// require $this->_config->composer->path . '/vendor/autoload.php'; | ||
98 | +// } | ||
99 | +// } | ||
100 | 100 | ||
101 | } | 101 | } |
1 | <?php | 1 | <?php |
2 | use Action\AbstractAction; | 2 | use Action\AbstractAction; |
3 | -use LibModels\Wap\Product\RecomData; | 3 | +use Api\Yohobuy; |
4 | 4 | ||
5 | /** | 5 | /** |
6 | * 频道选择 | 6 | * 频道选择 |
@@ -11,5 +11,7 @@ class IndexController extends AbstractAction | @@ -11,5 +11,7 @@ class IndexController extends AbstractAction | ||
11 | { | 11 | { |
12 | $this->_view->assign('title', 'YOHO!有货'); | 12 | $this->_view->assign('title', 'YOHO!有货'); |
13 | $this->_view->display('index', array('test' => 'hello world')); | 13 | $this->_view->display('index', array('test' => 'hello world')); |
14 | + | ||
15 | + //$test = Yohobuy::yarClient('http://service.api.yohobuy.com/guang/service/v1/plustar/', 'getBrandInfo', array('id' => 289)); | ||
14 | } | 16 | } |
15 | } | 17 | } |
1 | +<?php | ||
2 | + | ||
3 | +use Action\AbstractAction; | ||
4 | +use LibModels\Wap\Product\RecomData; | ||
5 | + | ||
6 | +/** | ||
7 | + * 商品推荐相关 | ||
8 | + * | ||
9 | + * @name RecomController | ||
10 | + * @package Product | ||
11 | + * @copyright yoho.inc | ||
12 | + * @version 1.0 (2015-10-8 14:43:52) | ||
13 | + * @author fei.hong <fei.hong@yoho.cn> | ||
14 | + */ | ||
15 | +class RecomController extends AbstractAction | ||
16 | +{ | ||
17 | + | ||
18 | + /** | ||
19 | + * 你可能喜欢的 | ||
20 | + * | ||
21 | + * 备注: | ||
22 | + * 调用位于男生(BOYS),女生(GIRLS),潮童(KIDS),创意生活(LifeStyle)页面的底部. | ||
23 | + * 调用方式为AJAX,需要用JS遍历该数据集,替换图片URL地址中的{width},{height},{mode}. | ||
24 | + * JS替换示例: str.replace("{width}", 300).replace("{height}", 300).replace("{mode}", 2); | ||
25 | + * | ||
26 | + * @param string gender "1,3"表示男, "2,3"表示女, 当channel为3时该参数可不传 | ||
27 | + * @param string channel 1表示男, 2表示女, 3表示潮童 | ||
28 | + * @return json | ||
29 | + */ | ||
30 | + public function maylikeAction() | ||
31 | + { | ||
32 | + if ($this->isAjax()) { | ||
33 | + $data = ''; | ||
34 | + $gender = $this->get('gender', '1,3'); | ||
35 | + $channel = $this->get('channel', '1'); | ||
36 | + | ||
37 | + switch (strval($channel)) { | ||
38 | + case '1': // 男(Boys) | ||
39 | + case '2': // 女(Girls) | ||
40 | + $data = RecomData::mayLike($gender, $channel); | ||
41 | + break; | ||
42 | + case '3': // 潮童(Kids) | ||
43 | + $data = RecomData::mayLikeKids(); | ||
44 | + break; | ||
45 | + case '4': // 创意生活(LifeStyle) | ||
46 | + $data = RecomData::mayLikeLifestyle(); | ||
47 | + break; | ||
48 | + } | ||
49 | + | ||
50 | + $this->echoJson($data); | ||
51 | + } | ||
52 | + } | ||
53 | + | ||
54 | +} |
-
Please register or login to post a comment