我检查并确保谷歌放置android的API已启用。Android Java谷歌地点GET(拉)评论JSONException对评论没有任何评论
起初我使用这个网址:
https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=34.0467359,-118.441764&radius=1000&sensor=true&key=YOUR_PLACE_API_KEY
,并切换到这一点:
https://maps.googleapis.com/maps/api/place/details/json? reference=REFERENCE_STRING_OF_THE_PLACE&sensor=true&key=YOUR_PLACE_API_KEY
按照建议在
Android - Google Places API - No "reviews" Array
,但仍然得到了同样的错误。
在https://developers.google.com/places/web-service/details
有人指出,参考已被废弃,现在我们必须使用place_id。我改变了网址为:
https://maps.googleapis.com/maps/api/place/details/json?placeid=ChIJN1t_tDeuEmsRUsoyG83frY4&key=YOUR_API_KEY
后来我读到了stackoverflow,在2012年谷歌地方的API没有功能来拉评语。这适用于现在吗? 2016年?如果没有,请帮我在我的代码下面解释我做错了什么。
如果我复制并粘贴任何上述网址的日志输出,评论显示在我的浏览器中,但响应中的输出不显示网址。
我收到此错误:
W/System.err: org.json.JSONException: No value for reviews
W/System.err: at org.json.JSONObject.get(JSONObject.java:389)
W/System.err: at org.json.JSONObject.getJSONArray(JSONObject.java:584)
W/System.err: at DownloadReviewsTask.doInBackground(DownloadReviewsTask.java:69)
W/System.err: at DownloadReviewsTask.doInBackground(DownloadReviewsTask.java:19)
W/System.err: at android.os.AsyncTask$2.call(AsyncTask.java:292)
W/System.err: at java.util.concurrent.FutureTask.run(FutureTask.java:237)
W/System.err: at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
W/System.err: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
W/System.err: at java.lang.Thread.run(Thread.java:818)
这是我下面的代码:
public class JSONParser {
String charset = "UTF-8";
HttpURLConnection conn;
DataOutputStream wr;
StringBuilder result = new StringBuilder();
URL urlObj;
JSONObject jObj = null;
StringBuilder sbParams;
String paramsString;
public JSONObject makeHttpRequest(String url, String method,
HashMap<String, String> params) {
sbParams = new StringBuilder();
int i = 0;
for (String key : params.keySet()) {
try {
if (i != 0){
sbParams.append("&");
}
sbParams.append(key).append("=")
.append(URLEncoder.encode(params.get(key), charset));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
i++;
}
if (method.equals("POST")) {
// request method is POST
try {
urlObj = new URL(url);
conn = (HttpURLConnection) urlObj.openConnection();
conn.setDoOutput(true);
conn.setRequestMethod("POST");
conn.setRequestProperty("Accept-Charset", charset);
conn.setReadTimeout(90000);
conn.setConnectTimeout(90000);
conn.connect();
paramsString = sbParams.toString();
wr = new DataOutputStream(conn.getOutputStream());
wr.writeBytes(paramsString);
wr.flush();
wr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
else if(method.equals("GET")){
// request method is GET
if (sbParams.length() != 0) {
url += "?" + sbParams.toString();
}
try {
urlObj = new URL(url);
conn = (HttpURLConnection) urlObj.openConnection();
conn.setDoOutput(false);
conn.setRequestMethod("GET");
conn.setRequestProperty("Accept-Charset", charset);
conn.setConnectTimeout(90000);
conn.connect();
} catch (IOException e) {
e.printStackTrace();
}
}
try {
//Receive the response from the server
InputStream in = new BufferedInputStream(conn.getInputStream());
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String line;
while ((line = reader.readLine()) != null) {
result.append(line);
}
Log.d("JSON Parser", "result: " + result.toString());
} catch (IOException e) {
e.printStackTrace();
}
conn.disconnect();
// try parse the string to a JSON object
try {
jObj = new JSONObject(result.toString());
} catch (JSONException e) {
Log.e("JSON Parser", "Error parsing data " + e.toString());
}
// return JSON Object
return jObj;
}
}
public class DownloadReviewsTask extends AsyncTask<String, Void, HashMap<String, List<MyModel>>> {
//Declarations
private Context mContext;
public Exception mException;
private OnEventListener<HashMap<String, List<MyModel>>> mCallBack;
JSONArray reviews;
String author_name;
String text;
//Constructor
public DownloadReviewsTask(Context context, OnEventListener callback) {
mCallBack = callback;
mContext = context;
}
//sets and passes the review author and text for each review and sets them in the My Model
public MyModel setPlace(JSONObject thisObject) throws JSONException {
JSONObject results = thisObject.getJSONObject("results");
MyModel thisMyModel = new MyModel();
if (!results.isNull("reviews")) {
reviews = results.getJSONArray("reviews");
Log.e("reviews array setPlace", String.valueOf(reviews));
for (int i = 0; i < reviews.length(); i++) {
//if(i==reviews.length()) break;
// if (thisObject.getJSONArray("reviews").getJSONObject(i).has("author_name")) //{
author_name = results.getJSONArray("reviews").getJSONObject(i).getString("author_name");//reviews.getJSONObject(i).getString("author");
Log.e("review_author in setup", results.getJSONArray("reviews").getJSONObject(i).getString("author_name"));
// }
//if (thisObject.getJSONArray("reviews").getJSONObject(i).has("text")) {
Log.e("review text in setup", results.getJSONArray("reviews").getJSONObject(i).getString("text"));
text = results.getJSONArray("reviews").getJSONObject(i).getString("text");//}
thisMyModel.setAuthor_name(author_name);
thisMyModel.setText(text);
}
}
return thisMyModel;
}
@Override
protected HashMap<String, List<MyModel>> doInBackground(String... args) {
try {
JSONParser jsonParser = new JSONParser();
JSONObject json;
String reviewUrl = args[0];
Log.e("reviewUrl",reviewUrl);
//Use a HashMap instead with the varargs:
HashMap<String, String> params = new HashMap<>();
json = jsonParser.makeHttpRequest(reviewUrl, "GET", params);
HashMap<String, List<MyModel>> myResults = new HashMap<>();
if(json != null) {
Log.e("reviews result", json.toString());
JSONArray parentArray = json.getJSONArray("reviews");
List<MyModel> allEventsList = new ArrayList<>();
//loops through json array
for (int i = 0; i < parentArray.length(); i++) {
JSONObject finalObject = parentArray.getJSONObject(i);
allEventsList.add(setPlace(finalObject));
Log.e("allEventsList", String.valueOf(allEventsList));
}
myResults.put("reviews", allEventsList);
Log.e("myResults",String.valueOf(myResults));
return myResults;
}else{
return null;
}
}
catch (JSONException e){
e.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(HashMap<String, List<MyModel>> result) {
if (mCallBack != null) {
if (mException == null) {
mCallBack.onSuccess(result);
} else {
mCallBack.onFailure(mException);
}
}
}
}
public class MyModel{
private String reference;
public void setReference(String reference) {
this.reference = reference;
}
public String getReference() {
return reference;
}
}
public class MainActivity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
String reviewsUrl = "https://maps.googleapis.com/maps/api/place/details/json?reference="+reference+sensor+key;
DownloadReviewsTask rev = new DownloadReviewsTask(this, new OnEventListener<HashMap<String, List<MyModel>>>() {
@Override
public void onSuccess(HashMap<String, List<MyModel>> result) {
if(result != null && result.size() > 0) {
for (int i = 0; i < result.size(); i++){
Log.e("review SingleVewInit",result.get("reviews").get(0).getAuthor_name());
Log.e("review SingleVewInit",result.get("reviews").get(0).getText());
}
}
}
@Override
public void onFailure(Exception e) {
//Toast.makeText(this, "ERROR: " + e.getMessage(), Toast.LENGTH_LONG).show();
Log.e("ERROR: " ,e.getMessage());
}
});
rev.execute(reviewsUrl);
}
}
我认为你只能获得评论,但仍不可能提交评论。因为在这种情况下,每个人都可以自动发送的评论和@Hrabosch代码是拉(GET)的评论,而不是张贴评论评论将失去其严重性 – Hrabosch
。通过在Android应用程序中显示,我的意思是把拉动的评论放在textView中。上面的代码不会生成评论。它们已经存在于谷歌 – iOSAndroidWindowsMobileAppsDev
@Hrabosch如果你有,你觉得这份工作的,即得到谷歌的评论相当不错的Android的Java代码,请随意张贴它的答案。也许我错了 – iOSAndroidWindowsMobileAppsDev