PHP uyarı yardım?

4 Cevap php

Ben aşağıda listelenen aşağıdaki hatayı alıyorum tutmak ve ben bu hatayı düzeltmek nasıl merak ediyordum.

Warning: mysqli_close() expects exactly 1 parameter, 0 given in

Aşağıda listelenen kodudur.

<?php
require_once ('./mysqli_connect.php'); // Connect to the db.

function make_list ($parent) {

	global $tasks;

	echo '<ol>';

	foreach ($parent as $task_id => $todo) {

		echo "<li>$todo";

		if (isset($tasks[$task_id])) { 

			make_list($tasks[$task_id]);

		}

		echo '</li>';

	} // End of FOREACH loop.

	// Close the ordered list:
	echo '</ol>';

} // End of make_list() function.

	$mysqli = new mysqli("localhost", "root", "", "sitename");
	$dbc = mysqli_query($mysqli,"SELECT task_id, parent_id, task FROM tasks WHERE date_completed='0000-00-00 00:00:00' ORDER BY parent_id, date_added ASC");
if (!$dbc) {
	// There was an error...do something about it here...
	print mysqli_error();
} 

$tasks = array();

while (list($task_id, $parent_id, $task) = mysqli_fetch_array($dbc, MYSQLI_NUM)) {

	// Add to the array:
	$tasks[$parent_id][$task_id] =  $task;

}

make_list($tasks[0]);


mysqli_close(); // close the connection

// Include the html footer
include('./includes/footer.html');
?>

4 Cevap

Hata mesajı açıktır: fonksiyon birini beklerken, herhangi bir argüman olmadan mysqli_close çağırdı.

Mysqli_close belgelerine göre, onun argüman olarak mysqli bağlantı vermeniz gerekir.

($ Mysqli) mysqli_close Çağrı;

Kullan $ mysqli-> close (); veya mysqli_close ($ mysqli);

Ben bir acemi değilim, ama sonunda mysqli_close konumunu () hareket ederek bu sorunu çözmek mümkün oldu. Ben} sağ sonra son vardı, ama sonra ben doğru ondan önce taşındı ve o çalıştı.

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Make Me Elvis - Send Email</title>
    <link rel="stylesheet" type="text/css" href="style.css" />
    </head>
    <body>
    <?php
    $from = 'elmer@makemeelvis.com';
    $subject = $_POST['subject'];
    $text = $_POST['elvismail'];

    if (empty($subject) && empty($text)){
    echo 'Both, the subject and the email field have been left empty';}

    if (empty($subject) && !empty($text)){
    echo 'The subject field is empty';}

    if (!empty($subject)&& empty($text)){
    echo 'The email field is empty'; }  

    if (!empty($subject) && !empty ($text)){

    $dbc = mysqli_connect('servername', 'username', 'password', 'dbname')
    or die('Error connecting to MySQL server.');

    $query = "SELECT * FROM email_list";
    $result = mysqli_query($dbc, $query)
    or die('Error querying database.');

    while ($row = mysqli_fetch_array($result)){
    $to = $row['email'];
    $first_name = $row['first_name'];
    $last_name = $row['last_name'];
    $msg = "Dear $first_name $last_name,\n $text";
    mail($to, $subject, $msg, 'From:' . $from);
    echo 'Email sent to: ' . $to . '<br />';
    }
    mysqli_close($dbc);
    } 

    ?>

``