$_GET ist und bleibt leer

theSplit

1998
Registriert
3 Aug. 2014
Beiträge
5.862
Ich habe aktuell ein, merkwürdiges, Problem bei dem $_GET Requests mit Variablen leer bleibt.

Es ist wie folgt aufgebaut:
Javascript nutzt [kw]window.location.href = 'category.php?id=2&to=Neuer%20Name'[/kw]

Jetzt ist es aber so, nach der Weiterleitung zu "category.php?id=2....." kommt nichts an - in der Konsole (EntwicklerTools in Firefox) sehe ich aber, dass die URL aufgerufen wird und rufe ich die URL manuell auf, funktioniert es auch, nur eben nicht über die JS Weiterleitung.

Aber ich bekomme auch beim Aufruf keinen Status 200 oder ähnliches zurück in den DevTools von FF.

Dies scheint auch in Chrome wie auch Firefox ein Problem zu sein.
Hat jemand eine Idee woran dies liegen kann?

Ich nutze PHP 7.3 mit Apache 2.
 
Was heißt denn genau "kommt nichts an"?

Wie sieht es aus, wenn Du eine leere Seite nimmst und dort dann onload Dein window.location.href packst? Wird die Seite geladen oder bleibt die Seite leer?
 
  • Thread Starter Thread Starter
  • #3
Das folgende Beispiel funktioniert:

[src=php]<<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Test Page</title>
</head>
<body>

<?php
print_r($_GET);
if (isset($_GET['rename']) && isset($_GET['to'])) {
echo 'inside!';
die();
}
?>

<script type="text/javascript">
window.location.href = "test.php?rename=1&to=NewOne"
</script>
</body>
</html>[/src]

Was nicht funktioniert, hier alles was im [kw]script-Tag[/kw] enthalten ist.

[src=php]<!DOCTYPE html>
<html>
<head>
<title>sqStorage</title>
<link rel="stylesheet" href="./css/bootstrap/bootstrap.css">
<link rel="stylesheet" href="./css/base.css">

<link rel="stylesheet" href="./fonts/fontawesome/css/solid.css">
<link rel="stylesheet" href="./fonts/fontawesome/css/regular.css">
<link rel="stylesheet" href="./fonts/fontawesome/css/fontawesome.css">
<meta charset="utf-8">
</head> <body>
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<a href="index.php"><img class="logo" src="./img/sqstorage.png" /></a>
<ul class="nav">
<li class="nav-item"><a href="index.php" class="nav-link">Eintragen</a></li>
<li class="nav-item"><a href="inventory.php" class="nav-link">Inventar</a></li>
<li class="nav-item"><a href="categories.php" class="nav-link">Kategorien</a></li>
</ul>

<form class="form-inline my-2 " method="GET" action="inventory.php">
<input class="form-control mr-sm-2" name="searchValue" type="search" placeholder="Suche" aria-label="Suche">
<button class="btn btn-outline-success my-2 my-sm-0" type="submit">Suchen</button>
</form>
</nav>
<div class="content">
<hr/><ul class="categories list-group"><li class="alert alert-info"><span class="list-span">Kategorien</span><span class="list-span">Anzahl</span><span class="list-span">Aktionen</span></li><li class="list-group-item"><a name="removeCategory" data-name="Netzwerk2" href="categories.php?removeCategory=4" class="removalButton fas fa-times-circle btn"></a><a class="list-span" data-name="Netzwerk2" href="inventory.php?category=4">Netzwerk2</a><span class="list-span">1 Gegenstand</span><a class="fas fa-edit editCategory" href="categories.php" name="editCategory" data-name="Netzwerk2" data-id="4"></a></li><li class="list-group-item"><a name="removeCategory" data-name="Netzwerk3" href="categories.php?removeCategory=5" class="removalButton fas fa-times-circle btn"></a><a class="list-span" data-name="Netzwerk3" href="inventory.php?category=5">Netzwerk3</a><span class="list-span">3 Gegenstände</span><a class="fas fa-edit editCategory" href="categories.php" name="editCategory" data-name="Netzwerk3" data-id="5"></a></li></ul><hr/><ul class="categories list-group"><li class="alert alert-info"><span class="list-span">Unterkategorien</span><span class="list-span">Anzahl</span><span class="list-span">Aktionen</span></li></ul> </div>

<script type="text/javascript">
let removalButtons = document.querySelectorAll('.removalButton')
for (let button of removalButtons) {
button.addEventListener('click', function (evt) {
let targetType = evt.target.name === 'removeCategory' ? 'Kategorie wirklich entfernen?' : 'Unterkategorie wirklich entfernen?'
if (!window.confirm(targetType + ' "' + evt.target.dataset['name'] +'"')) {
evt.preventDefault()
}
})
}

let editCategoryButtons = document.querySelectorAll('.editCategory')
for (let button of editCategoryButtons) {
button.addEventListener('click', function (evt) {
let targetType = evt.target.name === 'editCategory' ? 'Kategorie umbenennen?' : 'Unterkategorie umbenennen?'
let newName = window.prompt(targetType + ' "' + evt.target.dataset['name'] + '"', '')

if (newName !== null && newName.length !== 0) {
if (evt.target.name === 'editCategory') window.location.href = 'categories.php?headCategory=' + evt.target.dataset['id'] + '&to=' + newName
else window.location.href = 'categories.php?subCategory=' + evt.target.dataset['id'] + '&to=' + newName
return false
}

evt.preventDefault()
return false
})
}
</script>
</body>
</html>[/src]

Screenshot des Aufrufs:



Edit: Noch ein Nachtrag, auch wenn ich ein "die()" einfüge, der $_GET Parameter ist leer. Auch wenn die URL wie im Screenshot aufgerufen wird.

Hier ein Screenshot dazu:
$_SERVER, $_GET, $_POST (letzten zwei sind leere Arrays.

 
Zuletzt bearbeitet:
Das komische ist ja, das direkt danach die url ohne Parameter aufgerufen wird.
Irgendeine Idee warum? Irgendwas noch im Code, was hier fehlt?
 
Nachdem du window.location.href setzt, rufst du nicht evt.preventDefault() auf, wodurch der Browser dem Link zu categories.php (ohne Query-String) folgt?

Wenn du dir evt.preventDefault() sparen willst, sorge dafür dass der Link auf ein Ziel (href) wie "#" oder "javascript:;" und nicht auf eine andere Seite zeigt.
 
Und bei der Gelegenheit: Codier deine URL-Parameter mal richtig :D [kw]encodeURIComponent[/kw] ist dein Freund:
[src=javascript]if (evt.target.name === 'editCategory') window.location.href = 'categories.php?headCategory=' + encodeURIComponent(evt.target.dataset['id']) + '&to=' + encodeURIComponent(newName)
else window.location.href = 'categories.php?subCategory=' + encodeURIComponent(evt.target.dataset['id']) + '&to=' + encodeURIComponent(newName)[/src]
 
  • Thread Starter Thread Starter
  • #7
Mea culpa :)

In der Tat ist/war das Problem, das die URL dem "href" gefolgt ist und nicht allein dem [kw]window.location.href[/kw] für die Renaming-URL - das event.preventDefault() hat dann aber das übrige getan.

Ich bin mir aber ziemlich sicher, dass beides mal funktioniert hatte - aber gut. :)

So sieht es jetzt aus:
[src=php]
<div class="content">
<div class="alert alert-info" role="alert"><p>Kategorie umbenannt.</p></div><hr/><ul class="categories list-group"><li class="alert alert-info"><span class="list-span">Kategorien</span><span class="list-span">Anzahl</span><span class="list-span">Aktionen</span></li><li class="list-group-item"><a name="removeCategory" data-name="Netz" href="categories.php?removeCategory=4" class="removalButton fas fa-times-circle btn"></a><a class="list-span" data-name="Netz" href="inventory.php?category=4">Netz</a><span class="list-span">1 Gegenstand</span><a class="fas fa-edit editCategory" href="#" name="editCategory" data-name="Netz" data-id="4"></a></li><li class="list-group-item"><a name="removeCategory" data-name="Netzwerk3" href="categories.php?removeCategory=5" class="removalButton fas fa-times-circle btn"></a><a class="list-span" data-name="Netzwerk3" href="inventory.php?category=5">Netzwerk3</a><span class="list-span">3 Gegenstände</span><a class="fas fa-edit editCategory" href="#" name="editCategory" data-name="Netzwerk3" data-id="5"></a></li></ul><hr/><ul class="categories list-group"><li class="alert alert-info"><span class="list-span">Unterkategorien</span><span class="list-span">Anzahl</span><span class="list-span">Aktionen</span></li></ul> </div>

<script type="text/javascript">
let removalButtons = document.querySelectorAll('.removalButton')
for (let button of removalButtons) {
button.addEventListener('click', function (evt) {
let targetType = evt.target.name === 'removeCategory' ? 'Kategorie wirklich entfernen?' : 'Unterkategorie wirklich entfernen?'
if (!window.confirm(targetType + ' "' + evt.target.dataset['name'] +'"')) {
evt.preventDefault()
}
})
}

let editCategoryButtons = document.querySelectorAll('.editCategory')
for (let button of editCategoryButtons) {
button.addEventListener('click', function (evt) {
let targetType = evt.target.name === 'editCategory' ? 'Kategorie umbenennen?' : 'Unterkategorie umbenennen?'
let newName = window.prompt(targetType + ' "' + evt.target.dataset['name'] + '"', '')

if (newName !== null && newName.length !== 0) {
if (evt.target.name === 'editCategory') window.location.href = 'categories.php?headCategory=' + evt.target.dataset['id'] + '&to=' + encodeURIComponent(newName)
else window.location.href = 'categories.php?subCategory=' + evt.target.dataset['id'] + '&to=' + encodeURIComponent(newName)
}

return false
})
}
</script>
[/src]

[kw]encodURIcomponent[/kw] habe ich auch integriert.

Vielen Dank nochmal euch allen!
 
Zuletzt bearbeitet:
Zurück
Oben