org.json.jsonexception在字符1的输入结束

时间:2022-10-29 14:33:45

hi i am trying to check the username and password from mysql database, where i inserted my password using md5() hashing now i wanna access this username, password. i am getting

嗨我想从mysql数据库检查用户名和密码,我用md5()哈希插入我的密码现在我想访问这个用户名,密码。我正进入(状态

"org.json.jsonexception end of input at character 1 of"

“org.json.jsonexception在字符1的输入结束时”

error.

this is my php code.

这是我的PHP代码。

    <?php
error_reporting(E_ALL^E_NOTICE^E_WARNING);
$dbhost="localhost";
$dbuser="dev";
$dbpass="dev";
$dbdb="myandroid";
$connect =mysql_connect($dbhost,$dbuser,$dbpass) or die("connection error");
mysql_select_db($dbdb) or die("database selection error");
$username=$_POST["username"];
$password=$_POST["password"];
$pass=md5('$password');
$query=mysql_query("SELECT * FROM androidtable WHERE username='$username' AND password='$pass'")or die(mysql_error());

$num=mysql_num_rows($query);
if($num==1){
while($list=mysql_fetch_assoc($query)){
$output=$list;
echo json_encode($output);
}
mysql_close();
}
?>

the android code

android代码

public class DBActivity extends Activity implements OnClickListener{
EditText eduser, edpass;
Button logbutton;

String username, password;

HttpClient httpclient;

HttpPost httppost;

ArrayList<NameValuePair> nameValuePair;

HttpResponse httpresponse;
HttpEntity httpentity;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_db);
    initialise();


}

private void initialise() {
    eduser=(EditText) findViewById(R.id.eduser);
    edpass=(EditText) findViewById(R.id.edpass);
    logbutton=(Button) findViewById(R.id.login);
    logbutton.setOnClickListener(this); 

}

public void onClick(View v) {
    httpclient=new DefaultHttpClient();

    httppost=new HttpPost("http://192.168.1.2/androidtut/check.php");
    username=eduser.getText().toString();
    password=edpass.getText().toString();



    try{
        nameValuePair=new ArrayList<NameValuePair>();

        nameValuePair.add(new BasicNameValuePair("username", username));
        nameValuePair.add(new BasicNameValuePair("password", password));

        httppost.setEntity(new UrlEncodedFormEntity(nameValuePair));
        httpresponse=httpclient.execute(httppost);
        if(httpresponse.getStatusLine().getStatusCode()==200){
            httpentity=httpresponse.getEntity();
            if(httpentity != null){
                InputStream is=httpentity.getContent();
                JSONObject jresp=new JSONObject(convertStreamToString(is));

                String retUser=jresp.getString("username");
                String retPass=jresp.getString("password");

                if(username.equals(retUser) && password.equals(retPass)){

                    SharedPreferences sp=getSharedPreferences("tableandroid",0);
                    SharedPreferences.Editor spedit=sp.edit();
                    spedit.putString("username", username);
                    spedit.putString("password", password);
                    spedit.commit();

                    Toast.makeText(getBaseContext(), "loggin success",Toast.LENGTH_LONG).show();
                }else{
                    Toast.makeText(getBaseContext(), "user invalid",Toast.LENGTH_LONG).show();
                }

            }
        }

    }catch(Exception e){
        String error=e.toString();
        Toast.makeText(getBaseContext(), error,Toast.LENGTH_LONG).show();
    }


}

private static String convertStreamToString(InputStream is) {
    /*
     * To convert the InputStream to String we use the BufferedReader.readLine()
     * method. We iterate until the BufferedReader return null which means
     * there's no more data to read. Each line will appended to a StringBuilder
     * and returned as String.
     */
    BufferedReader reader = new BufferedReader(new InputStreamReader(is));
    StringBuilder sb = new StringBuilder();

    String line = null;
    try {
        while ((line = reader.readLine()) != null) {
            sb.append(line + "\n");
        }
    } catch (IOException e) {
        e.printStackTrace();
    } finally {
        try {
            is.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    return sb.toString();
}

}

1 个解决方案

#1


0  

Your server isn't returning anything. So your Android client has nothing to marshall.

您的服务器没有返回任何内容。因此,您的Android客户端无需编组。

$pass=md5('$password');

Isn't hashing the password, but the $password string literal instead (single quotes don't expand variables). Use the following instead:

不是哈希密码,而是$ password字符串文字(单引号不扩展变量)。请改用以下内容:

$pass=md5($password);

#1


0  

Your server isn't returning anything. So your Android client has nothing to marshall.

您的服务器没有返回任何内容。因此,您的Android客户端无需编组。

$pass=md5('$password');

Isn't hashing the password, but the $password string literal instead (single quotes don't expand variables). Use the following instead:

不是哈希密码,而是$ password字符串文字(单引号不扩展变量)。请改用以下内容:

$pass=md5($password);