get.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. /*
  3. 获取句子译文
  4. */
  5. require_once "../path.php";
  6. require_once "../public/_pdo.php";
  7. require_once "../public/function.php";
  8. #查询有阅读权限的channel
  9. $channal_list = array();
  10. if(isset($_COOKIE["userid"])){
  11. PDO_Connect("sqlite:"._FILE_DB_CHANNAL_);
  12. $query = "SELECT id from channal where owner = ? limit 0,100";
  13. $Fetch_my = PDO_FetchAll($query,array($_COOKIE["userid"]));
  14. foreach ($Fetch_my as $key => $value) {
  15. # code...
  16. $channal_list[]=$value["id"];
  17. }
  18. # 找协作的
  19. $Fetch_coop = array();
  20. $query = "SELECT channal_id FROM cooperation WHERE user_id = ? ";
  21. $coop_channal = PDO_FetchAll($query,array($_COOKIE["userid"]));
  22. if(count($coop_channal)>0){
  23. foreach ($coop_channal as $key => $value) {
  24. # code...
  25. $channal_list[]=$value["channal_id"];
  26. }
  27. }
  28. /* 创建一个填充了和params相同数量占位符的字符串 */
  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. }
  34. else{
  35. $channel_query = "";
  36. }
  37. # 查询有阅读权限的channel 结束
  38. $dns = "sqlite:"._FILE_DB_SENTENCE_;
  39. $dbh = new PDO($dns, "", "",array(PDO::ATTR_PERSISTENT=>true));
  40. $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  41. /* 开始一个事务,关闭自动提交 */
  42. if(isset($_GET["sentences"])){
  43. #查询句子编号列表
  44. $arrSent = explode(",",$_GET["sentences"]);
  45. /* 创建一个填充了和params相同数量占位符的字符串 */
  46. $place_holders = implode(',', array_fill(0, count($arrSent), '?'));
  47. $query="SELECT * FROM sentence WHERE id IN ($place_holders) and (status = 30 {$channel_query} )";
  48. $stmt = $dbh->prepare($query);
  49. $stmt->execute($arrSent);
  50. }
  51. else{
  52. $book = $_GET["book"];
  53. $para = $_GET["para"];
  54. $begin = $_GET["begin"];
  55. $end = $_GET["end"];
  56. $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 ";
  57. $stmt = $dbh->prepare($query);
  58. $parm = array($book,$para,$begin,$end);
  59. $parm = array_merge_recursive($parm,$channal_list);
  60. $stmt->execute($parm);
  61. }
  62. $Fetch = $stmt->fetchAll(PDO::FETCH_ASSOC);
  63. echo json_encode($Fetch, JSON_UNESCAPED_UNICODE);
  64. ?>