[请教]session入库在5.2出错,5.5正常是为什么呢
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语句的第三个参数没给,所以没成功

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Alipay PHP ...

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> 'Hello World', 'github.com'=> [ 'foo'=> 'bar'], 'forge.laravel.com'=>

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

기사는 PHP 5.3에 도입 된 PHP의 LSB (Late STATIC BING)에 대해 논의하여 정적 방법의 런타임 해상도가보다 유연한 상속을 요구할 수있게한다. LSB의 실제 응용 프로그램 및 잠재적 성능

기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,
