get.php 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?php
  2. /*
  3. 获取句子译文
  4. */
  5. require_once "../path.php";
  6. require_once "../public/_pdo.php";
  7. require_once "../public/function.php";
  8. require_once "../channal/function.php";
  9. require_once "../redis/function.php";
  10. require_once "../ucenter/function.php";
  11. require_once "../share/function.php";
  12. $redis = redis_connect();
  13. #查询有阅读权限的channel
  14. $channal_list = array();
  15. if (isset($_COOKIE["userid"])) {
  16. PDO_Connect(_FILE_DB_CHANNAL_);
  17. $query = "SELECT id from channal where owner = ? limit 0,100";
  18. $Fetch_my = PDO_FetchAll($query, array($_COOKIE["userid"]));
  19. foreach ($Fetch_my as $key => $value) {
  20. # code...
  21. $channal_list[] = $value["id"];
  22. }
  23. # 找协作的
  24. $coop_channal = share_res_list_get($_COOKIE["userid"],2);
  25. foreach ($coop_channal as $key => $value) {
  26. # code...
  27. $channal_list[] = $value["res_id"];
  28. }
  29. }
  30. if (count($channal_list) > 0) {
  31. $channel_place_holders = implode(',', array_fill(0, count($channal_list), '?'));
  32. $channel_query = " OR channal IN ($channel_place_holders)";
  33. } else {
  34. $channel_query = "";
  35. }
  36. # 查询有阅读权限的channel 结束
  37. $dbh = new PDO(_FILE_DB_SENTENCE_, "", "", array(PDO::ATTR_PERSISTENT => true));
  38. $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  39. /* 开始一个事务,关闭自动提交 */
  40. if (isset($_GET["sentences"])) {
  41. #查询句子编号列表
  42. $arrSent = explode(",", $_GET["sentences"]);
  43. /* 创建一个填充了和params相同数量占位符的字符串 */
  44. $place_holders = implode(',', array_fill(0, count($arrSent), '?'));
  45. $query = "SELECT * FROM sentence WHERE id IN ($place_holders) and (status = 30 {$channel_query} )";
  46. $stmt = $dbh->prepare($query);
  47. $stmt->execute($arrSent);
  48. } else {
  49. $book = $_GET["book"];
  50. $para = $_GET["para"];
  51. $begin = $_GET["begin"];
  52. $end = $_GET["end"];
  53. $query = "SELECT * FROM sentence WHERE (book = ? AND paragraph = ? AND begin = ? AND end = ? and strlen >0 and (status = 30 {$channel_query} ) ) order by modify_time DESC ";
  54. $stmt = $dbh->prepare($query);
  55. $parm = array($book, $para, $begin, $end);
  56. $parm = array_merge_recursive($parm, $channal_list);
  57. $stmt->execute($parm);
  58. }
  59. $Fetch = $stmt->fetchAll(PDO::FETCH_ASSOC);
  60. $channel_info = new Channal($redis);
  61. $user_info = new UserInfo();
  62. foreach ($Fetch as $key => $value) {
  63. # code...
  64. $channel = $channel_info->getChannal($value["channal"]);
  65. if ($channel) {
  66. $Fetch[$key]["mypower"] = $channel_info->getPower($value["channal"]);
  67. $Fetch[$key]["c_name"] = $channel["name"];
  68. $Fetch[$key]["c_owner"] = $user_info->getName($channel["owner"]);
  69. $Fetch[$key]["channalinfo"] = $channel;
  70. }
  71. else{
  72. $Fetch[$key]["c_name"] = "unkow";
  73. $Fetch[$key]["c_owner"] = "unkow";
  74. }
  75. $Fetch[$key]["editor_name"]=$user_info->getName($value["editor"]);
  76. $Fetch[$key]["update_time"]=$value["modify_time"];
  77. }
  78. echo json_encode($Fetch, JSON_UNESCAPED_UNICODE);