kvflush.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <?php
  2. namespace loyalsoft;
  3. include_once __DIR__ . '/../../main.php';
  4. require_once ROOTDIR . '/Util/OpenSSLVerify.php'; #Ps. 这个文件和类名没有对应关系.
  5. define("CLOGUTIL_DEBUG", true);
  6. /**
  7. * Description of config
  8. * 数据中转功能.
  9. * 通过远程地址向服务器刷入Cmem的key-value数据. key和value通过gzcompress和base64处理.
  10. * @version
  11. * 1.0.1 通过openssl,RSA验证发送方具有刷数据的权限.
  12. * 1.0.0 基础功能, 没有安全功能.
  13. * @author gwang email:wanggangzero@qq.com
  14. * @copyright © 2015-12-1, SJZ LoyalSoft Corporation & gwang. All rights reserved.
  15. */
  16. /**
  17. * Description of kvflush
  18. * 写一个key=>value对到目标CMEM
  19. * @author gwang
  20. */
  21. class kvflush {
  22. public static function flush() {
  23. InitZoneId(); # 初始化分区信息 Ps. $_REQUEST["zoneid"]
  24. $params = HttpUtil::getQueryParas();
  25. $key = CommUtil::zb64decode(urldecode($params["key"]));
  26. $val = CommUtil::zb64decode(urldecode($params["val"]));
  27. $user = urldecode($params["user"]);
  28. $type = urldecode($params['type']);
  29. $keypath = ROOTDIR . "/Util/key";
  30. $myrsa = new MyRsa($keypath);
  31. $sign = urldecode($params['sign']);
  32. if (!$myrsa->verify_arr($params, $sign)) { # 验证下签名
  33. echo "签名验证失败!";
  34. } else {
  35. switch ($type) {
  36. case 'hash':
  37. $val = json_decode($val); # 需要还原为Obj才能解开
  38. $ret = self::FlushToMem_hmSet($key, $val);
  39. self::FlushToFile_hash($key, $val);
  40. break;
  41. case 'normal':
  42. $ret = self::FlushToMem_set($key, $val);
  43. self::FlushToFile_str($key, $val);
  44. break;
  45. default :
  46. $ret = self::FlushToMem_set($key, $val);
  47. break;
  48. }
  49. if ($ret) {
  50. echo "success";
  51. self::log($user, $key); # 记录日志
  52. } else {
  53. echo "[$key] flush to mem failed!";
  54. }
  55. }
  56. unset($myrsa);
  57. }
  58. //put your code here
  59. static function log($user, $modelname) {
  60. $who = $user . '_' . HttpUtil::clientIP();
  61. $key = "log-flush";
  62. CLog::warn($who . "flushing [$modelname]", __CLASS__); # 写文件
  63. $mem = gMem();
  64. $ret = $mem->hset($key, $who, TimeUtil::tsYmdHis()); # 写入mem
  65. $mem->close();
  66. return $ret;
  67. }
  68. /**
  69. * 普通写入方法
  70. * @param string $key
  71. * @param mixed $value
  72. * @return boolean
  73. */
  74. public static function FlushToMem_set($key, $value) {
  75. $mem = gMem();
  76. $mem->delete($key);
  77. $ret = $mem->set($key, $value); # 写入mem
  78. $mem->close();
  79. return $ret;
  80. }
  81. /**
  82. * 写入哈希表
  83. * @param string $key
  84. * @param obj/assoc_arr $assoc_array
  85. * @return type
  86. */
  87. public static function FlushToMem_hmSet($key, $assoc_array) {
  88. $mem = gMem();
  89. if (!is_array($assoc_array)) {
  90. if (is_object($assoc_array)) {
  91. $assoc_arr = array();
  92. foreach ($assoc_array as $k => $v) { # 组合成符合hmset的关联数组
  93. $assoc_arr[$k] = JsonUtil::encode($v);
  94. }
  95. $assoc_array = $assoc_arr;
  96. } else {
  97. return false;
  98. }
  99. }
  100. $ret = TRUE;
  101. if (count($assoc_arr) > 0) {
  102. $mem->delete($key);
  103. $ret = $mem->hmset($key, $assoc_array); # 写入
  104. }
  105. $mem->close();
  106. return $ret;
  107. }
  108. private static function getFolder() {
  109. if (defined('CodeGen_Folder')) {
  110. if (!dir(CodeGen_Folder)) {
  111. if (mkdir(CodeGen_Folder)) {
  112. return CodeGen_Folder;
  113. }
  114. } else {
  115. return CodeGen_Folder;
  116. }
  117. }
  118. return ROOTDIR . '/Configs/data/';
  119. }
  120. private static function writePHPFile($key, $value) {
  121. if (defined('CodeGen_Enabled') && CodeGen_Enabled) { # (部署环境)是否允许代码生成
  122. $file = fopen(self::getFolder() . $key . ".php", 'w');
  123. $str = "<?php " . PHP_EOL . " return unserialize('" . serialize($value) . "');";
  124. fwrite($file, $str);
  125. fclose($file);
  126. }
  127. }
  128. private static function FlushToFile_str($key, $value) {
  129. if ($key == "gamecfg-client") {
  130. self::writePHPFile($key, $value);
  131. } else {
  132. self::writePHPFile($key, JsonUtil::decode($value));
  133. }
  134. }
  135. private static function FlushToFile_hash($key, $assoc_array) {
  136. self::writePHPFile($key, $assoc_array);
  137. }
  138. }
  139. //exit("success");
  140. CLog::err(HttpUtil::getQueryString(), "刷数据");
  141. HttpUtil::PostOnly();
  142. kvflush::flush(); # do it