FillDescription.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?php
  2. namespace app\admin\command;
  3. use think\console\Command;
  4. use think\console\Input;
  5. use think\console\Output;
  6. use think\Request;
  7. class FillDescription extends Command
  8. {
  9. protected function configure()
  10. {
  11. $this->setName('FillDescription')->setDescription('填充图文推荐库的简介内容');
  12. }
  13. protected function execute(Input $input, Output $output)
  14. {
  15. Request::instance()->module('admin');
  16. //更新智能推送库
  17. $this->updateSmartPush($output);
  18. //更新自动回复资源库
  19. $this->updateResponse($output);
  20. }
  21. //更新自动回复资源库
  22. protected function updateResponse(Output $output){
  23. if($response_list = model('WechatResponse')->where('type','news')->column('id,content')){
  24. foreach($response_list as $id => $content){
  25. //解析json
  26. if(!$source = json_decode($content,true)){
  27. $output->warning("id:{$id} Failed to parse data content, skipped");
  28. continue;
  29. }
  30. foreach($source as $key => &$val){
  31. try{
  32. //获取url
  33. if(!$url = $val['url'] ?? ''){
  34. $output->warning("id:{$id} URL acquisition failed, skipped");
  35. continue;
  36. }
  37. //解析book_id
  38. if(!$book_id = $this->getUrlParams('book_id',$url)){
  39. $output->warning("id:{$id} Failed to get book ID, skipped");
  40. continue;
  41. }
  42. //获取书籍简介
  43. if(!$up_description = model('Book')->where('id',$book_id)->value('description')){
  44. $output->warning("id:{$id} book_id:{$book_id} Books are empty of information");
  45. continue;
  46. }
  47. //已设置过简介
  48. if(isset($val['description']) && trim($val['description'])){
  49. $output->warning("id:{$id} book_id:{$book_id} Brief introduction is not skipped");
  50. continue;
  51. }
  52. $val['description'] = $up_description;
  53. $up_content = ['content'=>json_encode($source,JSON_UNESCAPED_UNICODE)];
  54. model('WechatResponse')->where('id',$id)->update($up_content);
  55. $output->info("id:{$id} book_id:{$book_id} Brief Introduction to Successful Update ".($val['description'] ?? ''));
  56. }catch (\Exception $e){
  57. $output->warning("id:{$id} WeChat Response Exception:".$e->getMessage());
  58. }
  59. }
  60. }
  61. }else{
  62. $output->warning("wechat_response table is null");
  63. }
  64. $output->newLine(1);
  65. $output->question("**************微信自动回复资源库修改完成**************");
  66. $output->newLine(1);
  67. }
  68. private function getUrlParams($name,$url){
  69. try{
  70. if($url_array = parse_url($url)){
  71. parse_str($url_array['query'], $query_arr);
  72. if(isset($query_arr[$name])){
  73. return $query_arr[$name];
  74. }else{
  75. return false;
  76. }
  77. }else{
  78. return false;
  79. }
  80. }catch (\Exception $e){
  81. return false;
  82. }catch (\Throwable $e){
  83. return false;
  84. }
  85. }
  86. //更新智能推送库
  87. /**
  88. * @param Output $output
  89. */
  90. protected function updateSmartPush(Output $output){
  91. $output->newLine(2);
  92. if($smart_list = model('SmartRecommand')->column('id,book_id,description')){
  93. foreach($smart_list as $id => $val){
  94. $book_id = $val['book_id'];
  95. $description = $val['description'];
  96. //检查简介是否为空
  97. if(trim($description)){
  98. $output->warning("id:{$id} book_id:{$book_id} Brief introduction is not skipped");
  99. continue;
  100. }
  101. //检查book_id
  102. if(!intval($book_id)){
  103. $output->warning("id:{$id} book_id:{$book_id} Book_id error skipped");
  104. continue;
  105. }
  106. //获取书籍简介信息
  107. if(!$up_description = model('Book')->where('id',$book_id)->value('description')){
  108. $output->warning("id:{$id} book_id:{$book_id} Books are empty of information");
  109. continue;
  110. }
  111. //更新
  112. model('SmartRecommand')->where('id',$id)->update(['description'=>$up_description]);
  113. $output->info("id:{$id} book_id:{$book_id} Brief Introduction to Successful Update ".$up_description);
  114. }
  115. }else{
  116. $output->warning("smart_recommand table is null");
  117. }
  118. $output->newLine(1);
  119. $output->question("**************智能推送库修改完成**************");
  120. $output->newLine(1);
  121. }
  122. }