VIP视频解析网站的原理

[复制链接]
查看488 | 回复0 | 2020-2-27 22:07:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
大家可能经常看到各种VIP网站,不要钱可以看全网的VIP视频!其原理就是这个!
这是一款强大的类库它基于PHP根据视频URL抓取视频信息的工具,支持优酷、土豆、酷六、56、乐视、搜狐、腾讯、新浪。
说明:调用该工具php文件zhuaqu.php,$url变量后面的字符串为视频页的地址,然后使用echo输出变量$info。
  1. <?php

  2. /**

  3. *

  4. * foreach($urls as $url){

  5. * $info = VideoUrlParser::parse($url);

  6. * //var_dump($info);

  7. * echo "<a href='{$info['url']}' target='_new'>{$info['title']}</a>";

  8. * echo "<br />";

  9. * echo $info['object'];

  10. * echo "<br />";

  11. * }

  12. *

  13. *

  14. *

  15. * //优酷

  16. * http://v.youku.com/v_show/id_XMjU0NjY4OTEy.html

  17. * <embed src="http://player.youku.com/player.php/sid/XMjU0NjY4OTEy/v.swf" quality="high" width="480" height="400" align="middle" allowAccess="sameDomain" type="application/x-shockwave-flash"></embed>

  18. *

  19. * //酷六

  20. * http://v.ku6.com/special/show_3917484/x0BMXAbgZdQS6FqN.html

  21. * <embed src="http://player.ku6.com/refer/x0BMXAbgZdQS6FqN/v.swf" quality="high" width="480" height="400" align="middle" allowAccess="always" allowfullscreen="true" type="application/x-shockwave-flash"></embed>

  22. *

  23. * //土豆

  24. * http://www.tudou.com/playlist/p/a65929.html?iid=74905844

  25. * <embed src="http://www.tudou.com/l/A_0urj-Geec/&iid=74905844/v.swf" type="application/x-shockwave-flash" allowaccess="always" allowfullscreen="true" wmode="opaque" width="480" height="400"></embed>

  26. *

  27. * //56

  28. * http://www.56.com/u98/v_NTkyODY2NTU.html

  29. * <embed src="http://player.56.com/v_NTkyODY2NTU.swf" type="application/x-shockwave-flash" width="480" height="405" allowNetworking="all" allowAccess="always"></embed>

  30. *

  31. * //新浪播客

  32. * http://video.sina.com.cn/v/b/46909166-1290055681.html

  33. * <embed src="http://you.video.sina.com.cn/api/sinawebApi/outplayrefer.php/vid=46909166_1290055681_b0K1GHEwDWbK+l1lHz2stqkP7KQNt6nki2O0u1ehIwZYQ0/XM5GdZNQH6SjQBtkEqDhAQJ42dfcn0Rs/s.swf" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" name="ssss" allowFullScreen="true" allowAccess="always" width="480" height="370"></embed>

  34. *

  35. * //乐视

  36. * http://www.letv.com/ptv/vplay/1168109.html

  37. * <embed src="http://i3.imgs.letv.com/player/swfPlayer.swf?id=1168109&host=app.letv.com&vstatus=1&AP=1&logoMask=0&isShowP2p=0&autoplay=true" quality="high" scale="NO_SCALE" wmode="opaque" bgcolor="#000000" width="480" height="388" name="FLV_player" align="middle" allowaccess="always" allowfullscreen="true" type="application/x-shockwave-flash" pluginspage="http://www.macromedia.com/go/getflashplayer">

  38. */

  39. class VideoUrlParser

  40. {

  41. const USER_AGENT = "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/534.10 (KHTML, like Gecko)

  42. Chrome/8.0.552.224 Safari/534.10";

  43. const CHECK_URL_VALID = "/(youku\.com|tudou\.com|ku6\.com|56\.com|letv\.com|video\.sina\.com\.cn|(my\.)?tv\.sohu\.com|v\.qq\.com)/";

  44. /**

  45. * parse

  46. *

  47. * @param string $url

  48. * @param mixed $createObject

  49. * @static

  50. * @access public

  51. * @return void

  52. */

  53. static public function parse($url='', $createObject=true){

  54. $lowerurl = strtolower($url);

  55. preg_match(self::CHECK_URL_VALID, $lowerurl, $matches);

  56. if(!$matches) return false;

  57. switch($matches[1]){

  58. case 'youku.com':

  59. $data = self::_parseYouku($url);

  60. break;

  61. case 'tudou.com':

  62. $data = self::_parseTudou($url);

  63. break;

  64. case 'ku6.com':

  65. $data = self::_parseKu6($url);

  66. break;

  67. case '56.com':

  68. $data = self::_parse56($url);

  69. break;

  70. case 'letv.com':

  71. $data = self::_parseLetv($url);

  72. break;

  73. case 'video.sina.com.cn':

  74. $data = self::_parseSina($url);

  75. break;

  76. case 'my.tv.sohu.com':

  77. case 'tv.sohu.com':

  78. case 'sohu.com':

  79. $data = self::_parseSohu($url);

  80. break;

  81. case 'v.qq.com':

  82. $data = self::_parseQq($url);

  83. break;

  84. default:

  85. $data = false;

  86. }

  87. if($data && $createObject) $data['object'] = "<embed src="{$data['swf']}" quality="high" width="480" height="400" align="middle" allowNetworking="all" allowAccess="always" type="application/x-shockwave-flash"></embed>";

  88. return $data;

  89. }

  90. /**

  91. * 腾讯视频

  92. * http://v.qq.com/cover/o/o9tab7nuu0q3esh.html?vid=97abu74o4w3_0

  93. * http://v.qq.com/play/97abu74o4w3.html

  94. * http://v.qq.com/cover/d/dtdqyd8g7xvoj0o.html

  95. * http://v.qq.com/cover/d/dtdqyd8g7xvoj0o/9SfqULsrtSb.html

  96. * http://imgcache.qq.com/tencentvideo_v1/player/TencentPlayer.swf?_v=20110829&vid=97abu74o4w3&autoplay=1&list=2&showcfg=1&tpid=23&title=%E7%AC%AC%E4%B8%80%E7%8E%B0%E5%9C%BA&adplay=1&cid=o9tab7nuu0q3esh

  97. */

  98. private function _parseQq($url){

  99. if(preg_match("/\/play\//", $url)){

  100. $html = self::_fget($url);

  101. preg_match("/url=[^"]+/", $html, $matches);

  102. if(!$matches); return false;

  103. $url = $matches[0];

  104. }

  105. preg_match("/vid=([^\_]+)/", $url, $matches);

  106. $vid = $matches[1];

  107. $html = self::_fget($url);

  108. // query

  109. preg_match("/flashvars\s=\s"([^;]+)/s", $html, $matches);

  110. $query = $matches[1];

  111. if(!$vid){

  112. preg_match("/vid\s?=\s?vid\s?\|\|\s?"(\w+)";/i", $html, $matches);

  113. $vid = $matches[1];

  114. }

  115. $query = str_replace('"+vid+"', $vid, $query);

  116. parse_str($query, $output);

  117. $data['img'] = "http://vpic.video.qq.com/{$output['cid']}/{$vid}_1.jpg";

  118. $data['url'] = $url;

  119. $data['title'] = $output['title'];

  120. $data['swf'] = "http://imgcache.qq.com/tencentvideo_v1/player/TencentPlayer.swf?".$query;

  121. return $data;

  122. }

  123. /**

  124. * 优酷网

  125. * http://v.youku.com/v_show/id_XMjI4MDM4NDc2.html

  126. * http://player.youku.com/player.php/sid/XMjU0NjI2Njg4/v.swf

  127. */

  128. private function _parseYouku($url){

  129. preg_match("#id\_(\w+)#", $url, $matches);

  130. if (empty($matches)){

  131. preg_match("#v_playlist\/#", $url, $mat);

  132. if(!$mat) return false;

  133. $html = self::_fget($url);

  134. preg_match("#videoId2\s*=\s*\'(\w+)\'#", $html, $matches);

  135. if(!$matches) return false;

  136. }

  137. $link = "http://v.youku.com/player/getPlayList/VideoIDS/{$matches[1]}/timezone/+08/version/5/source/out?password=&ran=2513&n=3";

  138. $retval = self::_cget($link);

  139. if ($retval) {

  140. $json = json_decode($retval, true);

  141. $data['img'] = $json['data'][0]['logo'];

  142. $data['title'] = $json['data'][0]['title'];

  143. $data['url'] = $url;

  144. $data['swf'] = "http://player.youku.com/player.php/sid/{$matches[1]}/v.swf";

  145. return $data;

  146. } else {

  147. return false;

  148. }

  149. }

  150. /**

  151. * 土豆网

  152. * http://www.tudou.com/programs/view/Wtt3FjiDxEE/

  153. * http://www.tudou.com/v/Wtt3FjiDxEE/v.swf

  154. *

  155. * http://www.tudou.com/playlist/p/a65718.html?iid=74909603

  156. * http://www.tudou.com/l/G5BzgI4lAb8/&iid=74909603/v.swf

  157. */

  158. private function _parseTudou($url){

  159. preg_match("#view/([-\w]+)/#", $url, $matches);

  160. $lowerurl = "";

  161. if (empty($matches)) {

  162. if (strpos($url, "/playlist/") == false) return false;

  163. if(strpos($url, 'iid=') !== false){

  164. $quarr = explode("iid=", $lowerurl);

  165. if (empty($quarr[1])) return false;

  166. }elseif(preg_match("#p\/l(\d+).#", $lowerurl, $quarr)){

  167. if (empty($quarr[1])) return false;

  168. }

  169. $html = self::_fget($url);

  170. $html = iconv("GB2312", "UTF-8", $html);

  171. preg_match("/lid_code\s=\slcode\s=\s[\'"]([^\'"]+)/s", $html, $matches);

  172. $icode = $matches[1];

  173. preg_match("/iid\s=\s.*?\|\|\s(\d+)/sx", $html, $matches);

  174. $iid = $matches[1];

  175. preg_match("/listData\s=\s(\[\{.*\}\])/sx", $html, $matches);

  176. $find = array("/\n/", '/\s/', "/:[^\d"]\w+[^\,]*,/i", "/(\{|,)(\w+):/");

  177. $replace = array("", "", ':"",', '\\1"\\2":');

  178. $str = preg_replace($find, $replace, $matches[1]);

  179. //var_dump($str);

  180. $json = json_decode($str);

  181. //var_dump($json);exit;

  182. if(is_array($json) || is_object($json) && !empty($json)){

  183. foreach ($json as $val) {

  184. if ($val->iid == $iid) {

  185. break;

  186. }

  187. }

  188. }

  189. $data['img'] = $val->pic;

  190. $data['title'] = $val->title;

  191. $data['url'] = $url;

  192. $data['swf'] = "http://www.tudou.com/l/{$icode}/&iid={$iid}/v.swf";

  193. return $data;

  194. }

  195. $host = "www.tudou.com";

  196. $path = "/v/{$matches[1]}/v.swf";

  197. $ret = self::_fsget($path, $host);

  198. $snap_pic = "";

  199. $title = "";

  200. if (preg_match("#\nLocation: (.*)\n#", $ret, $mat)) {

  201. parse_str(parse_url(urldecode($mat[1]), PHP_URL_QUERY));

  202. $data['img'] = $snap_pic;

  203. $data['title'] = $title;

  204. $data['url'] = $url;

  205. $data['swf'] = "http://www.tudou.com/v/{$matches[1]}/v.swf";

  206. return $data;

  207. }

  208. return false;

  209. }

  210. /**

  211. * 酷6网

  212. * http://v.ku6.com/film/show_520/3X93vo4tIS7uotHg.html

  213. * http://v.ku6.com/special/show_4926690/Klze2mhMeSK6g05X.html

  214. * http://v.ku6.com/show/7US-kDXjyKyIInDevhpwHg...html

  215. * http://player.ku6.com/refer/3X93vo4tIS7uotHg/v.swf

  216. */

  217. private function _parseKu6($url){

  218. if(preg_match("/show\_/", $url)){

  219. preg_match("#/([-\w]+)\.html#", $url, $matches);

  220. $url = "http://v.ku6.com/fetchVideo4Player/{$matches[1]}.html";

  221. $html = self::_fget($url);

  222. if ($html) {

  223. $json = json_decode($html, true);

  224. if(!$json) return false;

  225. $data['img'] = $json['data']['picpath'];

  226. $data['title'] = $json['data']['t'];

  227. $data['url'] = $url;

  228. $data['swf'] = "http://player.ku6.com/refer/{$matches[1]}/v.swf";

  229. return $data;

  230. } else {

  231. return false;

  232. }

  233. }elseif(preg_match("/show\//", $url, $matches)){

  234. $html = self::_fget($url);

  235. preg_match("/ObjectInfo\s?=\s?([^\n]*)};/si", $html, $matches);

  236. $str = $matches[1];

  237. // img

  238. preg_match("/cover\s?:\s?"([^"]+)"/", $str, $matches);

  239. $data['img'] = $matches[1];

  240. // title

  241. preg_match("/title"?\s?:\s?"([^"]+)"/", $str, $matches);

  242. $jsstr = "{"title":"{$matches[1]}"}";

  243. $json = json_decode($jsstr, true);

  244. $data['title'] = $json['title'];

  245. // url

  246. $data['url'] = $url;

  247. // query

  248. preg_match("/"(vid=[^"]+)"\sname="flashVars"/s", $html, $matches);

  249. $query = str_replace("&", '&', $matches[1]);

  250. preg_match("/\/\/player\.ku6cdn\.com[^"\']+/", $html, $matches);

  251. $data['swf'] = 'http:'.$matches[0].'?'.$query;

  252. return $data;

  253. }

  254. }

  255. /**

  256. * 56网

  257. * http://www.56.com/u73/v_NTkzMDcwNDY.html

  258. * http://player.56.com/v_NTkzMDcwNDY.swf

  259. */

  260. private function _parse56($url){

  261. preg_match("#/v_(\w+)\.html#", $url, $matches);

  262. if (empty($matches)) return false;

  263. $link="http://vxml.56.com/json/{$matches[1]}/?src=out";

  264. $retval = self::_cget($link);

  265. if ($retval) {

  266. $json = json_decode($retval, true);

  267. $data['img'] = $json['info']['img'];

  268. $data['title'] = $json['info']['Subject'];

  269. $data['url'] = $url;

  270. $data['swf'] = "http://player.56.com/v_{$matches[1]}.swf";

  271. return $data;

  272. } else {

  273. return false;

  274. }

  275. }

  276. /**

  277. * 乐视网

  278. * http://www.letv.com/ptv/vplay/1168109.html

  279. * http://www.letv.com/player/x1168109.swf

  280. */

  281. private function _parseLetv($url){

  282. $html = self::_fget($url);

  283. $pic = "";

  284. $title = "";

  285. preg_match("#http://v.t.sina.com.cn/([^'"]*)#", $html, $matches);

  286. parse_str(parse_url(urldecode($matches[0]), PHP_URL_QUERY));

  287. preg_match("#vplay/(\d+)#", $url, $matches);

  288. $data['img'] = $pic;

  289. $data['title'] = $title;

  290. $data['url'] = $url;

  291. $data['swf'] = "http://www.letv.com/player/x{$matches[1]}.swf";

  292. return $data;

  293. }

  294. // 搜狐TV http://my.tv.sohu.com/u/vw/5101536

  295. private function _parseSohu($url){

  296. $html = self::_fget($url);

  297. $html = iconv("GB2312", "UTF-8", $html);

  298. preg_match_all("/og:(?:title|image|videosrc)"\scontent="([^"]+)"/s", $html, $matches);

  299. $data['img'] = $matches[1][1];

  300. $data['title'] = $matches[1][0];

  301. $data['url'] = $url;

  302. $data['swf'] = $matches[1][2];

  303. return $data;

  304. }

  305. /*

  306. * 新浪播客

  307. * http://video.sina.com.cn/v/b/48717043-1290055681.html

  308. * http://you.video.sina.com.cn/api/sinawebApi/outplayrefer.php/vid=48717043_1290055681_PUzkSndrDzXK+l1lHz2stqkP7KQNt6nki2O0u1ehIwZYQ0/XM5GdatoG5ynSA9kEqDhAQJA4dPkm0x4/s.swf

  309. */

  310. private function _parseSina($url){

  311. preg_match("/(\d+)(?:\-|\_)(\d+)/", $url, $matches);

  312. $url = "http://video.sina.com.cn/v/b/{$matches[1]}-{$matches[2]}.html";

  313. $html = self::_fget($url);

  314. preg_match("/video\s?:\s?([^<]+)}/", $html, $matches);

  315. $find = array("/\n/", "/\s*/", "/\'/", "/\{([^:,]+):/", "/,([^:]+):/", "/:[^\d"]\w+[^\,]*,/i");

  316. $replace = array('', '', '"', '{"\\1":', ',"\\1":', ':"",');

  317. $str = preg_replace($find, $replace, $matches[1]);

  318. $arr = json_decode($str, true);

  319. $data['img'] = $arr['pic'];

  320. $data['title'] = $arr['title'];

  321. $data['url'] = $url;

  322. $data['swf'] = $arr['swfOutsideUrl'];

  323. return $data;

  324. }

  325. /*

  326. * 通过 file_get_contents 获取内容

  327. */

  328. private function _fget($url=''){

  329. if(!$url) return false;

  330. $html = file_get_contents($url);

  331. // 判断是否gzip压缩

  332. if($dehtml = self::_gzdecode($html))

  333. return $dehtml;

  334. else

  335. return $html;

  336. }

  337. /*

  338. * 通过 fsockopen 获取内容

  339. */

  340. private function _fsget($path='/', $host='', $user_agent=''){

  341. if(!$path || !$host) return false;

  342. $user_agent = $user_agent ? $user_agent : self::USER_AGENT;

  343. $out = <<<HEADER

  344. GET $path HTTP/1.1

  345. Host: $host

  346. User-Agent: $user_agent

  347. Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

  348. Accept-Language: zh-cn,zh;q=0.5

  349. Accept-Charset: GB2312,utf-8;q=0.7,*;q=0.7\r\n\r\n

  350. HEADER;

  351. $fp = @fsockopen($host, 80, $errno, $errstr, 10);

  352. $html = "";

  353. if (!$fp) return false;

  354. if(!fputs($fp, $out)) return false;

  355. while ( !feof($fp) ) {

  356. $html .= fgets($fp, 1024);

  357. }

  358. fclose($fp);

  359. // 判断是否gzip压缩

  360. if($dehtml = self::_gzdecode($html))

  361. return $dehtml;

  362. else

  363. return $html;

  364. }

  365. /*

  366. * 通过 curl 获取内容

  367. */

  368. private function _cget($url='', $user_agent=''){

  369. if(!$url) return;

  370. $user_agent = $user_agent ? $user_agent : self::USER_AGENT;

  371. $ch = curl_init();

  372. curl_setopt($ch, CURLOPT_URL, $url);

  373. curl_setopt($ch, CURLOPT_HEADER, 0);

  374. if(strlen($user_agent)) curl_setopt($ch, CURLOPT_USERAGENT, $user_agent);

  375. ob_start();

  376. curl_exec($ch);

  377. $html = ob_get_contents();

  378. ob_end_clean();

  379. if(curl_errno($ch)){

  380. curl_close($ch);

  381. return false;

  382. }

  383. curl_close($ch);

  384. if(!is_string($html) || !strlen($html)){

  385. return false;

  386. }

  387. return $html;

  388. // 判断是否gzip压缩

  389. if($dehtml = self::_gzdecode($html))

  390. return $dehtml;

  391. else

  392. return $html;

  393. }

  394. private function _gzdecode($data) {

  395. $len = strlen ( $data );

  396. if ($len < 18 || strcmp ( substr ( $data, 0, 2 ), "\x1f\x8b" )) {

  397. return null; // Not GZIP format (See RFC 1952)

  398. }

  399. $method = ord ( substr ( $data, 2, 1 ) ); // Compression method

  400. $flags = ord ( substr ( $data, 3, 1 ) ); // Flags

  401. if ($flags & 31 != $flags) {

  402. // Reserved bits are set -- NOT ALLOWED by RFC 1952

  403. return null;

  404. }

  405. // NOTE: $mtime may be negative (PHP integer limitations)

  406. $mtime = unpack ( "V", substr ( $data, 4, 4 ) );

  407. $mtime = $mtime [1];

  408. $xfl = substr ( $data, 8, 1 );

  409. $os = substr ( $data, 8, 1 );

  410. $headerlen = 10;

  411. $extralen = 0;

  412. $extra = "";

  413. if ($flags & 4) {

  414. // 2-byte length prefixed EXTRA data in header

  415. if ($len - $headerlen - 2 < 8) {

  416. return false; // Invalid format

  417. }

  418. $extralen = unpack ( "v", substr ( $data, 8, 2 ) );

  419. $extralen = $extralen [1];

  420. if ($len - $headerlen - 2 - $extralen < 8) {

  421. return false; // Invalid format

  422. }

  423. $extra = substr ( $data, 10, $extralen );

  424. $headerlen += 2 + $extralen;

  425. }

  426. $filenamelen = 0;

  427. $filename = "";

  428. if ($flags & 8) {

  429. // C-style string file NAME data in header

  430. if ($len - $headerlen - 1 < 8) {

  431. return false; // Invalid format

  432. }

  433. $filenamelen = strpos ( substr ( $data, 8 + $extralen ), chr ( 0 ) );

  434. if ($filenamelen === false || $len - $headerlen - $filenamelen - 1 < 8) {

  435. return false; // Invalid format

  436. }

  437. $filename = substr ( $data, $headerlen, $filenamelen );

  438. $headerlen += $filenamelen + 1;

  439. }

  440. $commentlen = 0;

  441. $comment = "";

  442. if ($flags & 16) {

  443. // C-style string COMMENT data in header

  444. if ($len - $headerlen - 1 < 8) {

  445. return false; // Invalid format

  446. }

  447. $commentlen = strpos ( substr ( $data, 8 + $extralen + $filenamelen ), chr ( 0 ) );

  448. if ($commentlen === false || $len - $headerlen - $commentlen - 1 < 8) {

  449. return false; // Invalid header format

  450. }

  451. $comment = substr ( $data, $headerlen, $commentlen );

  452. $headerlen += $commentlen + 1;

  453. }

  454. $headercrc = "";

  455. if ($flags & 1) {

  456. // 2-bytes (lowest order) of CRC32 on header present

  457. if ($len - $headerlen - 2 < 8) {

  458. return false; // Invalid format

  459. }

  460. $calccrc = crc32 ( substr ( $data, 0, $headerlen ) ) & 0xffff;

  461. $headercrc = unpack ( "v", substr ( $data, $headerlen, 2 ) );

  462. $headercrc = $headercrc [1];

  463. if ($headercrc != $calccrc) {

  464. return false; // Bad header CRC

  465. }

  466. $headerlen += 2;

  467. }

  468. // GZIP FOOTER - These be negative due to PHP's limitations

  469. $datacrc = unpack ( "V", substr ( $data, - 8, 4 ) );

  470. $datacrc = $datacrc [1];

  471. $isize = unpack ( "V", substr ( $data, - 4 ) );

  472. $isize = $isize [1];

  473. // Perform the decompression:

  474. $bodylen = $len - $headerlen - 8;

  475. if ($bodylen < 1) {

  476. // This should never happen - IMPLEMENTATION BUG!

  477. return null;

  478. }

  479. $body = substr ( $data, $headerlen, $bodylen );

  480. $data = "";

  481. if ($bodylen > 0) {

  482. switch ($method) {

  483. case 8 :

  484. // Currently the only supported compression method:

  485. $data = gzinflate ( $body );

  486. break;

  487. default :

  488. // Unknown compression method

  489. return false;

  490. }

  491. } else {

  492. //...

  493. }

  494. if ($isize != strlen ( $data ) || crc32 ( $data ) != $datacrc) {

  495. // Bad format! Length or CRC doesn't match!

  496. return false;

  497. }

  498. return $data;

  499. }

  500. }
复制代码


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

灌水成绩
406
主题
410
帖子
1574
积分
等级头衔
积分成就
  • 威望: 0
  • 贡献: 1164
  • 金钱: 0
  • 违规:
  • 在线时间:156 小时
  • 注册时间:2020-2-11
  • 最后登录:2020-8-23
个人勋章

最佳新人活跃会员热心会员突出贡献优秀版主论坛元老精贴王灌水之王荣誉管理

联系方式