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语句的第三个参数没给,所以没成功