- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个 Android 应用程序,它连接到远程 MYSQL 数据库并通过 JSON 数据检索信息。我遇到问题的应用程序部分涉及通过 userID
进行搜索在应用程序中,并从数据库返回关联的用户信息,例如 ID、名字、公司和职位。
问题在于解析应用程序内的 JSON 数据。我收到的错误消息是 System.err: org.json.JSONException: No value for id
。
php页面显示JSON数据。输出两个 JSON 对象:a success
对象和一个result
目的。 success
对象由应用程序正确解析,并通过 if 语句告诉应用程序要做什么。所以if success == 1
,应用程序执行一段应该解析 result
的代码块。对象并将数组的每个元素分配给 String
应用程序中的值(value)。 php 页面的输出是:
{"success":1,"message":"UserID found!"}{"result":[{"id":"1100011","firstname":"Kevin","company":"company","position":"bartender"}]}
问题是 results
中的值应用程序未解析对象。这是 php 页面:
<?php
define('HOST','localhost');
define('USER','********');
define('PASS','**********');
define('DB','**********');
if (!empty($_POST)){
if (empty($_POST['userID'])){
$response["success"] = 0;
$response["message"] = "Please enter a User ID";
die(json_encode($response));
}
$userID = mysql_escape_string($_POST['userID']);
$con = mysqli_connect(HOST,USER,PASS,DB);
$sql = "SELECT * FROM users WHERE id = $userID";
$res = mysqli_query($con,$sql);
$result = array();
while($row = mysqli_fetch_array($res)){
array_push($result, array(
'id'=>$row[0],
'firstname'=>$row[4],
'company'=>$row[6],
'position'=>$row[7],
)
);
}
if($result){
$response["success"] = 1;
$response["message"] = "UserID found!";
echo json_encode($response); // if I comment out this line, the result array gets parsed properly by the app.
echo json_encode(array("result"=>$result));
}else{
$response["success"] = 0;
$response["message"] = "UserID not found. Please try again.";
die(json_encode($response));
}
mysqli_close($con);
} else {
?>
<h1>Search by User ID:</h1>
<form action="searchbyuserid.php" method="post">
Enter the UserID of the receipient:<br />
<input type="text" name="userID" placeholder="User ID" />
<br /><br />
<input type="submit" value="Submit" />
</form>
<a href="register.php">Register</a>
<?php
}
?>
如果我注释掉上面提到的行,应用程序的日志将显示应用程序为 results
解析的正确数据。数组:
D/UserID Lookup:: {"result":[{"id":"1100011","firstname":"Kevin","company":"company","position":"bartender"}]}
,但随后我收到 W/System.err: org.json.JSONException: No value for success
的错误因为success
没有被发送(显然)。
这是我的 Android 代码:
import android.app.ProgressDialog; ...
public class SearchByUserID extends ActionBarActivity implements View.OnClickListener {
// Buttons
private Button mSubmitButton, mBackButton;
// EditText Field
EditText enterUserID;
// Progress Dialog
private ProgressDialog pDialog;
// JSON parser class
JSONParser jsonParser = new JSONParser();
// Variable for holding URL:
private static final String LOGIN_URL = "http://www.***********/webservice/searchbyuserid.php";
//JSON element ids from response of php script:
private static final String TAG_SUCCESS = "success";
private static final String TAG_MESSAGE = "message";
private static final String TAG_USERID = "id";
private static final String TAG_FIRSTNAME = "firstname";
private static final String TAG_COMPANY = "company";
private static final String TAG_POSITION = "POSITION";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.search_by_user_id_layout);
mSubmitButton = (Button)findViewById(R.id.submit);
mBackButton = (Button)findViewById(R.id.back);
mSubmitButton.setOnClickListener(this);
mBackButton.setOnClickListener(this);
enterUserID = (EditText)findViewById(R.id.enterUserIdNumber);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.submit:
new SearchUserId().execute();
break;
case R.id.back:
finish();
break;
default:
break;
}
}
class SearchUserId extends AsyncTask<String, String, String> {
// Show progress dialog
boolean failure = false;
@Override
protected void onPreExecute() {
super.onPreExecute();
pDialog = new ProgressDialog(SearchByUserID.this);
pDialog.setMessage("Searching User ID...");
pDialog.setIndeterminate(false);
pDialog.setCancelable(true);
pDialog.show();
}
@Override
protected String doInBackground(String... args) {
// Check for success tag
int success;
String userID = enterUserID.getText().toString();
try {
// Building Parameters
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("userID", userID));
Log.d("UserID:", userID);
Log.d("request!", "starting");
JSONObject json = jsonParser.makeHttpRequest(LOGIN_URL, "POST", params);
// check your log for json response
Log.d("UserID Lookup:", json.toString());
// json success tag
success = json.getInt(TAG_SUCCESS);
if (success == 1) {
JSONObject json2 = jsonParser.makeHttpRequest(LOGIN_URL, "POST", params);
String userid = json2.getString(TAG_USERID);
String firstName = json2.getString(TAG_FIRSTNAME);
String company = json2.getString(TAG_COMPANY);
String position = json2.getString(TAG_POSITION);
Log.d("User ID Found!", json.toString());
Log.d("userid:", userid);
Log.d("firstName:", firstName);
Log.d("company:", company);
Log.d("position:", position);
Intent i = new Intent(SearchByUserID.this, HomeActivity.class);
finish();
startActivity(i);
return json.getString(TAG_MESSAGE);
}else{
Log.d("User ID not found.", json.getString(TAG_MESSAGE));
return json.getString(TAG_MESSAGE);
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
/**
* After completing background task Dismiss the progress dialog
* **/
protected void onPostExecute(String file_url) {
// dismiss the dialog once product deleted
pDialog.dismiss();
if (file_url != null){
Toast.makeText(SearchByUserID.this, file_url, Toast.LENGTH_LONG).show();
}
}
}
}
所以基本上我能够正确解析 success
对象或 results
对象,但不是两者。如果我尝试解析两者,则会收到 no value for id
的 JSON 错误。 。
最佳答案
JSONObject json2 = jsonParser.makeHttpRequest(LOGIN_URL, "POST", params);
JSONArray jsArray = json2.getJSONArray("result");
String usrid = jsArray.getJSONObject("id");
String firstName = jsArray.getJSONObject("firstname");
String company = jsArray.getJSONObject("company");
String position = jsArray.getJSONObject("position");
尝试将您的代码转换为此。
关于php - 需要帮助将 JSON 数据从 MYSQL 数据库获取到 Android 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39714573/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!