国内流行的内容管理系统(CMS)多端全媒体解决方案 https://www.dedebiz.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

236 lines
9.7KB

  1. <?php
  2. /**
  3. * @version $Id: config.php 1 8:38 2010年7月9日Z tianya $
  4. * @package DedeBIZ.Member
  5. * @copyright Copyright (c) 2020, DedeBIZ.COM
  6. * @license https://www.dedebiz.com/license
  7. * @link https://www.dedebiz.com
  8. */
  9. //针对会员中心操作进行XSS过滤
  10. function XSSClean($val)
  11. {
  12. global $cfg_soft_lang;
  13. if ($cfg_soft_lang == 'gb2312') gb2utf8($val);
  14. if (is_array($val)) {
  15. // while (list($key) = each($val))
  16. foreach ($val as $key => $value) {
  17. if (in_array($key, array('tags', 'body', 'dede_fields', 'dede_addonfields', 'dopost', 'introduce'))) continue;
  18. $val[$key] = XSSClean($val[$key]);
  19. }
  20. return $val;
  21. }
  22. $val = preg_replace('/([\x00-\x08,\x0b-\x0c,\x0e-\x19])/', '', $val);
  23. $search = 'abcdefghijklmnopqrstuvwxyz';
  24. $search .= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  25. $search .= '1234567890!@#$%^&*()';
  26. $search .= '~`";:?+/={}[]-_|\'\\';
  27. for ($i = 0; $i < strlen($search); $i++) {
  28. $val = preg_replace('/(&#[xX]0{0,8}' . dechex(ord($search[$i])) . ';?)/i', $search[$i], $val); // with a ;
  29. $val = preg_replace('/(&#0{0,8}' . ord($search[$i]) . ';?)/', $search[$i], $val); // with a ;
  30. }
  31. $val = str_replace("`", "‘", $val);
  32. $val = str_replace("'", "‘", $val);
  33. $val = str_replace("\"", "“", $val);
  34. $val = str_replace(",", ",", $val);
  35. $val = str_replace("(", "(", $val);
  36. $val = str_replace(")", ")", $val);
  37. $ra1 = array('javascript', 'vbscript', 'expression', 'applet', 'meta', 'xml', 'blink', 'link', 'style', 'script', 'embed', 'object', 'iframe', 'frame', 'frameset', 'ilayer', 'layer', 'bgsound', 'title', 'base');
  38. $ra2 = array('onabort', 'onactivate', 'onafterprint', 'onafterupdate', 'onbeforeactivate', 'onbeforecopy', 'onbeforecut', 'onbeforedeactivate', 'onbeforeeditfocus', 'onbeforepaste', 'onbeforeprint', 'onbeforeunload', 'onbeforeupdate', 'onblur', 'onbounce', 'oncellchange', 'onchange', 'onclick', 'oncontextmenu', 'oncontrolselect', 'oncopy', 'oncut', 'ondataavailable', 'ondatasetchanged', 'ondatasetcomplete', 'ondblclick', 'ondeactivate', 'ondrag', 'ondragend', 'ondragenter', 'ondragleave', 'ondragover', 'ondragstart', 'ondrop', 'onerror', 'onerrorupdate', 'onfilterchange', 'onfinish', 'onfocus', 'onfocusin', 'onfocusout', 'onhelp', 'onkeydown', 'onkeypress', 'onkeyup', 'onlayoutcomplete', 'onload', 'onlosecapture', 'onmousedown', 'onmouseenter', 'onmouseleave', 'onmousemove', 'onmouseout', 'onmouseover', 'onmouseup', 'onmousewheel', 'onmove', 'onmoveend', 'onmovestart', 'onpaste', 'onpropertychange', 'onreadystatechange', 'onreset', 'onresize', 'onresizeend', 'onresizestart', 'onrowenter', 'onrowexit', 'onrowsdelete', 'onrowsinserted', 'onscroll', 'onselect', 'onselectionchange', 'onselectstart', 'onstart', 'onstop', 'onsubmit', 'onunload');
  39. $ra = array_merge($ra1, $ra2);
  40. $found = true;
  41. while ($found == true) {
  42. $val_before = $val;
  43. for ($i = 0; $i < sizeof($ra); $i++) {
  44. $pattern = '/';
  45. for ($j = 0; $j < strlen($ra[$i]); $j++) {
  46. if ($j > 0) {
  47. $pattern .= '(';
  48. $pattern .= '(&#[xX]0{0,8}([9ab]);)';
  49. $pattern .= '|';
  50. $pattern .= '|(&#0{0,8}([9|10|13]);)';
  51. $pattern .= ')*';
  52. }
  53. $pattern .= $ra[$i][$j];
  54. }
  55. $pattern .= '/i';
  56. $replacement = substr($ra[$i], 0, 2) . '<x>' . substr($ra[$i], 2);
  57. $val = preg_replace($pattern, $replacement, $val);
  58. if ($val_before == $val) {
  59. $found = false;
  60. }
  61. }
  62. }
  63. if ($cfg_soft_lang == 'gb2312') utf82gb($val);
  64. return $val;
  65. }
  66. $_GET = XSSClean($_GET);
  67. $_POST = XSSClean($_POST);
  68. $_REQUEST = XSSClean($_REQUEST);
  69. $_COOKIE = XSSClean($_COOKIE);
  70. require_once(dirname(__FILE__) . '/../include/common.inc.php');
  71. require_once(DEDEINC . '/filter.inc.php');
  72. require_once(DEDEINC . '/memberlogin.class.php');
  73. require_once(DEDEINC . '/dedetemplate.class.php');
  74. // 检查CSRF
  75. function CheckCSRF()
  76. {
  77. $cc_csrf_token_check = GetCookie("dede_csrf_token");
  78. if (
  79. !(isset($_POST['_csrf_token'], $cc_csrf_token_check)
  80. && is_string($_POST['_csrf_token']) && is_string($cc_csrf_token_check)
  81. && hash_equals($_POST['_csrf_token'], $cc_csrf_token_check))
  82. ) {
  83. ShowMsg('CSRF校验失败,请刷新页面重新提交', '-1');
  84. exit();
  85. }
  86. DropCookie("dede_csrf_token");
  87. }
  88. // 生成CSRF校验token,在比较重要的表单中应该要加上这个token校验
  89. $cc_csrf_token = GetCookie("dede_csrf_token");
  90. if (!isset($GLOBALS['csrf_token']) || $GLOBALS['csrf_token'] === null) {
  91. if (
  92. isset($cc_csrf_token) && is_string($cc_csrf_token)
  93. && preg_match('#^[0-9a-f]{32}$#iS', $cc_csrf_token) === 1
  94. ) {
  95. $GLOBALS['csrf_token'] = $cc_csrf_token;
  96. } else {
  97. $GLOBALS['csrf_token'] = md5(uniqid(mt_rand(), TRUE));
  98. }
  99. }
  100. if (strtoupper($_SERVER['REQUEST_METHOD']) !== 'POST') {
  101. PutCookie('dede_csrf_token', $GLOBALS['csrf_token'], 7200, '/');
  102. }
  103. //获得当前脚本名称,如果你的系统被禁用了$_SERVER变量,请自行更改这个选项
  104. $dedeNowurl = $s_scriptName = '';
  105. $dedeNowurl = GetCurUrl();
  106. $dedeNowurls = explode('?', $dedeNowurl);
  107. $s_scriptName = $dedeNowurls[0];
  108. $menutype = '';
  109. $menutype_son = '';
  110. $gourl = empty($gourl) ? "" : RemoveXSS($gourl);
  111. //检查是否开放会员功能
  112. if ($cfg_mb_open == 'N') {
  113. if (defined('AJAXLOGIN')) {
  114. if ($format === 'json') {
  115. echo json_encode(array(
  116. "code" => -1,
  117. "msg" => "系统关闭了会员功能,因此你无法访问此页面",
  118. "data" => null,
  119. ));
  120. exit;
  121. } else {
  122. die('');
  123. }
  124. } else {
  125. ShowMsg("系统关闭了会员功能,因此你无法访问此页面!", "javascript:;");
  126. exit();
  127. }
  128. }
  129. $keeptime = isset($keeptime) && is_numeric($keeptime) ? $keeptime : -1;
  130. $cfg_ml = new MemberLogin($keeptime);
  131. //判断用户是否登录
  132. $myurl = '';
  133. if ($cfg_ml->IsLogin()) {
  134. $myurl = $cfg_memberurl . "/index.php?uid=" . urlencode($cfg_ml->M_LoginID);
  135. if (!preg_match("#^http[s]?:#i", $myurl)) $myurl = $cfg_basehost . $myurl;
  136. if ($cfg_ml->fields['face'] == "") {
  137. $cfg_ml->fields['face'] = $cfg_cmsurl . "/static/img/avatar.png";
  138. }
  139. }
  140. /** 有没新短信 **/
  141. $pms = $dsql->GetOne("SELECT COUNT(*) AS nums FROM `#@__member_pms` WHERE toid='{$cfg_ml->M_ID}' AND `hasview`=0 AND folder = 'inbox'");
  142. /**
  143. * 检查用户是否有权限进行某个操作
  144. *
  145. * @param int $rank 权限值
  146. * @param int $money 金币
  147. * @return void
  148. */
  149. function CheckRank($rank = 0, $money = 0)
  150. {
  151. global $cfg_ml, $cfg_memberurl, $cfg_mb_spacesta,$dsql;
  152. if (!$cfg_ml->IsLogin()) {
  153. header("Location:{$cfg_memberurl}/login.php?gourl=" . urlencode(GetCurUrl()));
  154. exit();
  155. } else {
  156. if ($cfg_mb_spacesta == '-10') {
  157. // var_dump($cfg_ml->fields);
  158. //如果启用注册邮件验证
  159. if ($cfg_ml->fields['spacesta'] == '-10') {
  160. if (empty($cfg_ml->fields['email'])) {
  161. ShowMsg("邮箱地址为空,请设置一个可用的邮箱地址", "edit_email.php", 0, 5000);
  162. exit;
  163. }
  164. $msg = "您尚未进行邮件验证,请到邮箱查阅...</br>重新发送邮件验证 <a href='{$cfg_memberurl}/index_do.php?fmdo=sendMail'><font color='red'>点击此处</font></a>";
  165. ShowMsg($msg, "-1", 0, 5000);
  166. exit;
  167. }
  168. }
  169. if ($cfg_ml->M_Rank < $rank) {
  170. $needname = "";
  171. if ($cfg_ml->M_Rank == 0) {
  172. $row = $dsql->GetOne("SELECT membername FROM `#@__arcrank` WHERE rank='$rank'");
  173. $myname = "普通会员";
  174. $needname = $row['membername'];
  175. } else {
  176. $dsql->SetQuery("SELECT membername From `#@__arcrank` WHERE rank='$rank' OR rank='" . $cfg_ml->M_Rank . "' ORDER BY rank DESC");
  177. $dsql->Execute();
  178. $row = $dsql->GetObject();
  179. $needname = $row->membername;
  180. if ($row = $dsql->GetObject()) {
  181. $myname = $row->membername;
  182. } else {
  183. $myname = "普通会员";
  184. }
  185. }
  186. ShowMsg("对不起,需要:<span style='font-size:11pt;color:red'>$needname</span> 才能访问本页面。<br>你目前的等级是:<span style='font-size:11pt;color:red'>$myname</span> 。", "-1", 0, 5000);
  187. exit();
  188. } else if ($cfg_ml->M_Money < $money) {
  189. ShowMsg("对不起,需要花费金币:<span style='font-size:11pt;color:red'>$money</span> 才能访问本页面。<br>你目前拥有的金币是:<span style='font-size:11pt;color:red'>" . $cfg_ml->M_Money . "</span> 。", "-1", 0, 5000);
  190. exit();
  191. }
  192. }
  193. }
  194. /**
  195. * 更新文档统计
  196. *
  197. * @access public
  198. * @param int $channelid 频道模型id
  199. * @return string
  200. */
  201. function countArchives($channelid)
  202. {
  203. global $cfg_ml, $dsql;
  204. $id = (int)$channelid;
  205. if ($cfg_ml->IsLogin()) {
  206. $channeltype = array(1 => 'article', 2 => 'album', 3 => 'soft', -8 => 'infos');
  207. if (isset($channeltype[$id])) {
  208. $_field = $channeltype[$id];
  209. } else {
  210. $_field = 'articles';
  211. }
  212. $row = $dsql->GetOne("SELECT COUNT(*) AS nums FROM #@__archives WHERE channel='$id' AND mid='" . $cfg_ml->M_ID . "'");
  213. $dsql->ExecuteNoneQuery("UPDATE #@__member_tj SET " . $_field . "='" . $row['nums'] . "' WHERE mid='" . $cfg_ml->M_ID . "'");
  214. } else {
  215. return FALSE;
  216. }
  217. }