代码如下 一直出现 Warning: Cannot modify header information - headers already sent by (output started at D:\AppServ\www\admin_check.php:1) in D:\AppServ\www\admin_check.php on line 10 <?php
require_once 'user_service.class.php';
$admin_id=$_POST['admin_id'];
$admin_password=$_POST['admin_password'];
$userService=new userservice();
if($name=$userService->checkUser($admin_id, $admin_password)){ header("Location: manage.php?name=$admin_id"); exit;
}else{
header("Location: login.php?error=1");
exit;
}
?>这段代码前端没有问题 都是执行到header 出现的问题
这是user_service.class.php
<?php
require_once 'sqlhelper.class.php';
require_once 'user.class.php';
class userservice{
//提供一个根据用户名name获取一个账号信息的方法
public function getUserByName($name) {
$sql="select * from user where name='".$name."'";
$sqlHelper= new sqlhelper();
$arr=$sqlHelper->dql2($sql);
$sqlHelper->close_conn(); return $arr;//
}
//提供一个验证用户是否合法的方法
public function checkUser($name,$password){
$sql="select password ,name from user where name='".$name."'";
//创建一个sqlhelper对象
$sqlHelper=new sqlhelper();
$res=$sqlHelper->dql($sql);
if($row=mysql_fetch_assoc($res)){
//比对密码
if($password==$row['password']){
return $row['name'];
}
}
mysql_free_result($res);
$sqlHelper->close_conn();
return "";
}
public function gengGPassword($name,$newpassword){
$sql="update user set password='".$newpassword."' where name='".$name."'";
$sqlHelper=new sqlhelper();
$res=$sqlHelper->dql($sql);
// mysql_free_result($res);
$sqlHelper->close_conn();
}
}
?>
sqlhelper.class.php代码
<?php
//工具类
class sqlhelper{
public $host="localhost";
public $user="root";
public $password="123456";
public $db="bishe";
public $conn;
public function sqlhelper(){
$this->conn=mysql_connect("localhost","root","123456") or die ("123".mysql_errno () );
if(!$this->conn){
die("连接失败".mysql_errno());
}
mysql_query("set names utf8");
mysql_select_db($this->db,$this->conn);
}
public function dql($sql){
$res=mysql_query($sql,$this->conn)or die(mysql_errno()); return $res;
}
public function dql2($sql){ $res=mysql_query($sql,$this->conn)or die("错误!".mysql_errno()); $arr=mysql_fetch_array($res,$this->conn);
return $arr;
/* echo $arr[0],$arr['1'];
$result = mysql_query("SELECT * from user where name='xiaowang'"); while ($row = mysql_fetch_array($result, MYSQL_NUM)) {
printf ("ID: %s Name: %s", $row[0], $row[1]);
}
mysql_free_result($result);
return $row;*/
}
//public function dql2($sql){
// $res=mysql_query($sql,$this->conn)or die(mysql_errno());
//return $res;
//}
//删除?
public function dml($sql){
$b=mysql_query($sql,$this->conn);
if (!$b) {
return 0;//失败
;
}else {
if (mysql_affected_rows($this->conn)>0){
return 1;//表示执行OK
}else {
return 2;//表示没有行收到影响
}
}
}
public function close_conn(){
if(!empty($this->conn)){
mysql_close($this->conn);
}
}
}
?>
user.class.php是空的。求高手指点下啊 我以前用的时候没有问题啊 header前也没有输出啊 后来我重装了一下系统就出现问题了 求解决
require_once 'user_service.class.php';
$admin_id=$_POST['admin_id'];
$admin_password=$_POST['admin_password'];
$userService=new userservice();
if($name=$userService->checkUser($admin_id, $admin_password)){ header("Location: manage.php?name=$admin_id"); exit;
}else{
header("Location: login.php?error=1");
exit;
}
?>这段代码前端没有问题 都是执行到header 出现的问题
这是user_service.class.php
<?php
require_once 'sqlhelper.class.php';
require_once 'user.class.php';
class userservice{
//提供一个根据用户名name获取一个账号信息的方法
public function getUserByName($name) {
$sql="select * from user where name='".$name."'";
$sqlHelper= new sqlhelper();
$arr=$sqlHelper->dql2($sql);
$sqlHelper->close_conn(); return $arr;//
}
//提供一个验证用户是否合法的方法
public function checkUser($name,$password){
$sql="select password ,name from user where name='".$name."'";
//创建一个sqlhelper对象
$sqlHelper=new sqlhelper();
$res=$sqlHelper->dql($sql);
if($row=mysql_fetch_assoc($res)){
//比对密码
if($password==$row['password']){
return $row['name'];
}
}
mysql_free_result($res);
$sqlHelper->close_conn();
return "";
}
public function gengGPassword($name,$newpassword){
$sql="update user set password='".$newpassword."' where name='".$name."'";
$sqlHelper=new sqlhelper();
$res=$sqlHelper->dql($sql);
// mysql_free_result($res);
$sqlHelper->close_conn();
}
}
?>
sqlhelper.class.php代码
<?php
//工具类
class sqlhelper{
public $host="localhost";
public $user="root";
public $password="123456";
public $db="bishe";
public $conn;
public function sqlhelper(){
$this->conn=mysql_connect("localhost","root","123456") or die ("123".mysql_errno () );
if(!$this->conn){
die("连接失败".mysql_errno());
}
mysql_query("set names utf8");
mysql_select_db($this->db,$this->conn);
}
public function dql($sql){
$res=mysql_query($sql,$this->conn)or die(mysql_errno()); return $res;
}
public function dql2($sql){ $res=mysql_query($sql,$this->conn)or die("错误!".mysql_errno()); $arr=mysql_fetch_array($res,$this->conn);
return $arr;
/* echo $arr[0],$arr['1'];
$result = mysql_query("SELECT * from user where name='xiaowang'"); while ($row = mysql_fetch_array($result, MYSQL_NUM)) {
printf ("ID: %s Name: %s", $row[0], $row[1]);
}
mysql_free_result($result);
return $row;*/
}
//public function dql2($sql){
// $res=mysql_query($sql,$this->conn)or die(mysql_errno());
//return $res;
//}
//删除?
public function dml($sql){
$b=mysql_query($sql,$this->conn);
if (!$b) {
return 0;//失败
;
}else {
if (mysql_affected_rows($this->conn)>0){
return 1;//表示执行OK
}else {
return 2;//表示没有行收到影响
}
}
}
public function close_conn(){
if(!empty($this->conn)){
mysql_close($this->conn);
}
}
}
?>
user.class.php是空的。求高手指点下啊 我以前用的时候没有问题啊 header前也没有输出啊 后来我重装了一下系统就出现问题了 求解决
加括号就应该没有问题啦!你试一下.
//require_once 'user_service.class.php';
$admin_id=$_POST['admin_id'];
$admin_password=$_POST['admin_password'];
/*$userService=new userservice();
if($name=$userService->checkUser($admin_id, $admin_password)){ header("Location: manage.php?name=$admin_id"); exit;
}else{
header("Location: login.php?error=1");
exit;
}*/
$conn=mysql_connect("localhost","root","123456");
if(!$conn){
die("连接失败".mysql_errno());
}
//访问数据库编码
mysql_query("set names utf8",$conn) or die(mysql_errno());
//选择数据库
mysql_select_db("bishe",$conn) or die(mysql_errno());
//发送sql语句
//防止sql注入攻击 $sql="select * from user where id=$admin_id and password=$admin_password";
$sql="select password ,name from user where name='".$admin_id."'";
$res=mysql_query($sql,$conn); if($row=mysql_fetch_object($res)){
//查询到.
//取出数据库密码
if($row->password==$admin_password){
$name=$row->name;
echo "ok";
// header("Location:manage.php?name=$name");
exit();
}
}
echo "shibai";
//header("Location: login.php?error=1");
exit();
mysql_free_result($res);
mysql_close($conn);
if($admin_id=="admin"&&$admin_password=="123"){
header("Location:manage.php");
}
else{
header("Location:login.php?error=1");
exit();
}
?>
我将代码改成一下部分 没有类的引用 如果 我尝试了一下 如果成功 会输出 OK 密码错误的情况会输出shibai 数据那方面没有问题 只是 header 这不知道为什么出错啊
// require_once 'user_service.class.php';
$admin_id=$_POST['admin_id'];
$admin_password=$_POST['admin_password'];
$conn=mysql_connect("localhost","root","123456");
if(!$conn){
die("连接失败".mysql_errno());
}
//访问数据库编码
mysql_query("set names utf8",$conn) or die(mysql_errno());
//选择数据库
mysql_select_db("bishe",$conn) or die(mysql_errno());
//发送sql语句
//防止sql注入攻击 $sql="select * from user where id=$admin_id and password=$admin_password";
$sql="select password ,name from user where name='".$admin_id."'";
$res=mysql_query($sql,$conn); if($row=mysql_fetch_object($res)){
//查询到.
//取出数据库密码
if($row->password==$admin_password){
$name=$row->name;
header("Location:manage.php?name=$name");
exit();
}
}
;
header("Location: login.php?error=1");
exit();
mysql_free_result($res);
mysql_close($conn);
if($admin_id=="admin"&&$admin_password=="123"){
header("Location:manage.php");
}
else{
header("Location:login.php?error=1");
exit();
}
?>代码改成如下 则成功了我什么都没有操作 只是删除了一部分 注释代码
// require_once 'user_service.class.php';
$admin_id=$_POST['admin_id'];
$admin_password=$_POST['admin_password'];
$conn=mysql_connect("localhost","root","123456");
if(!$conn){
die("连接失败".mysql_errno());
}
//访问数据库编码
mysql_query("set names utf8",$conn) or die(mysql_errno());
//选择数据库
mysql_select_db("bishe",$conn) or die(mysql_errno());
//发送sql语句
//防止sql注入攻击 $sql="select * from user where id=$admin_id and password=$admin_password";
$sql="select password ,name from user where name='".$admin_id."'";
$res=mysql_query($sql,$conn); if($row=mysql_fetch_object($res)){
//查询到.
//取出数据库密码
if($row->password==$admin_password){
$name=$row->name;
header("Location:manage.php?name=$name");
exit();
}
}
;
header("Location: login.php?error=1");
exit();
mysql_free_result($res);
mysql_close($conn);
if($admin_id=="admin"&&$admin_password=="123"){
header("Location:manage.php");
}
else{
header("Location:login.php?error=1");
exit();
}
?>我只是删除了一部分注释代码 结果没问题了这是什么意思