Heim > Fragen und Antworten > Hauptteil
Vor ein paar Jahren habe ich für einige meiner mobilen Apps ein Backend (PHP, um einige JSON-Daten zu erhalten) erstellt. Ich habe diesen Code seitdem nicht mehr angerührt. Jetzt hat es schon vor Wochen aufgehört zu funktionieren. Ich bin kein Backend-Entwickler, daher habe ich hier nicht viel Erfahrung, aber vor ein paar Jahren dachte ich, es wäre besser, mein eigenes Backend zu erstellen, anstatt Firebase/Serverless zu verwenden ... was nicht meine beste Idee war: )
Was ich versucht habe:
<!doctype html> <html> <head> <meta charset="utf-8"> <meta name="robots" content="noindex, nofollow"> <title>One moment, please...</title> <style> body { background: #F6F7F8; color: #303131; font-family: sans-serif; margin-top: 45vh; text-align: center; } </style> </head> <body> <h1>Please wait while your request is being verified...</h1> <form id="wsidchk-form" style="display:none;" action="/z0f76a1d14fd21a8fb5fd0d03e0fdc3d3cedae52f" method="get"> <input type="hidden" id="wsidchk" name="wsidchk"/> </form> <script> (function(){ var west=+((+!+[])+(+!+[]+!![]+!![]+!![]+[])+(+!+[]+!![]+!![]+!![])+(+!+[]+!![]+!![]+!![]+[])+(+!+[])+(+!+[]+!![]+!![]+!![]+!![]+!![]+!![]+!![]+[])+(+!+[]+!![]+!![]+!![]+!![])+(+!+[]+[])), east=+((+!+[])+(+!+[]+!![]+[])+(+!+[]+!![]+!![]+!![]+!![]+!![]+!![]+!![])+(+!+[]+[])+(+![])+(+!+[]+!![]+[])+(+!+[]+!![])+(+!+[]+!![]+!![]+[])), x=function(){try{return !!window.addEventLis tener;}catch(e){return !!0;} }, y=function(y,z){x() ? document.addEventLis tener("DOMContentLoaded",y,z) : document.attachEvent("onreadystatechange",y);}; y(function(){ document.getElementById('wsidchk').value = west + east; document.getElementById('wsidchk-form').submit(); }, false); })(); </script> </body> </html>
Das ist meine PHP-Datei:
$response = array(); function saveResultOfQueryToArray($result){ global $response; $response['workouts'] = array(); while($row = mysqli_fetch_array($result)){ $temp = array(); // $temp['aufruf'] = $aufruf; $temp['error'] = false; $temp['workoutname'] = $row['workoutname']; $temp['duration'] = $row['duration']; ... array_push($response['workouts'],$temp); } } if($_SERVER['REQUEST_METHOD']=='GET') { $db = new DbOperation(); $users = $db->getHighestRatingWith31Results(); saveResultOfQueryToArray($users, $chooseMethod); } else { $response['error'] = true; $response['message'] = "Invalid Request"; } echo json_encode($response);
Kann mir jemand erklären, was ich falsch mache/was geändert werden kann?
P粉8212313192023-12-17 09:11:42
看起来 if($_SERVER['REQUEST_METHOD'] == 'GET')
没有 $response
。除非代码中有更多内容,否则 $response
未定义。
if($_SERVER['REQUEST_METHOD']=='GET') { $db = new DbOperation(); $users = $db->getHighestRatingWith31Results(); saveResultOfQueryToArray($users, $chooseMethod); $response['error'] = false; $response['message'] = 'Whatever you want returned here.'; else { $response['error'] = true; $response['message'] = "Invalid Request"; } echo json_encode($response);
类似的东西应该可以解决问题!我还建议查看 HTTP 响应,例如 HTTP 405。 https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/405
编辑:我看到了您的更新,很抱歉,但这引发了更多问题。也就是说,$db->getHighestRatingWith31Results();
是做什么的?函数 saveResultOfQueryToArray()
接受一个参数,但用法是给函数提供两个参数? saveResultOfQueryToArray 正在调用 mysqli_fetch_array(),它需要一个 mysqli_result 实例。
这是我的建议:
saveResultOfQueryToArray()
返回 $response,要么考虑通过引用传递。 https://www.php.net/manual/en/language。 references.pass.php