Avatar billede energie Nybegynder
13. februar 2006 - 13:34 Der er 11 kommentarer

Variabler fra flash til PHP og til mySQL

Hey... skal sende en highscore liste fra flash til php-program og videre til mysql. Men pt. kommer der intet over i db. Og der er forbindelse fra mit php dokument til min db.

Min flash streng ser således ud:

        var d = new Date();
        var strDate = d.getDate() + "." + (d.getMonth() + 1) + "." + d.getFullYear() + " " + d.getHours() + ":" + d.getMinutes();
        loadVariables("./save_score1.php?p=" + _root.gamePoints + "&n=" + escape(txtPlayersName) + "&e=" + escape(txtPlayersEmail) + "&d=" + escape(strDate) + "&l=" + _root.gameLevel + "&t=" + _root.secondsCounter / 1000 + "&a=" + _root.attemptsCounter, 0, "POST");
        }

Og mit php således:

<?php
// Sæt de variable der skal bruges for at lave forbindelse til databasen
$databaseuser = "atj";
$databasepassword = "anders";
$databasename = "memory";
$databaseserver = "localhost";

//Opret forbindelse til databaseserver
$dblink = mysql_connect($databaseserver,$databaseuser,$databasepassword)
    or die(mysql_error());
mysql_select_db($databasename)
    or die(mysql_error());

  $p = $_POST["p"];
  $n = $_POST["n"];
  $e = $_POST["e"];
  $d = $_POST["d"];
  $l = $_POST["l"];
  $t = $_POST["t"];
  $a = $_POST["a"];

$sql = "INSERT INTO highscore VALUES(";
$sql .= "'','$p','$n','$e','$d','$l','$t','$a'";
$sql .=");";
mysql_query ($sql) or die ("Fejl i select");
 
?>
Avatar billede showsource Seniormester
13. februar 2006 - 13:39 #1
Prøv med REQUEST i stedet for POST
Avatar billede webt Nybegynder
13. februar 2006 - 13:40 #2
Du mangler at definere hvilke felter de skal indsættes i fx.

"INSERT INTO highscore (p,n,e,d,i,t,a) VALUES ('$p','$n','$e','$d','$l','$t','$a')"

og hvilken felttype er de forskellige? hvis de er af typen integer eller andet nummer værk i mysql så skal der ikke ' ' rundt om $p osv osv kun hvis det er tekst

Mvh
Martin
Avatar billede pidgeot Nybegynder
13. februar 2006 - 13:44 #3
Blot en lille kommentar, følger ikke med: Det er muligt at lave en INSERT uden direkte at angive feltnavnene - det vil så blive opfatet som om at du har angivet ALLE felterne i taebllen, i den rækkefølge de ligger i tabellen.
Avatar billede michael_stim Ekspert
13. februar 2006 - 13:50 #4
Fjern de første '' hvis det er et autoincrement felt
Avatar billede michael_stim Ekspert
13. februar 2006 - 13:51 #5
$sql = "INSERT INTO highscore VALUES(
$sql .= '$p','$n','$e','$d','$l','$t','$a'";
$sql .=")";
mysql_query ($sql) or die ("Fejl i select");
Avatar billede michael_stim Ekspert
13. februar 2006 - 13:53 #6
$sql = "INSERT INTO highscore VALUES('$p','$n','$e','$d','$l','$t','$a')";
Avatar billede energie Nybegynder
13. februar 2006 - 14:22 #7
Okay... ingen af disse ændre noget. Det første '' er et id felt som ligeledes er min int. og primary key.
Jeg mistænker mere måden flash sender dataerne på... Jeg viser lige hele mit script i det pågældende layer:

scoreMsg = "Your score is " + _root.gamePoints + " points !";
txtScore = "Loading highscore, please wait...";

if(_root.modeHighscore == 1) {
    txtTop10 = "Top 10:";
    loadVariables("./get_score.php?count=10&" + _root.phpCounter++, 0, "POST");
    }   
if(_root.modeHighscore == 0) {
    txtScore = _root.getHighscore();
}

for(var i = 0; i < _root.arrCats[i].length; i++) {
    _root.arrCats[i]._visible = true;
    _root.arrCards[i]._visible = false;
}

function onBtnApply() {
    if(_root.modeHighscore == 0) {
        _root.addScoreItem(txtPlayersName, txtPlayersEmail);
        _root.saveHighscore();
    }
    if(_root.modeHighscore == 1) {
    var d = new Date();
    var strDate = d.getDate() + "." + (d.getMonth() + 1) + "." + d.getFullYear() + " " + d.getHours() + ":" + d.getMinutes();
    loadVariables("./save_score1.php?p=" + _root.gamePoints + "&n=" + escape(txtPlayersName) + "&e=" + escape(txtPlayersEmail) + "&d=" + escape(strDate) + "&l=" + _root.gameLevel + "&t=" + _root.secondsCounter / 1000 + "&a=" + _root.attemptsCounter, 0, "POST");
        }
    btnApply.setEnabled(false);
    gotoAndPlay(1);
};

function OnBtnBack() {
  gotoAndPlay(1);
};

stop();
Avatar billede michael_stim Ekspert
13. februar 2006 - 14:25 #8
Prøv at udskrive din SQL istedet for at eksekvere den.
Avatar billede energie Nybegynder
13. februar 2006 - 14:28 #9
hvorledes mener du?
Avatar billede michael_stim Ekspert
13. februar 2006 - 14:29 #10
$sql = "INSERT INTO highscore VALUES('$p','$n','$e','$d','$l','$t','$a')";
echo $sql;
//mysql_query ($sql) or die ("Fejl i select");
Avatar billede energie Nybegynder
13. februar 2006 - 14:34 #11
Jeg har gjort det med GET i browserlinjen og den udskriver ganske korrekt. Men mit flash åbner jo ingen browservindue eller lign. Den gemmer og vender tilbage til starten af spillet.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester