国内流行的内容管理系统(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.

261 lines
11KB

  1. <?php
  2. /**
  3. * @version $id:config.php 8:38 2010年7月9日 tianya $
  4. * @package DedeBIZ.User
  5. * @copyright Copyright (c) 2022 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','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__).'/../system/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. function PmRead(){
  133. global $dsql,$cfg_ml;
  134. $query = "SELECT * FROM `#@__member_pms` WHERE folder LIKE 'outbox' AND isadmin='1'";
  135. $dsql->SetQuery($query);
  136. $dsql->Execute();
  137. while ($row = $dsql->GetArray()) {
  138. $row2 = $dsql->GetOne("SELECT * FROM `#@__member_pms` WHERE fromid = '$row[id]' AND toid='{$cfg_ml->M_ID}'");
  139. if (!is_array($row2)) {
  140. $row3 = "INSERT INTO `#@__member_pms` (`floginid`,`fromid`,`toid`,`tologinid`,`folder`,`subject`,`sendtime`,`writetime`,`hasview`,`isadmin`,`message`) VALUES ('admin','{$row['id']}','{$cfg_ml->M_ID}','{$cfg_ml->M_LoginID}','inbox','{$row['subject']}','{$row['sendtime']}','{$row['writetime']}','{$row['hasview']}','{$row['isadmin']}','{$row['message']}')";
  141. $dsql->ExecuteNoneQuery($row3);
  142. }
  143. }
  144. }
  145. //判断用户是否登录
  146. $myurl = '';
  147. if ($cfg_ml->IsLogin()) {
  148. $myurl = $cfg_memberurl."/index.php?uid=".urlencode($cfg_ml->M_LoginID);
  149. if (!preg_match("#^http[s]?:#i", $myurl)) $myurl = $cfg_basehost.$myurl;
  150. if ($cfg_ml->fields['face'] == "") {
  151. $cfg_ml->fields['face'] = $cfg_cmsurl."../static/web/img/avatar.png";
  152. }
  153. PmRead();
  154. }
  155. //有没新短信
  156. $pms = $dsql->GetOne("SELECT COUNT(*) AS nums FROM `#@__member_pms` WHERE toid='{$cfg_ml->M_ID}' AND `hasview`=0 AND folder = 'inbox'");
  157. /**
  158. * 检查用户是否有权限进行某个操作
  159. *
  160. * @param int $rank 权限值
  161. * @param int $money 金币
  162. * @return void
  163. */
  164. function CheckRank($rank = 0, $money = 0)
  165. {
  166. global $cfg_ml, $cfg_memberurl, $cfg_mb_spacesta,$dsql;
  167. if (!$cfg_ml->IsLogin()) {
  168. header("Location:{$cfg_memberurl}/login.php?gourl=".urlencode(GetCurUrl()));
  169. exit();
  170. } else {
  171. if ($cfg_mb_spacesta == '-10') {
  172. //var_dump($cfg_ml->fields);
  173. //如果启用注册邮件验证
  174. if ($cfg_ml->fields['spacesta'] == '-10') {
  175. if (empty($cfg_ml->fields['email'])) {
  176. ShowMsg("邮箱地址为空,请设置一个可用的邮箱地址", "edit_email.php", 0, 5000);
  177. exit;
  178. }
  179. $msg = "您尚未进行邮件验证,请到邮箱查阅</br>重新发送邮件验证 <a href='{$cfg_memberurl}/index_do.php?fmdo=sendMail'><span class='text-danger'>点击此处</span></a>";
  180. ShowMsg($msg, "-1", 0, 5000);
  181. exit;
  182. }
  183. }
  184. if ($cfg_ml->M_Rank < $rank) {
  185. $needname = "";
  186. if ($cfg_ml->M_Rank == 0) {
  187. $row = $dsql->GetOne("SELECT membername FROM `#@__arcrank` WHERE `rank`='$rank'");
  188. $myname = "普通会员";
  189. $needname = $row['membername'];
  190. } else {
  191. $dsql->SetQuery("SELECT membername From `#@__arcrank` WHERE `rank`='$rank' OR `rank`='".$cfg_ml->M_Rank."' ORDER BY `rank` DESC");
  192. $dsql->Execute();
  193. $row = $dsql->GetObject();
  194. $needname = $row->membername;
  195. if ($row = $dsql->GetObject()) {
  196. $myname = $row->membername;
  197. } else {
  198. $myname = "普通会员";
  199. }
  200. }
  201. ShowMsg("对不起,需要:<span class='text-danger'>$needname</span> 才能访问本页面<br>您目前的等级是:<span class='text-danger'>$myname</span> ", "-1", 0, 5000);
  202. exit();
  203. } else if ($cfg_ml->M_Money < $money) {
  204. ShowMsg("对不起,需要花费金币:<span class='text-danger'>$money</span> 才能访问本页面<br>您目前拥有的金币是:<span class='text-danger'>".$cfg_ml->M_Money."</span> ", "-1", 0, 5000);
  205. exit();
  206. }
  207. }
  208. }
  209. /**
  210. * 更新文档统计
  211. *
  212. * @access public
  213. * @param int $channelid 栏目模型id
  214. * @return string
  215. */
  216. function countArchives($channelid)
  217. {
  218. global $cfg_ml, $dsql;
  219. $id = (int)$channelid;
  220. if ($cfg_ml->IsLogin()) {
  221. $channeltype = array(1 => 'article', 2 => 'album', 3 => 'soft', -8 => 'infos');
  222. if (isset($channeltype[$id])) {
  223. $_field = $channeltype[$id];
  224. } else {
  225. $_field = 'articles';
  226. }
  227. $row = $dsql->GetOne("SELECT COUNT(*) AS nums FROM `#@__archives` WHERE channel='$id' AND mid='".$cfg_ml->M_ID."'");
  228. $dsql->ExecuteNoneQuery("UPDATE `#@__member_tj` SET ".$_field."='".$row['nums']."' WHERE mid='".$cfg_ml->M_ID."'");
  229. } else {
  230. return FALSE;
  231. }
  232. }
  233. //安全提示问题,这两句不要修改
  234. $safequestions = array();
  235. $safequestions[0] = '没安全提示问题';
  236. //下面的设置可以手工修改
  237. $safequestions[1] = '您最喜欢的格言什么';
  238. $safequestions[2] = '您家乡的名称是什么';
  239. $safequestions[3] = '您读的小学叫什么';
  240. $safequestions[4] = '您的父亲叫什么名字';
  241. $safequestions[5] = '您的母亲叫什么名字';
  242. $safequestions[6] = '您最喜欢的偶像是谁';
  243. $safequestions[7] = '您最喜欢的歌曲是什么';
  244. //以下不要修改
  245. function GetSafequestion($selid=0,$formname='safequestion')
  246. {
  247. global $safequestions;
  248. $safequestions_form = "<select class='form-control' name='$formname' id='$formname'>";
  249. foreach($safequestions as $k=>$v)
  250. {
  251. if ($k==$selid) $safequestions_form .= "<option value='$k' selected>$v</option>\r\n";
  252. else $safequestions_form .= "<option value='$k'>$v</option>\r\n";
  253. }
  254. $safequestions_form .= "</select>\r\n";
  255. return $safequestions_form;
  256. }
  257. $enabledChannels = MemberLogin::GetEnabledChannels();
  258. ?>