ini配置文件都是默认的(应该是,不记得有改过)
求帮助,没一点头绪
你认真看一下错误信息中给出的文件和错误行行
你认真看一下错误信息中给出的文件和错误行行
session_start(); 前面不能有输出,将 echo ... 那一行注释掉看看。
session_start(); 前面不能有输出,将 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)";
第三个没给,自动有默认值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语句的第三个参数没给,所以没成功