- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在尝试在 android studio 中为我的应用程序创建一个登录系统,但我不断收到此错误
org.json.JSONException: Value Connection of type java.lang.String cannot be converted to JSONArray
并且无法以任何方式修复它,我希望你能发现它并帮助我。这是我认为问题所在的登录 Activity 的一部分(如果需要,我可以提供更多代码)
{StringRequest stringRequest = new StringRequest(Request.Method.POST, login_url,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
try
{
JSONArray jsonArray = new JSONArray(response);
JSONObject jsonObject = jsonArray.getJSONObject(0);
String code = jsonObject.getString("code");
if(code.equals("login_failed"))
{
builder.setTitle("Login Error...");
displayAlert(jsonObject.getString("message"));
}
else
{
Intent intent = new Intent(LoginActivity.this,TestActivity.class);
Bundle bundle = new Bundle();
bundle.putString("email",jsonObject.getString(("email")));
intent.putExtras(bundle);
startActivity(intent);
}
}
catch (JSONException e)
{
e.printStackTrace();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error)
{
Toast.makeText(LoginActivity.this,"Error",Toast.LENGTH_LONG).show();
error.printStackTrace();
}
})
{
@Override
protected Map<String, String> getParams() throws AuthFailureError
{
Map<String,String> params = new HashMap<String, String>();
params.put("email",email);
params.put("password",password);
return params;
}
};
MySingleton.getmInstance(LoginActivity.this).addToRequestQue(stringRequest);
}
这是 PHP 代码:
<?php
require "connection.php";
$email = $_POST["email"];
$password = $_POST["password"];
$sql = "select email,password from user_info where email like '".$email."' and password like '".$password."';";
$result = mysqli_query($connection,$sql);
$response = array();
if(mysqli_num_rows($result)>0)
{
$row = mysqli_fetch_row($result);
$email = $row[0];
$password = $row[1];
$code = "login_success";
array_push($response,array("code"=>$code,"email"=>$email,"password"=>$password));
echo json_encode($response);
}
else
{
$code = "login_failed";
$message = "User not found...";
array_push($response,array("code"=>$code,"message"=>$message));
echo json_encode($response);
}
mysqli_close($connection);
?>
最佳答案
除非该字符串是正确的字符串化 JSON 文件,否则无法从字符串创建 JSONArray。
您必须在 PHP 中将数组转换为 JSON 字符串。 (反之亦然,如果我错误地理解了这种关系,我没有太准确地阅读你的代码)。
另一个解决方案是你使用 jquery 和 ajax 函数来调用 PHP 脚本(我不知道你在创建什么,可能是一个 Cordova 插件,在这种情况下你有 Javascript,否则你必须这样做Java 中类似的东西,谷歌是你的 friend )。
这是直接取 self 自己正在制作的应用程序之一的函数。通读一遍,它可能不是100%可复制粘贴的。重要的部分是,它在将 JavaScript 对象发送到 PHP 函数之前将其转换为正确的 JSON 字符串。
function login(successCallback, errorCallback, args) {
var loginData = {
"username": args[0].username,
"password": args[0].password
};
var dataString = JSON.stringify(loginData);
$.ajax({
url: 'login.php',
method: 'post',
data: {loginData: dataString},
dataType: 'json',
complete: function (data) {
console.log(data.responseText);
},
error: function (xhr, status, errorThrown) {
console.log("Error: " + errorThrown);
console.log("Status: " + status);
errorCallback('Error logging in!');
},
success: function (data) {
if (data.status == "success") {
console.log(data.responseText);
successCallback('Success logging in!');
} else if (data.status = "noConnection") {
console.log(data.responseText);
errorCallback('Could not connect to database.');
} else {
console.log(data.responseText);
errorCallback('Error logging in (but database was connected to)!');
}
}
});
}
关于java - JSONException 字符串无法转换为 JSONArray,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42333206/
我有 7 个协议(protocol),我想在网站上显示。但该网站仅显示 4 个协议(protocol),尽管 JSON 文件中有 7 个协议(protocol)。我决定用调试器检查一下,它通过了 4
我在此代码中遇到 JSON 异常: JSONObject jObject = new JSONObject(JSONString); pontosUsuario.setIdUsuari
我创建了以下价格和移动型号名称的 json 数组。此数据是从表名称为“products”的 wamp phpmyadmin 服务器读取的: { "products": [
我正在从 linkedHashMap 获取 JSON 值 LinkedHashMap lst = JsonPath.parse(json).read("$.projects[0].issuetypes
我正在尝试使用来自 Guardian API 的 JSON 对象。 这是我调用的结果: https://pastebin.com/wqggLEeZ 这是我的代码 JSONObject root = n
我正在尝试从数据库中检索数据。我向此 PHP 文件发送请求: $code, "message"=>$message); echo json_encode($err); }
JSONObject login = new JSONObject(); login.put("Key1", "Value1"); 我只是想用键值对创建一个简单的 JSON 对象。我收到此异常“Unh
我试图解析下面的 json 并在第 150 行(在代码中标记)捕获了 JSONException,但我无法弄清楚为什么会发生。目标是找到特定包的测试列表并将其存储在 arraylist 中。 当我将
我在解析 JSON 时遇到很多问题,其中一个值具有空值。 { "available_from" : "2012-11-05T00:00:00Z", "available_to" : "2012-11-
我有一个带有一些 spring crud 存储库的经典 spring web 应用程序。 我正在尝试以经典的 Angular 形式保存我的实体,但我随机收到此错误: .w.s.m.s.DefaultH
我正在尝试将字符串转换为 JSONObject。这是我的代码: JSONObject obj = new JSONObject(str); Vehicle.feature 文件包含: Scen
@Override protected Integer doInBackground(Void... params) { String readMyJSON = rea
我想解析一些从网上下载的 JSONArray 中的 json。我认为这很简单,但无法让它发挥作用。 看来问题出在 JSON 格式上。我尝试了不同的方法修复它,但没有任何帮助。 我用这种方法下载字符串:
我收到以下错误: JSONException: No value for error 在 Android Studio 中的我的日志(查看日志截图的链接: /image/45eeF.png )上,它说
它可以很好地从数据库读取和写入,但会给出 JSONException 错误。任何帮助将不胜感激! 谢谢 最佳答案 此错误发生在 JSONObject 的 getter 函数中,这意味着您尝试使用 JS
我想从此链接获取json数据:link &这是我的代码: private static String url = "https://graph.facebook.com/fql?q=SELECT%20
描述:在 OnRespose 方法中,我可以在日志中看到从 froecast.io 接收的数据,但是当我传递“response.body().string()”时,即来自 Forecast.io 的数
我正在尝试从此网址中抓取书名:http://api.nytimes.com/svc/books/v2/lists/2010-10-01/trade-fiction-paperback?api-key=
我一直在尝试在 android studio 中为我的应用程序创建一个登录系统,但我不断收到此错误 org.json.JSONException: Value Connection of type j
我有一个 iOS 应用程序和一个 Android 应用程序,可以使用 RESTFul Web 服务。 当我向服务进行查询时,我得到一个像这样返回的 JSON 对象。 [ { "
我是一名优秀的程序员,十分优秀!