| 添加到收藏夹 | 返回目录页 | 上一篇:PHP和XSS跨站攻击 |
Discuz论坛2.5 升级到PHP MySQL新版遇到的问题
1 中文问题,在使用MySQL实例配置工具的使用,将使用的字符集设置为GBK,而不要设置为UTF-8
2 MySQL安装后密码无法访问问题:
mysql> SET PASSWORD FOR
-> @#some_user@#@@#some_host@# = OLD_PASSWORD(@#newpwd@#);
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;
}
}
- · PHP调用java类常见配置错误
- · PHP中的MD5加密
- · PHP能得到你是从什么页面过来的,referer的用处
- · AJAX技术在PHP开发中的简单应用
- · PHP中路径问题的解决方案
- · PHP+MySQL分页显示示例分析
- · 教你如何用PHP制作静态网站的模板框架
- · PHP实现网页自动更新块
- · PHP与SQL注入攻击
- · 如何使用php开发高效的WEB系统
- · 用php生成EAN_13标准的条形码
- · PHP 的配置详细选项
- · SmartTemplate(适用于企业级PHP开发的模板引擎)
- · 用PHP写的QQ Client,可以登陆、登出、收发消息、添加好友
- · [PHP]关于时间计算的结总
- · 用PHP实现文件下载
- · linux下用php连接sqlserver解决办法
- · 下拉透明菜单
- · 收集的精典代码
- · 关于PHP的分页代码
- · 一家之言的经验之谈php+mysql扎实个人基本功
- · 用PHP写FTP文件上传
- · 用PHP写的MD5加密函数
- · 在php中输出html代码
- · php的pconnect()
- · PHP/ASP上传漏洞探究
- · 做个站内搜索引擎
- · heapsort(PHP)
- · 一个塑料期货交易程序分析图程序(PHP+JAVA)
- · 计算排列组合的php代码
- · 对页面的源代码进行加密,使源代码变成乱码,没法读取
- · 用phpUnit帮你调试php程序
- · PHP下对缓冲区的控制
- · PHP实现文件下载
- · 用PHP实现windows资源管理器风格的树型菜单
- · BS结构中使用PHP访问ORACLE LOB
- · 使用PHP 5.0 轻松解析XML文档(5)
- · 使用PHP 5.0 轻松解析XML文档(3)
- · 使用PHP 5.0 轻松解析XML文档(1)
- · PHP中实现面向对象编程(上)
- · PHP中接收复选框信息的方法
- · PHP操作IMAP服务器的类
- · PHP中时间和日期函数总结
- · PHP应用分页显示制作详细讲解(2)
- · PHP5中使用Web服务访问J2EE应用程序(4)

