1

经过一些解释,我把我的代码放在了上面。

我对此进行编程是因为我需要使用 .mm 文档填充应用程序使用的数据库(Freemind 文档,.mm 是“思维导图”的扩展名)

应用程序和数据库需要我将结构保留在 Freemind 文档中。我不编写应用程序和数据库,这是另一个人的工作。

这就是原因,因为我拥有所有这些
“如果当前节点的子节点是具有子节点的节点是具有名为 BUILTIN 的属性的图标包含想法,则该子节点不是要放入数据库的其他对象,而是” contenu"当前节点创建的对象的值"

很难解释(用法语解释很可怕......我试着用英语说清楚。我希望它很清楚。)

当我尝试使用我的程序时,我可以选择我要转换的 Freemind 文档是 SQL,但之后出现此错误:
致命错误:无法在 C:\xampp\htdocs\ 的写入上下文中使用方法返回值第 25 行的 test2\transfertXmlBdd.php

有人知道为什么它不起作用以及我如何使它起作用?

我觉得是这个部分

    if(move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
    $chaineXML = $target_file;

我尝试将上传的文件保存在 $chaineXML 中,以便之后使用 DOM 对其进行收费。

$dom->loadXML($chaineXML);

但我可能做错了。

上传表格

<form action="upload.php" method="post" enctype="multipart/form-data">
Selectionner le document Freemind a charger:
<input type="file" name="fileToUpload" id="fileToUpload">
<input type="submit" value="Charger le document" name="submit">
</form>

</body>
</html>

上传

// Check if image file is a actual image or fake image
//if(isset($_POST["submit"])) {
//    $check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
//    if($check !== false) {
//        echo "File is an image - " . $check["mime"] . ".";
//        $uploadOk = 1;
//    } else {
//        echo "File is not an image.";
//        $uploadOk = 0;
//    }
//}

// Check if file already exists
if (file_exists($target_file)) {
    echo "Le fichier a deja ete charger.";
    $uploadOk = 0;
}

// Check file size
//if ($_FILES["fileToUpload"]["size"] > 50000000) {
//    echo "Le fichier est trop lourd.";
//    $uploadOk = 0;
//}

// Allow certain file formats
if($imageFileType != "mm") {
    echo "Vous ne pouvez upload que des fichiers XML au format MM (mind mapping).";
    $uploadOk = 0;
}

// Check if $uploadOk is set to 0 by an error
if ($uploadOk == 0) {
    echo "Echec du chargement.";
// if everything is ok, try to upload file
} else {
    if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
        $chaineXML = $target_file;
        echo "Le fichier ". basename( $_FILES["fileToUpload"]["name"]). " a ete charger.";

        //on appelle la conversion/transfert
        include_once('C:/xampp/htdocs/test2/transfertXmlBdd.php');
        echo "Les donnees ont ete enregistre dans la BDD.";
    } else {
        echo "Une erreur s'est produite.";
    }
}
?>

transferXmlBdd

$dom->loadXML($chaineXML);

$element = $listeElements->item(0);

//variables
$id= NULL;
$nom = NULL;
$type = NULL;
$contenu = NULL;
$idParent = NULL;
$idFils = NULL;

//comper le nombres d'elements déjà présent dans la table
$res = $bdd->query('select count(*) as nb from element');
$data = $res->fetch();
$id = $data['nb'];

foreach($xml as $node)
{
    //on vérifie la présence ou non de BUILTIN de valeur idea, on passe à l'itération suivante (en forçant) si oui
    if($node->hasChild("icon")->hasAttribute("BUILTIN")="idea")
    {
        continue;
    }

    //on génere les valeurs id et nom
    $nom = getAttributeNode('NAME');
    $id = $id + 1;
    $idFils = $id;
    //
    $node.setAttribute(bddid,$id);

    //on vérifie la parenté de l'enregistrement
    if($node->hasParent("node"))
    {
        $idParent = getAttributeParent('bddid');
        $req = $bdd->prepare('INSERT INTO fils_des_element(id_elem, id_fils) VALUES( idParent, :idFils)');
    }
    else
    {
        // affilié à l'élement 0
        $req = $bdd->prepare('INSERT INTO fils_des_element(id_elem, id_fils) VALUES( 0, :idFils)');
    }

    //vérification de contenu
    if($node->hasChild("node")->hasChild("icon")->hasAttribute("BUILTIN")=idea)
    {
        $contenu = getChildAttribute('NAME');
    }

    //détermination du type
    if($node->hasChild("icon")-hasAttribute("BUILTIN")=button_ok)
    {
        $type = "Avec Solution";
    }
    elseif($node->hasChild("icon")-hasAttribute("BUILTIN")=button_cancel)
    {
        $type = "Sans Solution";
    }
    else
    {
        $type = NULL;
    }

    //création de l'entré dans la table
    $req = $bdd->prepare('INSERT INTO element(id_element, nom, type, proprietaire, visible, contenu, date_modif) VALUES( :id, :nom, :type, drn, 0, :contenu, CURDATE())');
}

?>
4

0 回答 0