get_chapter_info.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  2. require_once __DIR__.'/../config.php';
  3. require_once __DIR__.'/../redis/function.php';
  4. $redis = redis_connect();
  5. $dns = _FILE_DB_PALI_TOC_;
  6. $dbh_toc = new PDO($dns, _DB_USERNAME_, _DB_PASSWORD_, array(PDO::ATTR_PERSISTENT => true));
  7. $dbh_toc->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  8. $dns = _FILE_DB_PALITEXT_;
  9. $dbh_pali_text = new PDO($dns, _DB_USERNAME_, _DB_PASSWORD_, array(PDO::ATTR_PERSISTENT => true));
  10. $dbh_pali_text->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  11. $dns = _FILE_DB_RESRES_INDEX_;
  12. $dbh_res = new PDO($dns, _DB_USERNAME_, _DB_PASSWORD_, array(PDO::ATTR_PERSISTENT => true));
  13. $dbh_res->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
  14. if (isset($_GET["book"])) {
  15. $book = (int) $_GET["book"];
  16. }
  17. if (isset($_GET["para"])) {
  18. $para = (int) $_GET["para"];
  19. }
  20. $query = "SELECT * FROM "._TABLE_PALI_TEXT_." WHERE book = ? and paragraph = ?";
  21. $stmt = $dbh_pali_text->prepare($query);
  22. $stmt->execute(array($book, $para));
  23. $paraInfo = $stmt->fetch(PDO::FETCH_ASSOC);
  24. if ($paraInfo) {
  25. # 查进度
  26. $paraProgress = array();
  27. if ($redis) {
  28. $count = $redis->hLen("progress_chapter_{$book}_{$para}");
  29. if ($count > 0) {
  30. $prog = $redis->hGetAll("progress_chapter_{$book}_{$para}");
  31. foreach ($prog as $keylang => $valuetrans) {
  32. # code...
  33. $paraProgress[] = array("lang" => $keylang, "all_trans" => $valuetrans);
  34. }
  35. }
  36. } else {
  37. $query = "SELECT lang, all_trans from "._TABLE_PROGRESS_CHAPTER_." where book=? and para=?";
  38. $stmt = $dbh_toc->prepare($query);
  39. $sth_toc = $dbh_toc->prepare($query);
  40. $sth_toc->execute(array($book, $para));
  41. $paraProgress = $sth_toc->fetchAll(PDO::FETCH_ASSOC);
  42. }
  43. $paraInfo["progress"] = $paraProgress;
  44. #查标题
  45. if (isset($_GET["lang"])) {
  46. $query = "SELECT title from \""._TABLE_RES_INDEX_."\" where book=? and paragraph=? and language=?";
  47. $stmt = $dbh_res->prepare($query);
  48. $sth_title = $dbh_res->prepare($query);
  49. $sth_title->execute(array($book, $para, $_GET["lang"]));
  50. $trans_title = $sth_title->fetch(PDO::FETCH_ASSOC);
  51. if ($trans_title) {
  52. $paraInfo["trans_title"] = $trans_title['title'];
  53. }
  54. }
  55. echo json_encode($paraInfo, JSON_UNESCAPED_UNICODE);
  56. } else {
  57. echo json_encode(array(), JSON_UNESCAPED_UNICODE);
  58. }