php中session引起错误问题集锦与解决办法
php中session经常会出现一些很奇怪的问题,这些问题很多都是小细节的事情,对于php 初学者来说可能很难发现是什么原因,今天我们把几乎所有的session引起或出现的问题收集在一起,一一给出了解决方案,有需要的同学看看哦,如果有更好的朋友可提供给我。
1>错误提示
代码如下 | 复制代码 |
Warning: Cannot send session cookie - headers already sent Warning: Cannot send session cache limiter - headers already sent |
问题的原因是在程序中使用session_start()时,之前已经有实际的html内容输出了。即使是echo或print一条消息了,echo或print语句所产生的输出,就是实际的html内容输出。解决此类问题的办法是,将session_start()调到程序的第一行。
2>错误提示
代码如下 | 复制代码 |
Warning: open(F:/webphpsessiondatasess_76666aecf239891edc98b5, O_RDWR) failed |
出现这样的错误语句一般是因为你的php.ini中关于session.save_path一项没有设置好,解决的方法是将
代码如下 | 复制代码 |
session.save_path和session.cookie_path 设置置为 session_save_path = c:temp session.cookie_path = c:temp |
然后在c:目录下建立一个temp目录,即可
3>
代码如下 | 复制代码 |
错误提示 Warning: Trying to destroy uninitialized session in |
出类这样的提示,一般情况都是你直接调session_destroy()函数造成的。很多的朋友认为session_destroy()函数可以独立的运行,其实不然。解决的方法是在你调session_destroy()函数之前,要用session_start()开启session的功能。
4>怎么获得当前session的id值呢?
最简单的方法是:
代码如下 | 复制代码 |
echo SID; |
5>在调用header函数之前没有任何的输出,虽然我include了一个config.php文件,但在config.php文件中也没有任何的输出,为什么session还是会报出与问题1同样的错误呢,是不是因为我在header之前用了session_start()的缘故呢?
认真的检查了你的php程序,在引用header()之前确实也没有任何的输出,并且在你的include文件中也没有任何的输出!
但是你是否用光标键在?>这个PHP代码结束语句后移动检查呢?那么你会发现在?>这个后面,有一个空行或几个空格,你删除了这几个空行或空格,那么问题就解决了。
注:此问题,会出现在PHP4.1.2中。
6>用session做登录主页面后,其它页面怎么用session限制登录。。。
解决的方法:
代码如下 | 复制代码 |
session_start(); if(!session_registered(’login’) ││ login != true) { echo “你没有登陆”; exit; } |
7>用session_register()注册了session变量,可是当用header或用javascript的重定向语句,那么在一下页面中,却访问不到session所注册的变量值。
问题的程序片段:
代码如下 | 复制代码 |
session_start(); $ok = ‘love you’; session_register($ok); header(”location : next.php”); ?> next.php session_start(); echo $ok; ?> |
解决的方法:
当你用header函数或window.location这样的功能后,你上一个页面所注册的session变量,就会容易的丢失。
解决的方法。
代码如下 | 复制代码 |
header(”Location: next.php” .”?” . SID); |
在跳转到下一页面的时候,将session的当前id做为一个参数,传到后一个页面。
8>session如何传数组
代码如下 | 复制代码 |
session_register(’data’;); data=array(1,2,3,4); |
方法是先注册后赋值
9>可以用像 HTTP_GET_VARS['**']方式来访问session值呢?
回答:可以,你可以使用如下global数组来访问session,以加强网页的安全性
HTTP_SESSION_VARS_SESSION
例程:
代码如下 | 复制代码 |
session_start(); $username = ‘;stangly.wrong’;; session_register(’;username’;); echo $HTTP_SESSION_VARS['username']; echo ‘; ’;; echo _SESSION['username']; ?> 10> |
session_unregister() 和 session_destroy() 有何区别?
session_unregister()函数主要作用是注消当前的一个session变量。不过要注意的是,如果你用HTTP_SESSION_VARS或_SESSION在当前页面中引用过session变量,那么你可能需要和unset()配合 来注消session变量。
而session_destroy()是清除当前的session环境。意思就是说,当你用session_destroy()函数后,那么你就不可能再用session_is_registered()来检测session的变量了。但是需要注意的是他不能清除global中的session或使用了session cookie的中的session.所以在用session_destroy之前,最好不要用HTTP_SESSION_VARS _SESSION来访问session.
例程:
代码如下 | 复制代码 |
if(isset(_COOKIE[session_name()])) { session_start(); session_destroy(); unset(_COOKIE[session_name()]); } |

핫 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)

뜨거운 주제









이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu
