2017-09-11 10 views
1

私はこのチュートリアルをfolowingログイン/登録アプリを作りました: https://www.youtube.com/watch?v=QxffHgiJ64M&list=PLe60o7ed8E-TztoF2K3y4VdDgT6APZ0kaものは値を入力する「0」

すべてがOKだったが、その後、私は「年齢」パラメータを削除して挿入"ラストネーム"と "電子メール"パラメータ。だから、毎回私は、ユーザーを登録しようと、「電子メール」フィールドには値を行く「0」(私は@かを使用していけない場合でも。)

私Register.phpファイルです

<?php 
 
    require("Password.php"); 
 
    $connect = mysqli_connect("x", "x", "x", "x"); 
 
    
 
    $name = $_POST["name"]; 
 
    $lastname = $_POST["lastname"]; 
 
    $email = $_POST["email"]; 
 
    $password = $_POST["password"]; 
 
    function registerUser() { 
 
     global $connect, $name, $lastname, $email, $password; 
 
     $passwordHash = password_hash($password, PASSWORD_DEFAULT); 
 
     $statement = mysqli_prepare($connect, "INSERT INTO user (name, lastname, email, password) VALUES (?, ?, ?, ?)"); 
 
     mysqli_stmt_bind_param($statement, "ssis", $name, $lastname, $email, $passwordHash); 
 
     mysqli_stmt_execute($statement); 
 
     mysqli_stmt_close($statement);  
 
    } 
 
    function emailAvailable() { 
 
     global $connect, $email; 
 
     $statement = mysqli_prepare($connect, "SELECT * FROM user WHERE email= ?"); 
 
     mysqli_stmt_bind_param($statement, "s", $email); 
 
     mysqli_stmt_execute($statement); 
 
     mysqli_stmt_store_result($statement); 
 
     $count = mysqli_stmt_num_rows($statement); 
 
     mysqli_stmt_close($statement); 
 
     if ($count < 1){ 
 
      return true; 
 
     }else { 
 
      return false; 
 
     } 
 
    } 
 
    $response = array(); 
 
    $response["success"] = false; 
 
    if (emailAvailable()){ 
 
     registerUser(); 
 
     $response["success"] = true; 
 
    } 
 
    
 
    echo json_encode($response); 
 
    ?>

、それは私のRegisterActivity.javaファイルです:

package com.example.gustavo.loginregister; 
 

 
import android.app.AlertDialog; 
 
import android.support.v7.app.AppCompatActivity; 
 
import android.os.Bundle; 
 
import android.view.View; 
 
import android.widget.Button; 
 
import android.widget.EditText; 
 
import android.content.Intent; 
 

 
import com.android.volley.RequestQueue; 
 
import com.android.volley.Response; 
 
import com.android.volley.toolbox.Volley; 
 

 
import org.json.JSONException; 
 
import org.json.JSONObject; 
 

 
public class RegisterActivity extends AppCompatActivity { 
 

 
    @Override 
 
    protected void onCreate(Bundle savedInstanceState) { 
 
     super.onCreate(savedInstanceState); 
 
     setContentView(R.layout.activity_register); 
 

 
     final EditText edtNome = (EditText) findViewById(R.id.edtNome); 
 
     final EditText edtSobrenome = (EditText) findViewById(R.id.edtSobrenome); 
 
     final EditText edtEmail = (EditText) findViewById(R.id.edtEmail); 
 
     final EditText edtSenha = (EditText) findViewById(R.id.edtSenha); 
 
     final Button btnRegistrar = (Button) findViewById(R.id.btnRegistrar); 
 

 
     btnRegistrar.setOnClickListener(new View.OnClickListener() { 
 
      @Override 
 
      public void onClick(View v) { 
 
       final String name = edtNome.getText().toString(); 
 
       final String lastname = edtSobrenome.getText().toString(); 
 
       final String email = edtEmail.getText().toString(); 
 
       final String password = edtSenha.getText().toString(); 
 

 
       Response.Listener<String> responseListener = new Response.Listener<String>() { 
 
        @Override 
 
        public void onResponse(String response) { 
 
         try { 
 
          JSONObject jsonResponse = new JSONObject(response); 
 
          boolean success = jsonResponse.getBoolean("success"); 
 
          if (success){ 
 
           Intent intent = new Intent(RegisterActivity.this, LoginActivity.class); 
 
           RegisterActivity.this.startActivity(intent); 
 
          } else{ 
 
           AlertDialog.Builder builder = new AlertDialog.Builder(RegisterActivity.this); 
 
           builder.setMessage("Register Failed") 
 
             .setNegativeButton("Retry",null) 
 
             .create() 
 
             .show(); 
 
           } 
 
         } catch (JSONException e) { 
 
          e.printStackTrace(); 
 
         } 
 
        } 
 
       }; 
 

 
       RegisterRequest registerRequest = new RegisterRequest(name, lastname, email, password, responseListener); 
 
       RequestQueue queue = Volley.newRequestQueue(RegisterActivity.this); 
 
       queue.add(registerRequest); 
 
      } 
 
     }); 
 
    } 
 
}

及びその一つが私のRegisterRequest.javaファイルです:

package com.example.gustavo.loginregister; 
 

 
import com.android.volley.Response; 
 
import com.android.volley.toolbox.StringRequest; 
 

 
import java.util.HashMap; 
 
import java.util.Map; 
 

 
public class RegisterRequest extends StringRequest { 
 
    private static final String REGISTER_REQUEST_URL="https://wavecheckapp.000webhostapp.com/Register.php"; 
 
    private Map<String, String> params; 
 

 
    public RegisterRequest(String name, String lastname, String email, String password, Response.Listener<String> listener){ 
 
     super(Method.POST, REGISTER_REQUEST_URL, listener, null); 
 
     params = new HashMap<String, String>(); 
 
     params.put("name", name); 
 
     params.put("lastname", lastname); 
 
     params.put("email", email); 
 
     params.put("password", password); 
 
    } 
 

 
    @Override 
 
    public Map<String, String> getParams() { 
 
     return params; 
 
    } 
 
}

私が間違って何をしているのですか?私は何度も何度もチェックしました... INTパラメータはありません。すべてがSTRINGです。 utf8_unicode_ciのデータベース。名前と姓とパスワードは完全に保存されています。データベースでは、パラメータはVARCHAR型です。

答えて

2

単純な間違いの場合、mysqli_stmt_bind_paramのメールアドレスフィールドは、sの代わりにiと混同しています。

変更、

mysqli_stmt_bind_param($statement, "ssis", $name, $lastname, $email, $passwordHash); 

に、

mysqli_stmt_bind_param($statement, "ssss", $name, $lastname, $email, $passwordHash); 

私はmysqliはあなたが提供しているタイプのパラメータをキャストする方法がわからないんだけど、あなたが次のコードを実行すると、出力が0です:

<?php 
echo (int) '[email protected]'; ---> 0 
?> 
+0

Thaanks、あなたは私の人生を救った。私はAndroidスタジオでのプログラミングにちょっとしたことがあるので、この "ssis"の意味を本当に知りませんでした。今、私はあなたに感謝しています:) –

+1

@GustavoContreiras問題はありません、まず[documentation](http://php.net/manual/en/mysqli-stmt.bind-param.php)を参照してください。それが助けられたら私の答えを受け入れることを検討してください。 – Script47

関連する問題