• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Discuz论坛2.5 升级到PHP MySQL新版遇到的问题_PHP

php 搞代码 3年前 (2022-01-25) 14次浏览 已收录 0个评论

1 中文问题,在使用MySQL实例配置工具的使用,将使用的字符集设置为GBK,而不要设置为UTF-8

2 MySQL安装后密码无法访问问题:

mysql> SET PASSWORD FOR
-> ‘some_user’@’some_host’ = OLD_PASSWORD(‘newp本文@来#源gaodai$ma#com搞$$代**码网搞代gaodaima码wd’);

3 PHP有Warning

在php.ini里面找到
bug_combat_warning = 1 两行,1 改成 0

4 MySQL 对SQL插入实行更强的格式检查.所以如果某个列是整数,就不能使用''来插入.因此修改Discuz的一个函数如下

function updatesession() {
if(empty($GLOBALS[‘sessionupdated’])) {
global $db, $sessionexists, $sessionupdated, $sid, $onlineip, $discuz_uid, $discuz_user, $timestamp, $groupid, $styleid, $invisible, $discuz_action, $fid, $tid, $onlinehold, $logincredits, $table_sessions, $table_members, $user_lastactivity, $onlinehold;

if($sessionexists == 1) {
$db->query(“UPDATE $table_sessions SET uid=’$discuz_uid’, username=’$discuz_user’, groupid=’$groupid’, styleid=’$styleid’, invisible='” . ($invisible==””?0:1) . “‘, action=’$discuz_action’, lastactivity=’$timestamp’, fid='” . ($fid==””?0:1) . “‘, tid='” . ($tid==””?0:1) . “‘ WHERE sid=’$sid'”);
if ($onlinehold && $user_lastactivity && $timestamp – $user_lastactivity > $onlinehold) {
$db->query(“UPDATE $table_members SET lastvisit=lastactivity, lastactivity=$timestamp WHERE uid=’$discuz_uid'”, ‘UNBUFFERED’);
}
} else {
$ips = explode(‘.’, $onlineip);

$db->query(“DELETE FROM $table_sessions WHERE sid=’$sid’ OR lastactivity<($timestamp-$onlinehold) OR ('$discuz_uid'’0′ AND uid=’$discuz_uid’) OR (uid=’0′ AND ip1=’$ips[0]’ AND ip2=’$ips[1]’ AND ip3=’$ips[2]’ AND ip4=’$ips[3]’ AND lastactivity>$timestamp-60)”);
$db->query(“INSERT INTO $table_sessions (sid, ip1, ip2, ip3, ip4, uid, username, groupid, styleid, invisible, action, lastactivity, fid, tid)
VALUES (‘$sid’, ‘$ips[0]’, ‘$ips[1]’, ‘$ips[2]’, ‘$ips[3]’, ‘$discuz_uid’, ‘$discuz_user’, ‘$groupid’, ‘$styleid’, ‘” . ($invisible==””?0:1) . “‘, ‘$discuz_action’, ‘$timestamp’, ‘” . ($fid==””?0:1) . “‘, ‘” . ($tid==””?0:1) . “‘)”);
if($discuz_uid) {
$db->query(“UPDATE $table_members SET credit=credit “.intval($logincredits).”, lastip=’$onlineip’, lastvisit=lastactivity, lastactivity=$timestamp WHERE uid=’$discuz_uid'”, ‘UNBUFFERED’);
}
}
$sessionupdated = 1;
}
}


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Discuz论坛2.5 升级到PHP MySQL新版遇到的问题_PHP
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址