2016-08-25 161 views
-3

我無法在我的服務器上輸入數據 我正在使用wampp服務器,每次運行我的項目和輸入數據時,我總是得到以下錯誤server connection failedandroid studio - 登錄註冊php mysql(服務器連接失敗)

有人可以幫我解決這個問題嗎?

下面是我的代碼:

public class MainActivity extends ActionBarActivity { 

protected EditText username; 
private EditText password; 
protected String enteredUsername; 
private final String serverUrl = "url server"; 

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

    username = (EditText)findViewById(R.id.username_field); 
    password = (EditText)findViewById(R.id.password_field); 
    Button loginButton = (Button)findViewById(R.id.login); 
    Button registerButton = (Button)findViewById(R.id.register_button); 

    loginButton.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      enteredUsername = username.getText().toString(); 
      String enteredPassword = password.getText().toString(); 

      if(enteredUsername.equals("") || enteredPassword.equals("")){ 
       Toast.makeText(MainActivity.this, "Username or password must be filled", Toast.LENGTH_LONG).show(); 
       return; 
      } 
      if(enteredUsername.length() <= 1 || enteredPassword.length() <= 1){ 
       Toast.makeText(MainActivity.this, "Username or password length must be greater than one", Toast.LENGTH_LONG).show(); 
       return; 
      } 
      // request authentication with remote server4 
      AsyncDataClass asyncRequestObject = new AsyncDataClass(); 
      asyncRequestObject.execute(serverUrl, enteredUsername, enteredPassword); 
     } 
    }); 

    registerButton.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View v) { 
      Intent intent = new Intent(MainActivity.this, RegisterActivity.class); 
      startActivity(intent); 
     } 
    }); 
} 

@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    // Inflate the menu; this adds items to the action bar if it is present. 
    getMenuInflater().inflate(R.menu.menu_main, menu); 
    return true; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    // Handle action bar item clicks here. The action bar will 
    // automatically handle clicks on the Home/Up button, so long 
    // as you specify a parent activity in AndroidManifest.xml. 
    int id = item.getItemId(); 

    //noinspection SimplifiableIfStatement 
    if (id == R.id.action_settings) { 
     return true; 
    } 

    return super.onOptionsItemSelected(item); 
} 

private class AsyncDataClass extends AsyncTask<String, Void, String> { 

    @Override 
    protected String doInBackground(String... params) { 

     HttpParams httpParameters = new BasicHttpParams(); 
     HttpConnectionParams.setConnectionTimeout(httpParameters, 5000); 
     HttpConnectionParams.setSoTimeout(httpParameters, 5000); 

     HttpClient httpClient = new DefaultHttpClient(httpParameters); 
     HttpPost httpPost = new HttpPost(params[0]); 

     String jsonResult = ""; 
     try { 
      List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2); 
      nameValuePairs.add(new BasicNameValuePair("username", params[1])); 
      nameValuePairs.add(new BasicNameValuePair("password", params[2])); 
      httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairs)); 
      HttpResponse response = httpClient.execute(httpPost); 
      jsonResult = inputStreamToString(response.getEntity().getContent()).toString(); 

     } catch (ClientProtocolException e) { 
      e.printStackTrace(); 
     } catch (IOException e) { 
      e.printStackTrace(); 
     } 
     return jsonResult; 
    } 

    @Override 
    protected void onPreExecute() { 
     super.onPreExecute(); 
    } 

    @Override 
    protected void onPostExecute(String result) { 
     super.onPostExecute(result); 
     System.out.println("Resulted Value: " + result); 
     if(result.equals("") || result == null){ 
      Toast.makeText(MainActivity.this, "Server connection failed", Toast.LENGTH_LONG).show(); 
      return; 
     } 
     int jsonResult = returnParsedJsonObject(result); 
     if(jsonResult == 0){ 
      Toast.makeText(MainActivity.this, "Invalid username or password", Toast.LENGTH_LONG).show(); 
      return; 
     } 
     if(jsonResult == 1){ 
      Intent intent = new Intent(MainActivity.this, LoginActivity.class); 
      intent.putExtra("USERNAME", enteredUsername); 
      intent.putExtra("MESSAGE", "You have been successfully login"); 
      startActivity(intent); 
     } 
    } 
    private StringBuilder inputStreamToString(InputStream is) { 
     String rLine = ""; 
     StringBuilder answer = new StringBuilder(); 
     BufferedReader br = new BufferedReader(new InputStreamReader(is)); 
     try { 
      while ((rLine = br.readLine()) != null) { 
       answer.append(rLine); 
      } 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
     return answer; 
    } 
} 
private int returnParsedJsonObject(String result){ 

    JSONObject resultObject = null; 
    int returnedResult = 0; 
    try { 
     resultObject = new JSONObject(result); 
     returnedResult = resultObject.getInt("success"); 
    } catch (JSONException e) { 
     e.printStackTrace(); 
    } 
    return returnedResult; 
} 
} 

user.php的

<?php 

include_once 'db.php'; 

class User{ 

    private $db; 
    private $db_table = "users"; 

    public function __construct(){ 
     $this->db = new DbConnect(); 
    } 

    public function isLoginExist($username, $password){  

     $query = "select * from " . $this->db_table . " where username = '$username' AND password = '$password' Limit 1"; 
     $result = mysqli_query($this->db->getDb(), $query); 
     if(mysqli_num_rows($result) > 0){ 
      mysqli_close($this->db->getDb()); 
      return true; 
     }  
     mysqli_close($this->db->getDb()); 
     return false;  
    } 

    public function createNewRegisterUser($username, $password, $email){ 

     $query = "insert into users (username, password, email, created_at, updated_at) values ('$username', '$password', '$email', NOW(), NOW())"; 
     $inserted = mysqli_query($this->db->getDb(), $query); 
     if($inserted == 1){ 
      $json['success'] = 1;         
     }else{ 
      $json['success'] = 0; 
     } 
     mysqli_close($this->db->getDb()); 
     return $json; 
    } 

    public function loginUsers($username, $password){ 

     $json = array(); 
     $canUserLogin = $this->isLoginExist($username, $password); 
     if($canUserLogin){ 
      $json['success'] = 1; 
     }else{ 
      $json['success'] = 0; 
     } 
     return $json; 
    } 

} 
?> 

的index.php

<?php 

require_once 'androidlogin/user.php'; 

$username = ""; 
$password = ""; 
$email = ""; 
echo "hello"; 
if(isset($_POST['username'])){ 
    $username = $_POST['username']; 
} 
if(isset($_POST['password'])){ 
    $password = $_POST['password']; 
} 
if(isset($_POST['email'])){ 
    $email = $_POST['email']; 
} 

// Instance of a User class 
$userObject = new User(); 

// Registration of new user 
if(!empty($username) && !empty($password) && !empty($email)){ 
    $hashed_password = md5($password); 
    $json_registration = $userObject->createNewRegisterUser($username, $hashed_password, $email); 

    echo json_encode($json_registration); 
} 

// User Login 
if(!empty($username) && !empty($password) && empty($email)){ 
    $hashed_password = md5($password); 
    $json_array = $userObject->loginUsers($username, $hashed_password); 

    echo json_encode($json_array); 
} 

?> 

db.php

<?php 
include_once 'config.php'; 

class DbConnect{ 


    private $connect; 


    public function __construct(){ 

     $this->connect = mysqli_connect(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME); 

     if (mysqli_connect_errno($this->connect)) 
     { 
      echo "Failed to connect to MySQL: " . mysqli_connect_error(); 
     } 
    } 

    public function getDb(){ 

     return $this->connect; 
    } 

} 

回答

0

這很簡單。您不能使用wamp服務器,因爲PHP文件不會暴露給Web。從更簡單的意義上講,您編碼的PHP文件只能在您的PC /筆記本電腦上使用,並且無法通過移動應用程序訪問。如果您正在使用模擬器進行調試,則可能可以進行連接,但是一旦將您的應用程序安裝在實際設備上,就不會連接到服務器。

我建議您選擇以下在線託管服務之一併上傳您在WAMP中創建的文件和數據庫。您將需要明顯更改從上面發佈的代碼連接到的IP地址。這將讓您連接到服務器併成功登錄。有幾個免費的託管服務,其中大部分有99%的正常運行時間。所以你不會有任何連接問題。此類託管服務由awardspace,freewebhostingeu或000webhost提供。這些都可以幫助你完成工作。

改變你可以暴露你的PHP文件到網絡,以便它可以從您的設備訪問。如果安裝了IIS,則可以將網站內容複製到C:\inetpub\www文件夾中。這會將您的網站公開(將其提供給網站)給任何知道該網址的人。您也可以使用this tutorial來幫助您。這個選項是一個更高級的選項,但如果您面臨挑戰,它將幫助您瞭解如何發佈網站。

我在通過PHP返回響應時在代碼中發現了一個問題。您的代碼將返回org.json.JSONException。這是因爲從PHP腳本返回的值不是有效的JSON格式。 (這只是返回你好)因此,在index.php文件,修改的新用戶代碼的註冊過程是這樣:

if(!empty($username) && !empty($password) && !empty($email)){ 
    $hashed_password = md5($password); 
    $json_registration = $userObject->createNewRegisterUser($username, $hashed_password, $email); 
    if ($json_registration) { 

      $response["error"] = FALSE; 
      $response["user"]["name"] = $json_registration["username"]; 
      $response["user"]["email"] = $json_registration["email"]; 

      echo json_encode($response); 
     } else { 

      $response["error"] = TRUE; 
      $response["error_msg"] = "Unknown error occurred in registration!"; 
      echo json_encode($response); 
     } 
} 

這從數據庫返回應用程式返回的實際數據。

你需要做同樣的登錄腳本:

if(!empty($username) && !empty($password) && empty($email)){ 
    $hashed_password = md5($password); 
    $json_login = $userObject->loginUsers($username, $hashed_password); 

    if ($json_login) { 
     $response["error"] = FALSE; 
     $response["uid"] = $user["unique_id"]; 
     $response["user"]["name"] = $json_login["Username"]; 
     $response["user"]["email"] = $json_login["email"]; 
     echo json_encode($response); 
    } else { 
     $response["error"] = TRUE; 
     $response["error_msg"] = "Login credentials are wrong. Please try again!"; 
     echo json_encode($response); 
    } 

} 

我,也可以推薦一些改動你的代碼風格,做一個整潔的項目。

  • 使用不同的文件名不是index.php,只是因爲這是 邊的默認着陸頁。例如,我寧願將它重命名爲 Register.php
  • 拿走代碼從index.php文件登錄並將其添加到 單獨的文件,稱爲Login.php。不要忘記,您需要在此腳本中調用 連接字符串和User.php類,以確保它連接到正確的數據庫。

希望這有助於:)

+0

謝謝你回答我的問題,先生,我會嘗試你的建議:) – indodev28

+0

我已經上傳到主機,現在的問題每次我總是註冊顯示無效的用戶名或密碼或電子郵件。請幫我先生:( – indodev28

+0

請問您可以在這裏包括你的PHP代碼嗎? –