• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

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

发布: 2007-7-01 15:06 | 作者: admin | 来源: | 查看: 20次 | 进入软件测试论坛讨论

领测软件测试网

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;
 }
}

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网