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

262 lines
11KB

  1. <?php
  2. /**
  3. * 会员配置
  4. *
  5. * @version $id:config.php 8:38 2010年7月9日 tianya $
  6. * @package DedeBIZ.User
  7. * @copyright Copyright (c) 2022 DedeBIZ.COM
  8. * @license https://www.dedebiz.com/license
  9. * @link https://www.dedebiz.com
  10. */
  11. //针对会员中心操作进行XSS过滤
  12. function XSSClean($val)
  13. {
  14. global $cfg_soft_lang;
  15. if ($cfg_soft_lang == 'gb2312') gb2utf8($val);
  16. if (is_array($val)) {
  17. foreach ($val as $key => $value) {
  18. if (in_array($key, array('tags', 'body', 'dede_fields', 'dede_addonfields', 'dopost', 'introduce'))) continue;
  19. $val[$key] = XSSClean($val[$key]);
  20. }
  21. return $val;
  22. }
  23. $val = preg_replace('/([\x00-\x08,\x0b-\x0c,\x0e-\x19])/','', $val);
  24. $search = 'abcdefghijklmnopqrstuvwxyz';
  25. $search .= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
  26. $search .= '1234567890!@#$%^&*()';
  27. $search .= '~`";:?+/={}[]-_|\'\\';
  28. for ($i = 0; $i < strlen($search); $i++) {
  29. $val = preg_replace('/(&#[xX]0{0,8}'.dechex(ord($search[$i])).';?)/i', $search[$i], $val); //with a ;
  30. $val = preg_replace('/(&#0{0,8}'.ord($search[$i]).';?)/', $search[$i], $val); //with a ;
  31. }
  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. $val = str_replace(")", ")", $val);
  38. $ra1 = array('javascript','vbscript','expression','applet','meta','xml','blink','link','style','script','embed','object','iframe','frame','frameset','ilayer','layer','bgsound','title','base');
  39. $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');
  40. $ra = array_merge($ra1, $ra2);
  41. $found = true;
  42. while ($found == true) {
  43. $val_before = $val;
  44. for ($i = 0; $i < sizeof($ra); $i++) {
  45. $pattern = '/';
  46. for ($j = 0; $j < strlen($ra[$i]); $j++) {
  47. if ($j > 0) {
  48. $pattern .= '(';
  49. $pattern .= '(&#[xX]0{0,8}([9ab]);)';
  50. $pattern .= '|';
  51. $pattern .= '|(&#0{0,8}([9|10|13]);)';
  52. $pattern .= ')*';
  53. }
  54. $pattern .= $ra[$i][$j];
  55. }
  56. $pattern .= '/i';
  57. $replacement = substr($ra[$i], 0, 2).'<x>'.substr($ra[$i], 2);
  58. $val = preg_replace($pattern, $replacement, $val);
  59. if ($val_before == $val) {
  60. $found = false;
  61. }
  62. }
  63. }
  64. if ($cfg_soft_lang == 'gb2312') utf82gb($val);
  65. return $val;
  66. }
  67. $_GET = XSSClean($_GET);
  68. $_POST = XSSClean($_POST);
  69. $_REQUEST = XSSClean($_REQUEST);
  70. $_COOKIE = XSSClean($_COOKIE);
  71. require_once(dirname(__FILE__).'/../system/common.inc.php');
  72. require_once(DEDEINC.'/filter.inc.php');
  73. require_once(DEDEINC.'/memberlogin.class.php');
  74. require_once(DEDEINC.'/dedetemplate.class.php');
  75. //检查CSRF
  76. function CheckCSRF()
  77. {
  78. $cc_csrf_token_check = GetCookie("dede_csrf_token");
  79. if (
  80. !(isset($_POST['_csrf_token'], $cc_csrf_token_check) && is_string($_POST['_csrf_token']) && is_string($cc_csrf_token_check) && hash_equals($_POST['_csrf_token'], $cc_csrf_token_check))
  81. ) {
  82. ShowMsg('刷新页面重新提交,请不要发布重复文档', '-1');
  83. exit();
  84. }
  85. DropCookie("dede_csrf_token");
  86. }
  87. //生成CSRF校验token,在比较重要的表单中应该要加上这个token校验
  88. $cc_csrf_token = GetCookie("dede_csrf_token");
  89. if (!isset($GLOBALS['csrf_token']) || $GLOBALS['csrf_token'] === null) {
  90. if (
  91. isset($cc_csrf_token) && is_string($cc_csrf_token)
  92. && preg_match('#^[0-9a-f]{32}$#iS', $cc_csrf_token) === 1
  93. ) {
  94. $GLOBALS['csrf_token'] = $cc_csrf_token;
  95. } else {
  96. $GLOBALS['csrf_token'] = md5(uniqid(mt_rand(), TRUE));
  97. }
  98. }
  99. if (strtoupper($_SERVER['REQUEST_METHOD']) !== 'POST') {
  100. PutCookie('dede_csrf_token', $GLOBALS['csrf_token'], 7200, '/');
  101. }
  102. //获得当前脚本名称,如果您的系统被禁用了$_SERVER变量,请自行修改这个选项
  103. $dedeNowurl = $s_scriptName = '';
  104. $dedeNowurl = GetCurUrl();
  105. $dedeNowurls = explode('?', $dedeNowurl);
  106. $s_scriptName = $dedeNowurls[0];
  107. $menutype = '';
  108. $menutype_son = '';
  109. $gourl = empty($gourl) ? "" : RemoveXSS($gourl);
  110. //检查是否开放会员功能
  111. if ($cfg_mb_open == 'N') {
  112. if (defined('AJAXLOGIN')) {
  113. if ($format === 'json') {
  114. echo json_encode(array(
  115. "code" => -1,
  116. "msg" => "网站关闭了会员功能,您无法浏览此页面",
  117. "data" => null,
  118. ));
  119. exit;
  120. } else {
  121. die('');
  122. }
  123. } else {
  124. ShowMsg("网站关闭了会员功能,您无法浏览此页面", "javascript:;");
  125. exit();
  126. }
  127. }
  128. $keeptime = isset($keeptime) && is_numeric($keeptime) ? $keeptime : -1;
  129. $cfg_ml = new MemberLogin($keeptime);
  130. //检查收件箱
  131. function PmRead(){
  132. global $dsql, $cfg_ml;
  133. $query = "SELECT * FROM `#@__member_pms` WHERE folder LIKE 'outbox' AND isadmin='1'";
  134. $dsql->SetQuery($query);
  135. $dsql->Execute();
  136. while ($row = $dsql->GetArray()) {
  137. $row2 = $dsql->GetOne("SELECT * FROM `#@__member_pms` WHERE fromid = '$row[id]' AND toid='{$cfg_ml->M_ID}'");
  138. if (!is_array($row2)) {
  139. $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']}')";
  140. $dsql->ExecuteNoneQuery($row3);
  141. }
  142. }
  143. }
  144. //判断会员是否登录
  145. $myurl = '';
  146. if ($cfg_ml->IsLogin()) {
  147. $myurl = $cfg_memberurl."/index.php?uid=".urlencode($cfg_ml->M_LoginID);
  148. if (!preg_match("#^http[s]?:#i", $myurl)) $myurl = $cfg_basehost.$myurl;
  149. if ($cfg_ml->fields['face'] == "") {
  150. $cfg_ml->fields['face'] = $cfg_cmsurl."/static/web/img/admin.png";
  151. }
  152. PmRead();
  153. }
  154. //有没新短信
  155. $pms = $dsql->GetOne("SELECT COUNT(*) AS nums FROM `#@__member_pms` WHERE toid='{$cfg_ml->M_ID}' AND `hasview`=0 AND folder = 'inbox'");
  156. /**
  157. * 检查会员是否有权限进行某个操作
  158. *
  159. * @param int $rank 权限值
  160. * @param int $money 金币
  161. * @return void
  162. */
  163. function CheckRank($rank = 0, $money = 0)
  164. {
  165. global $cfg_ml, $cfg_memberurl, $cfg_mb_spacesta,$dsql;
  166. if (!$cfg_ml->IsLogin()) {
  167. header("Location:{$cfg_memberurl}/login.php?gourl=".urlencode(GetCurUrl()));
  168. exit();
  169. } else {
  170. if ($cfg_mb_spacesta == '-10') {
  171. //var_dump($cfg_ml->fields);
  172. //如果启用注册邮件验证
  173. if ($cfg_ml->fields['spacesta'] == '-10' && !preg_match("#edit_baseinfo.php$#", GetCurUrl())) {
  174. if (empty($cfg_ml->fields['email'])) {
  175. ShowMsg("邮箱地址为空,请设置一个邮箱地址", "edit_baseinfo.php", 0, 5000);
  176. exit;
  177. }
  178. $msg = "您未进行邮件验证,发送验证邮件后请登录邮箱进行确认</br>发送验证邮件请点击<a href='{$cfg_memberurl}/index_do.php?fmdo=sendMail' class='btn btn-success'>发送</a>,或者点击<a href='javascript:history.go(-1)'>返回</a>取消当前操作";
  179. ShowMsg($msg, "javascript:;", 0, 5000);
  180. exit;
  181. }
  182. }
  183. if ($cfg_ml->M_Rank < $rank) {
  184. $needname = "";
  185. if ($cfg_ml->M_Rank == 0) {
  186. $row = $dsql->GetOne("SELECT membername FROM `#@__arcrank` WHERE `rank`='$rank'");
  187. $myname = "注册会员";
  188. $needname = $row['membername'];
  189. } else {
  190. $dsql->SetQuery("SELECT membername From `#@__arcrank` WHERE `rank`='$rank' OR `rank`='".$cfg_ml->M_Rank."' ORDER BY `rank` DESC");
  191. $dsql->Execute();
  192. $row = $dsql->GetObject();
  193. $needname = $row->membername;
  194. if ($row = $dsql->GetObject()) {
  195. $myname = $row->membername;
  196. } else {
  197. $myname = "注册会员";
  198. }
  199. }
  200. ShowMsg("需要<span class='text-primary'>$needname</span>才能浏览本页面<br>您目前等级是<span class='text-primary'>$myname</span>", "-1", 0, 5000);
  201. exit();
  202. } else if ($cfg_ml->M_Money < $money) {
  203. ShowMsg("需要<span class='text-primary'>$money</span>金币才能浏览本页面<br>您目前金币<span class='text-primary'>".$cfg_ml->M_Money."</span>个", "-1", 0, 5000);
  204. exit();
  205. }
  206. }
  207. }
  208. /**
  209. * 更新文档统计
  210. *
  211. * @access public
  212. * @param int $channelid 栏目模型id
  213. * @return string
  214. */
  215. function countArchives($channelid)
  216. {
  217. global $cfg_ml, $dsql;
  218. $id = (int)$channelid;
  219. if ($cfg_ml->IsLogin()) {
  220. $channeltype = array(1 => 'article', 2 => 'album', 3 => 'soft', -8 => 'infos');
  221. if (isset($channeltype[$id])) {
  222. $_field = $channeltype[$id];
  223. } else {
  224. $_field = 'articles';
  225. }
  226. $row = $dsql->GetOne("SELECT COUNT(*) AS nums FROM `#@__archives` WHERE channel='$id' AND mid='".$cfg_ml->M_ID."'");
  227. $dsql->ExecuteNoneQuery("UPDATE `#@__member_tj` SET ".$_field."='".$row['nums']."' WHERE mid='".$cfg_ml->M_ID."'");
  228. } else {
  229. return FALSE;
  230. }
  231. }
  232. //安全提示问题,这两句不要修改
  233. $safequestions = array();
  234. $safequestions[0] = '没安全提示问题';
  235. //下面的设置可以手工修改
  236. $safequestions[1] = '您最喜欢的格言什么';
  237. $safequestions[2] = '您家乡的名称是什么';
  238. $safequestions[3] = '您读的小学叫什么';
  239. $safequestions[4] = '您的父亲叫什么名字';
  240. $safequestions[5] = '您的母亲叫什么名字';
  241. $safequestions[6] = '您最喜欢的偶像是谁';
  242. $safequestions[7] = '您最喜欢的歌曲是什么';
  243. //以下不要修改
  244. function GetSafequestion($selid=0,$formname='safequestion')
  245. {
  246. global $safequestions;
  247. $safequestions_form = "<select name='$formname' id='$formname' class='form-control'>";
  248. foreach($safequestions as $k=>$v)
  249. {
  250. if ($k==$selid) $safequestions_form .= "<option value='$k' selected>$v</option>\r\n";
  251. else $safequestions_form .= "<option value='$k'>$v</option>\r\n";
  252. }
  253. $safequestions_form .= "</select>\r\n";
  254. return $safequestions_form;
  255. }
  256. $enabledChannels = MemberLogin::GetEnabledChannels();
  257. function UserInclude($file)
  258. {
  259. return DEDEMEMBER.'/'.$file;
  260. }
  261. ?>