欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

[请教]session入库在5.2出错,5.5正常是为什么呢

程序员文章站 2022-05-14 11:49:01
...
ini配置文件都是默认的(应该是,不记得有改过)
求帮助,没一点头绪


回复讨论(解决方案)

你认真看一下错误信息中给出的文件和错误行行

你认真看一下错误信息中给出的文件和错误行行




limiter这个看不懂
好像是cookie头已经发送(不大清楚说的是客户端发服务端,还是相反)

我把所有的echo都去掉,没错误提示了,但是数据并没有入库

session_start(); 前面不能有输出,将 echo ... 那一行注释掉看看。

session_start(); 前面不能有输出,将 echo ... 那一行注释掉看看。


echo注释了,没有任何提示,数据库中没有进去数据,说明操作没有成功,又没有错误提示,我去

没人能解决么,哎

贴出你的代码(不要截图!)

被导入文件userSession.php

/**
* Created by PhpStorm.
* User: Admin_BIN
* Date: 2015/12/2
* Time: 14:03
*/
function userSessionBegin(){
echo "
Begin
";
}
function userSessionEnd(){
echo "
End
";
}
/**
* 读操作
* 执行时机:session机制开启过程中执行
* 工作:从当前session数据区读取内容
* @param $sess_id string
* @return string
* */
function userSessionRead($sess_id){
echo "
Read
";
//初始化数据库服务器连接
$link=mysqli_connect("localhost","root","root","matchsys");
mysqli_query($link,"set names utf8");
//查询
$sql="select session_content from `session` where session_id='$sess_id'";
$result=mysqli_query($link,$sql);
if($row=mysqli_fetch_assoc($result)){
return $row["session_content"];
}else{
//没有找到,返回空字符串
return "";
}
}
/**
* 写操作
* 执行时机:脚本周期结束时,PHP在整理收尾时
* 工作:将当前脚本处理好的session数据,持久化到数据库中!
* @param $sess_id string
* @param $sess_content string 序列化好的session内容字符串
* @return bool
* */
function userSessionWrite($sess_id,$sess_content){
echo "
Write
";
//初始化数据库服务器连接
$link=mysqli_connect("localhost","root","root","matchsys");
mysqli_query($link,"set names utf8");
//写
$sql="replace into `session` values('$sess_id','$sess_content')";
//$sql="insert into `session` values('$sess_id','$sess_content') on duplicate key update session_content='$sess_content',last_time=unix_timestamp()";
return mysqli_query($link,$sql);
}
/*
* 删除操作
* 执行时机:调用了session_destory()销毁session过程中被调用
* 工作:删除当前session的数据区(记录)
* @param $sess_id string
* @return bool
* */
function userSessionDelete(){
echo "
Delete
";
//初始化数据库服务器连接
$link=mysqli_connect("localhost","root","root","matchsys");
mysqli_query($link,"set names utf8");
//删除
$sql="delete from `session` where session_id='$sess_id'";
return mysqli_query($link,$sql);
}
function userSessionGC(){
echo "
GC
";
}
//设置
session_set_save_handler("userSessionBegin","userSessionEnd","userSessionRead",
"userSessionWrite","userSessionDelete","userSessionGC");

main文件session_3.php

/**
* Created by PhpStorm.
* User: Admin_BIN
* Date: 2015/12/2
* Time: 15:12
*/
require "./userSession.php";
session_start();
$_SESSION["class_name"]="PHP";
$_SESSION["teacher_name"]="KANG";

数据库sql
create database matchSys charset utf8;
use matchSys;
create table `session` (
session_id varchar(40) not null default '',
session_content text,
last_time int not null default 0,
primary key(session_id)
)charset=utf8 engine=myisam;

万分感谢!!!

提示不是这个意思啊,我试着加个数据库选择mysqli_select_db($link,'matchSys');
还是一样的,说明不是这个原因

Column count doesn't match value count at row 1
列计数不匹配值计数排1

$sql="replace into `session` values('$sess_id','$sess_content')";
表有 3 列,你只插入了两列

$time = time();
$sql="replace into `session` values('$sess_id','$sess_content', $time)";

Column count doesn't match value count at row 1
列计数不匹配值计数排1

$sql="replace into `session` values('$sess_id','$sess_content')";
表有 3 列,你只插入了两列

$time = time();
$sql="replace into `session` values('$sess_id','$sess_content', $time)";


那个错误提示和这个无关啊,就算加个default也可以过的,我确实是插两个值,第三个给默认插进去了

第三个没给,自动有默认值0

Column count doesn't match value count at row 1
就报这个错!

你非要看不见,我也没办法

表数据列和所给值不匹配,这个错误很常见,给个default就过了,或者给个值就过了

不要自欺欺人了!
你的表有 session_id、session_content、last_time 三列
你的插入指令是 $sql="replace into `session` values('$sess_id','$sess_content')";
你说缺省的该是哪列?

给个default就过了,但需要有非缺省字段列表
或者给个值就过了,你并没有给

缺的是last_time,就是最后一列,就是在最后一个上给上default,或者一个数值
前面写是没有的,后来输入这个值的时候给的是一个函数unix_timestamp(),

但是值确是0,所以我去掉了,一个问题还没解决,多一个问题只会使问题复杂化

echo注释了,没有任何提示,数据库中没有进去数据,说明操作没有成功,又没有错误提示,我去


你不是说没有插进去吗?
所以让你贴代码的

都插进去了,那还能有什么问题?

前面就说了5.2不行,5.5可以的,我想知道的就是5.2为什么不可以

你把 userSessionWrite 中的
return mysqli_query($link,$sql);
改成
mysqli_query($link,$sql) or die(mysqli_error($link));
就知道了

我说的都是经过实测的,并非之上谈兵
php 5.4 都是 Column count doesn't match value count at row 1

就是这个错误
Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent (output started at D:\project\myCode\mystate\php\czbk\work2015.05\core\0.core\day20\3.Session\userSession.php:9) in D:\project\myCode\mystate\php\czbk\work2015.05\core\0.core\day20\3.Session\session_3.php on line 12

你不是把 echo "
Begin
"; 注释掉了吗?
怎么还在?

有可能是起先去掉了echo,但是插入sql语句的第三个参数没给,所以没成功