繁体   English   中英

$_POST 请求适用于 postman 但不适用于 android 应用程序

[英]$_POST request works with postman but not in android app

我在这个问题上已经有一段时间了,目前正在尝试将我的 php 脚本转换为 PDO 但是 $_POST 总是给我 null 时运行 isset。 我在 android 中的代码可以与我的其他脚本一起正常工作,但是当我将每个项目的 $_POST 更改为 $_REQUEST 并且链接看起来也不同时,这个代码仅适用于 postman。 还值得一提的是 onResponse 和 onFailure 没有接收/打印任何消息。

Postman URL

http://123.456.7.89/Database/register.php?username=asdfasdf&password=lj4ioidfoislkjsf&email=jalenpauloiudf&tece=true&profilePicPath=aksdfjlakjdsfl&tokenId=as89gwbeg98sd

当前URL

http://123.456.7.89/Database/register.php

脚本

<?php

$servername = "localhost";
$dbUsername = "root";
$dbPassword = "password";
$dbname = "Database";

try {
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $dbUsername, $dbPassword);
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    
    $username = $_POST['username'];
    $password = $_POST['password'];
    $email = $_POST['email'];
    $termsOfService = $_POST['termsOfService'];
    $profilePicPath = $_POST['profilePicPath'];
    $tokenId = $_POST['tokenId'];
    $userId = uniqId();

    //converting data
    $termsOfService = $termsOfService ? 'true' : 'false';

    //Username check
    $emailForQuery = "%" . $_POST['email'] . "%";
    $userIdForQuery = "%" . $userId . "%";
    $usernameCheckQuery = $conn->prepare("SELECT email, userId FROM users WHERE email LIKE ? OR userId LIKE ? LIMIT 1");
    $usernameCheckQuery->execute([$emailForQuery, $userIdForQuery]); 
    $usernameCheckQuery->fetch();

    if ($usernameCheckQuery->rowCount() == 0) {//username doesnt exist
        $usernameCheckQuery->closeCursor();

        $hashedPassword = password_hash($password, PASSWORD_DEFAULT);
        $query = $conn->prepare("INSERT INTO users(userId, username, password, email, termsOfService, profilePicPath, tokenId) 
            VALUES(?, ?, ?, ?, ?, ?, ?)");
        $query->execute([$userId, $username, $hashedPassword, $email, $termsOfService, $profilePicPath, $tokenId]);
        $query->closeCursor();

        header('Content-type:application/json;charset=utf-8');
        $resArray = ['success' => true, 'userId' => $userId];
        echo json_encode($resArray);

    } else { //username exists
        $usernameCheckQuery->closeCursor();
        connectionError("username already exists");
    }
        
} catch(PDOException $e) {    
    connectionError();
}

function connectionError($message = "database connection error") { //sending response
    header('Content-type:application/json;charset=utf-8');
    $resArray = ['success' => false, 'message' => $message];
    echo json_encode($resArray);
    $conn = null;
}

?>

Android 发布数据

    @FormUrlEncoded
@POST("register.php")
fun signUpUser(@Field("username") username: String,
               @Field("password") password: String,
               @Field("email") email: String,
               @Field("termsOfService") termsOfService: Boolean,
               @Field("profilePicPath") profilePicPath: String,
               @Field("tokenId") tokenId: String): Call<ResponseLoginOrSignUp>

我的猜测是它与网址有关,但又一次没有发送响应。

如果需要任何其他代码,请告诉我并添加它,谢谢。

回答!!! 这是我的结论,我的域不安全,需要将 ssl 添加到我的托管域和自定义域中。 对于 ssl,我将 cloudflare 用于寻找免费 ssl 的任何人,因为我花了一段时间才找到合适的站点。 还将 http 切换到 https 中的 url 展示在 ZC31B32364CE19CA8FCD150A41 工作室

在 android 清单中使用 android:usesCleartextTraffic="true"

首先,尝试将Http更改为https

然后我推荐使用 android 凌空发布请求

https://developer.android.com/training/volley[Android凌空示例] 1

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM