单个PHP文件上出现500内部服务器错误

时间:2015-02-17 12:16:31

标签: php runtime-error

今天我完成了一个新的PHP脚本,它处理来自注释的AJAX请求,并自动添加新的投票。 (我评论的第一个包括看他们是否改变了什么,但他们没有改变)

<?php

/*include_once 'functions.php';

include_once 'db_connect.php';
include_once 'psl-config.php';*/

sec_session_start();

$azione = filter_input(INPUT_GET, 'a', $filter = FILTER_SANITIZE_NUMBER_INT);
$da = filter_input(INPUT_GET, 'd', $filter = FILTER_SANITIZE_NUMBER_INT);
$su = filter_input(INPUT_GET, 's', $filter = FILTER_SANITIZE_NUMBER_INT);

if(!is_numeric($azione)){
    exit();
}

if(!is_numeric($da)){
    exit();
}

if(!is_numeric($su)){
    exit();
}

$azione = (int) $azione;
$da = (int) $da;
$su = (int) $su;

/*
 * Le azioni che possiamo utilizzare sono 3:
 * 1: VOTE UP
 * 2: VOTE DOWN 
 * 3: SEGNALAZIONE
 * 
 * Tuttavia per identificare, dalla variabile $azione ci saranno 5 possibilià.
 * 1: Vote up
 * 2: Remove vote up
 * 3: Vote down
 * 4: Remove vote down
 * 5: Segnalazione
 */

/*
 * Nel caso di un vote UP:
 * Eliminiamo ogni vote down
 * poi aggiungiamo il vote up.
 * DELETE FROM `azioni` WHERE `Tipo Azione` = 2 AND `Su` = ? AND `Da` = ?
 */ 
if($azione == 1) {
    $delete_stmt = $mysqli -> prepare("DELETE FROM `azioni` WHERE `Tipo Azione` = 2 AND `Su` = ? AND `Da` = ?");
    $delete_stmt -> bind_param ('ii', $su, $da);

    $delete_stmt -> execute();
    $delete_stmt -> store_result();

    // Ora che abbiamo eliminato il votedown aggiungiamo il voteup.
    $stmt = $mysqli->prepare("INSERT INTO `azioni` (`Tipo Azione`, `Da`, `Su`, `Data`) VALUES ('?', '?', '?', ?);");            
    $now_time = time();             
    $stmt->bind_param('iiii', $azione, $da, $su, $now_time);

    $stmt->execute();
    $stmt->store_result();

    // Finito.
    echo 1;
} else if($azione == 2) {
    // Nel caso in cui l'azione è 2, dobbiamo eliminare il vote up.
    $delete_stmt = $mysqli -> prepare("DELETE FROM `azioni` WHERE `Tipo Azione` = 1 AND `Su` = ? AND `Da` = ?");
    $delete_stmt -> bind_param ('ii', $su, $da);

    $delete_stmt -> execute();
    $delete_stmt -> store_result();

    // Finito.
    echo 1;
} else if($azione == 3) {
    $delete_stmt = $mysqli -> prepare("DELETE FROM `azioni` WHERE `Tipo Azione` = 1 AND `Su` = ? AND `Da` = ?");
    $delete_stmt -> bind_param ('ii', $su, $da);

    $delete_stmt -> execute();
    $delete_stmt -> store_result();

    // L'azione deve diventare 2 perchè 3 non corrisponde al votedown.
    $azione = 2;

    // Ora che abbiamo eliminato il voteup aggiungiamo il votedown.
    $stmt = $mysqli -> prepare("INSERT INTO `azioni` (`Tipo Azione`, `Da`, `Su`, `Data`) VALUES ('?', '?', '?', ?);");          
    $now_time = time();             
    $stmt->bind_param('iiii', $azione, $da, $su, $now_time);

    $stmt->execute();
    $stmt->store_result();

    // Finito.
    echo 1;
} else if($azione == 4) {
    // Nel caso in cui l'azione è 4, dobbiamo eliminare il vote down.
    $delete_stmt = $mysqli -> prepare("DELETE FROM `azioni` WHERE `Tipo Azione` = 2 AND `Su` = ? AND `Da` = ?");
    $delete_stmt -> bind_param ('ii', $su, $da);

    $delete_stmt -> execute();
    $delete_stmt -> store_result();

    // Finito.
    echo 1;
} else if($azione == 5){
    // L'azione deve essere 3 perchè è quella della segnalazione.
    $azione = 3;

    $stmt = $mysqli->prepare("INSERT INTO `azioni` (`Tipo Azione`, `Da`, `Su`, `Data`) VALUES ('?', '?', '?', ?);");            
    $now_time = time();             
    $stmt->bind_param('iiii', $azione, $da, $su, $now_time);

    $stmt->execute();
    $stmt->store_result();

    // Finito.
    echo 1;
}

现在它不起作用;事实上,当我尝试加载页面时,我收到500内部服务器错误,如果我进入服务器日志,我会收到以下两个错误:

[Tue Feb 17 12:58:25 2015] [error] [client ip.ip.ip.ip:port] - www.website.it - End of script output before headers: action-comment.php
[Tue Feb 17 12:58:25 2015] [error] [client ip.ip.ip.ip:port] - www.website.it - AH01215: suexec policy violation: see suexec log for more details 

我之前从未遇到此错误,它只显示在此特定页面上。 什么可以解决方案?

1 个答案:

答案 0 :(得分:0)

实际上,我发现问题是由Aptana 3做错了;事实上,如果我尝试在软件中创建一个新文件然后上传它,它将始终返回错误500.

相反,如果我从FileZilla创建文件,它就像魅力一样。