我尝试了所有在此处找到的解决方案,但似乎没有任何与我一起工作。我是Android新手,这是我的问题。将数组传递给带有JSON的Android应用程序
我有这个PHP脚本获取MySQL数据,并将其传递到一个数组
<?php
$con = mysqli_connect("localhost", "username", "passwod", "database");
$result = array();
$getacceptedsotres = mysqli_query($con, "SELECT * FROM offer WHERE
type='sale' AND approved = 'approved'");
while($rowgetid = mysqli_fetch_assoc($getacceptedsotres)){
$storeid = $rowgetid['id'];
$getstores = mysqli_query($con, "SELECT * FROM sale WHERE offerid =
'$storeid' ");
while($row = mysqli_fetch_assoc($getstores)){
array_push($result,array(
'title'=>$row['title'],
'offerto' => $rowgetid['offerto'],
'type' => $rowgetid['type'],
'percentageoff'=>$row['percentageoff']
));
}
}
echo json_encode(array($result));
当PHP脚本执行的时候给了我这样的:
[[{ “称号”: “所有饮料40%优惠”,“有效”:“06/29 /2016”,“type”:“sale”,“percentageoff”:“40%”},{“title”:“30% selected> items“,”offerto“:”07/31/2016“,”type“:”sale“,”percentageoff“:”30%“}, {”title“:”45%off on selected items“, “offerto”:“07/08 /2016”,“type”:“sale “,”percentageoff“:”45“}]]
我的问题是当我想要将此结果传递到android studio中的列表。
这是
公共类销售扩展AppCompatActivity实现AsyncResponse {
private ArrayList<GetSale> saleList;
private ListView lvSale;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sale);
ImageLoader.getInstance().init(UILConfig.config(Sale.this));
PostResponseAsyncTask taskRead = new PostResponseAsyncTask(Sale.this, this);
taskRead.execute("http://....php");
}
@Override
public void processFinish(String s) {
saleList = new JsonConverter<GetSale>().toArrayList(s, GetSale.class);
BindDictionary<GetSale> dict = new BindDictionary<GetSale>();
dict.addStringField(R.id.tvSaleAmount, new StringExtractor<GetSale>() {
@Override
public String getStringValue(GetSale getSale, int position) {
return getSale.title;
}
});
dict.addStringField(R.id.tvType, new StringExtractor<GetSale>() {
@Override
public String getStringValue(GetSale getSale, int position) {
return getSale.type;
}
});
FunDapter<GetSale> adapter = new FunDapter<>(
Sale.this, saleList, R.layout.layout_sale, dict);
lvSale = (ListView)findViewById(R.id.lvSale);
lvSale.setAdapter(adapter);
}
}
所以,当我运行应用程序并尝试列出的结果我在我的课堂上使用的代码m从我的PHP脚本得到我在Android工作室得到这个长的错误,但我认为这是导致错误的主线
>06-10 17:34:17.262 28516-28516/com.example.W/System.err:
>com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected
>BEGIN_OBJECT but was BEGIN_ARRAY at line 1 column 3
>06-10 17:34:17.262 28516-28516/com.example.W/System.err: at
>com.google.gson.internal.bind.ReflectiveTypeAdapterFactory$Adapter.read(Reflect>iveTypeAdapterFactory.java:176)
>06-10 17:34:17.262 28516-28516/com.example.W/System.err: at
>com.google.gson.internal.bind.TypeAdapterRuntimeTypeWrapper.read(TypeAdapterRun>timeTypeWrapper.java:40)
>.
>.
>.
>06-10 17:34:17.272 28516-28516/com.example.W/System.err: ... 21 more
>06-10 17:34:17.282 28516-28516/com.example.E/ViewRootImpl: >sendUserActionEvent() mView == null
任何帮助,将不胜感激。 预先感谢您
在您的PHP代码中将'echo json_encode(array($ result));'改为'echo json_encode($ result);'。 –
@PrerakSola omg它的工作..我有一个不同的数组类型,它不与echo json_encode($结果);但我改变了阵列,忘了再次尝试这个回声谢谢 –
高兴地帮助.. :) –