Я работаю над этим уже несколько часов и не добился никакого прогресса. Я новичок в модернизации и в основном просто пытаюсь сделать простой почтовый запрос с помощью jsonObject, но получаю эту ошибку:
java.lang.illegalStateException: Expected BEGIN_OBJECT but was STRING at line
1 column 1 path $
Я пытался изменить практически каждый бит этого кода от клиента на использование multipart или requestBody и даже мой код php, но ничего не работает, также попытался повторить ввод в скрипте, но он выводит пустой. Мы очень ценим любой ответ, спасибо.
Интерфейс
interface ApiInterface {
@Headers("Content-Type: application/json")
@POST(BuildConfig.URL_REGISTER)
fun signUpUser(@Body jsonObject: JSONObject): Call<Response>
}
Ответ
data class Response(@SerializedName("success") val success: Boolean,
@SerializedName("message") val message: String,
@SerializedName("userId") val userId:String)
Клиент
class ApiClient {
private external fun register(): String
companion object {
// Used to load the 'native-lib' library on application startup.
init {
System.loadLibrary("native-lib")
}
}
private val okhttpClient = OkHttpClient.Builder().build()
private val gson: Gson = GsonBuilder()
.setLenient()
.create()
val instance: ApiInterface by lazy {
val retrofit = Retrofit.Builder()
.baseUrl(register())
.addConverterFactory(GsonConverterFactory.create(gson))
.client(okhttpClient)
.build()
retrofit.create(ApiInterface::class.java)
}
Запрос
val jsonObject = JSONObject()
jsonObject.put("username", username)
jsonObject.put("password", password)
jsonObject.put("email", email)
jsonObject.put("termsOfService", termsOfService)
jsonObject.put("profilePicPath", imagePath)
ApiClient().instance.signUpUser(jsonObject).enqueue(object: Callback<com.passionit.picnbuy.models.Response>{
override fun onFailure(
call: Call<com.passionit.picnbuy.models.Response>, t: Throwable) {
Toast.makeText(this@LoginOrSignUpActivity, t.message, Toast.LENGTH_LONG).show()
}
override fun onResponse(call: Call<com.passionit.picnbuy.models.Response>, response: Response<com.passionit.picnbuy.models.Response>) {
Toast.makeText(this@LoginOrSignUpActivity, response.message(), Toast.LENGTH_LONG).show()
if (response.body()!!.success) { //success, now uploading pfp
//successful response doing stuff...
} else {
//error caught in script file
}
}
})
Php файл
<?php
$inputJSON = file_get_contents('php://input');
$input = json_decode($inputJSON, TRUE);
$conn = new mysqli("localhost", "root", "", "database");
if ($conn->connect_error) {
die("Failed to connect: " . $conn->connect_error);
}
$username = $input["username"];
$password = $input["password"];
$email = $input["email"];
$termsOfService = $input["termsOfService"];
$profilePicPath = $input["profilePicPath"];
//converting data
$termsOfService = $termsOfService ? 'true' : 'false';
//Username check
$usernameCheckQuery = $conn->prepare("SELECT * FROM allUsers WHERE username = ?");
$usernameCheckQuery->bind_param("s", $username);
$usernameCheckQuery->execute();
if ($usernameCheckQuery->num_rows > 0) {//username exists
$usernameCheckQuery->close();
print(json_encode(array('success' => false, 'message' => "username already exists")));
} else {
$usernameCheckQuery->close();
password_hash($password, PASSWORD_DEFAULT);
$query = $conn->prepare("INSERT INTO allUsers(username, password, email, tOS, pfPPath)
VALUES(?, ?, ?, ?, ?)");
$query->bind_param("sssss", $username, $password, $email, $termsOfService, $profilePicPath);
$query->execute();
$query->close();
print(json_encode(array('success' => true)));
}
$conn->close();
json_last_error();
?>