FATAL EXCEPTION: main
Process: ---, PID: 26657
java.lang.NumberFormatException: Invalid int: "12"
这是我遇到的异常,我不知道,为什么,因为12似乎是一个正常的整数,我之前没有遇到过这个问题。它刚刚开始,我甚至没有触及有关的活动。我甚至检查引号是否是字符串的一部分,但它们不是。为什么这不起作用。以下是上下文:
AsyncTask<Uri, Void, Void> asyncTask = new AsyncTask<Uri, Void, Void>() {
@Override
protected void onPreExecute() {
super.onPreExecute();
loginButtonLayout.setVisibility(View.GONE);
bar.setVisibility(View.VISIBLE);
}
@Override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
ans = ans.replace(" ", "");
ans = ans.replace("\"", "");
Log.d("test2", ans);
if (!(ans.equals("false")) || !(ans.equals(""))) {
ans = ans.replace("\"", "");
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
SharedPreferences.Editor editor = (getBaseContext().getSharedPreferences("USER_DATA", Context.MODE_PRIVATE)).edit();
editor.putBoolean("login", true);
int fahrer = Integer.parseInt(ans);
editor.putInt("fahrerId", fahrer);
editor.clear().apply();
((Alpacar) getApplication()).setLoginState(true);
((Alpacar) getApplication()).setFahrerId(Integer.parseInt(ans));
Toast.makeText(getBaseContext(), "Login successful", Toast.LENGTH_LONG).show();
finish();
startActivity(intent);
} else {
Toast.makeText(getBaseContext(), "Login failed", Toast.LENGTH_LONG).show();
}
}
@Override
protected Void doInBackground(Uri... uris) {
URL url;
url = null;
try {
url = new URL(uri.toString());
} catch (MalformedURLException e) {
e.printStackTrace();
}
if (url == null) {
Log.e("MainActivity.java", "Error creating URL");
return null;
}
// new try
HttpURLConnection urlConnection = null;
InputStream inputStream = null;
try {
urlConnection = (HttpURLConnection) url.openConnection();
urlConnection.setReadTimeout(10000 /* milliseconds */);
urlConnection.setConnectTimeout(15000 /* milliseconds */);
urlConnection.setRequestMethod("GET");
urlConnection.connect();
if (urlConnection.getResponseCode() == 200) {
inputStream = urlConnection.getInputStream();
ans = readFromStream(inputStream);
Log.d("test", ans);
} else {
Log.e("QueryUtils", "Error response code: " + urlConnection.getResponseCode());
}
} catch (ProtocolException e) {
Log.e("QueryUtils", "Problem with the protocol", e);
} catch (IOException e) {
Log.e("QueryUtils", "Problem establishing the connection", e);
} finally {
if (urlConnection != null) {
urlConnection.disconnect();
}
}
return null;
}
};
onPostExecute ...
出现问题答案 0 :(得分:1)
您的数据在&#34; 12&#34;之前包含UTF8 BOM字节ef bb bf
。它们不会在logcat中明显打印出来。 (您可以通过将异常消息粘贴到hexdump来检查。)这些字节将转换搞砸为整数。
修复发出该值的代码,或者使代码删除BOM字节。例如,请参阅Byte order mark screws up file reading in Java
答案 1 :(得分:0)
尝试使用Integer.valueOf(ans.toString())