СоХабр закрыт.
С 13.05.2019 изменения постов больше не отслеживаются, и новые посты не сохраняются.
<?php
// *** Я для наглядности решил взять константы в пример для данных для подключения***
define('HOST_DBNAME','mysql:host=localhost;dbname=andro');
define('USERNAME','root');
define('PASSWORD','password');
define('JSON_OBJECTS','product');
try {
// *** Определяем PDO объект для работы с БД ***
$db = new PDO(HOST_DBNAME,USERNAME,PASSWORD);
// *** Подготавливаем SQL запрос ***
$stmt = $db->prepare("SELECT * FROM `products`");
// *** Выводим результат выполнения запроса ***
if($stmt->execute()) {
// *** Массив для дальнейшего преобразования в JSON ***
$arrToJSON = Array();
// *** Заполняем наш массив для дальнейшего преобразования в JSON ***
while($row = $stmt->fetch()) {
$arrToJSON[JSON_OBJECTS][] = $row;
}
// *** Выводим построенный JSON код для дальнейшей работы с ним в приложении ***
print json_encode($arrToJSON);
// *** Закрываем соединение ***
$db = null;
// *** Если где-то произошла ошибка выводим её ***
} catch (PDOException $e) {
print "ERROR WITH PDO >> \n ".$e->getMessage();
}
?>
<form action="" method="get">
Название: <input type="text" name="title" /><br>
Описание: <input type="text" name="short" /><br>
Цена: <input type="text" name="price" /><br>
<input type="hidden" name="add" value="yes" />
<input type="submit" value="Добавить запись" />
</form>
<?php
// *** Если данные с новым продуктом пришли то выполняем скрипт добавления ***
if($_GET["add"] == "yes") {
// *** Как всегда расставляем все точки над ё ***
define('HOST_DBNAME','mysql:host=localhost;dbname=andro');
define('USERNAME','root');
define('PASSWORD','password');
try {
// *** Определяем объект PDO и тем самым подключаемся к нашей БД ***
$db = PDO(HOST_DBNAME,USERNAME,PASSWORD);
// *** Подготавливаем SQL запрос ***
$stmt = $db->prepare('INSERT INTO `products` AS p (p.`title`,p.`short`,p.`price`) VALUES (?,?,?)');
// *** Выполняем запрос и проверяем его выполнение ***
if($stmt->execute(Array($_GET['title'],$_GET['short'],$_GET['price']))) {
// *** Если запрос прошел ***
print 'SUCCESFULL. A new product create!';
} else {
// *** Если ничего не получилось и в catch ***
print 'ERROR: A product not are create! Please try again';
}
// *** Закрываем соединение и чистим $db ***
$db = null;
// *** Если появилась ошибка ***
} catch(PDOException $e) {
print "ERROR WITH PDO >> \n ".$e->getMessage;
}
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<ListView
android:id="@+id/listView1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_marginLeft="19dp"
android:layout_marginTop="15dp" >
</ListView>
</RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="10dp"
android:paddingLeft="10dp"
android:paddingRight="10dp" >
<!-- Поле названия-->
<TextView
android:id="@+id/name"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="2dip"
android:paddingTop="6dip"
android:textColor="#43bd00"
android:textSize="16sp"
android:textStyle="bold" />
<!-- Поле описание -->
<TextView
android:id="@+id/short"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="2dip"
android:textColor="#acacac" />
<!-- Поле цены -->
<TextView
android:id="@+id/price"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="0dip"
android:textColor="#acacac" />
</LinearLayout>
package com.example.andromysql; //подключаем наш проект
//Подключаем библиотеки нужные для работы нашего нового класса
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.List;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.utils.URLEncodedUtils;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
public class ServiceHandler {
static String response = null;
public final static int GET = 1;
public final static int POST = 2;
public ServiceHandler() {
}
/**
* Making service call
* @url - ссылка на запрос
* @method - http метод для получения значений
* */
public String makeServiceCall(String url, int method) {
return this.makeServiceCall(url, method, null);
}
/**
* Making service call
* @url - url для запроса
* @method - http метод для получения значений
* @params - http параметры
* */
public String makeServiceCall(String url, int method,
List<NameValuePair> params) {
try {
//Клиент HTTP
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpEntity httpEntity = null;
HttpResponse httpResponse = null;
// Проверяем HTTP на метод POST
if (method == POST) {
HttpPost httpPost = new HttpPost(url);
// добавляем параметры
if (params != null) {
httpPost.setEntity(new UrlEncodedFormEntity(params));
}
httpResponse = httpClient.execute(httpPost);
} else if (method == GET) {
// конкатерируем параметры к URL
if (params != null) {
String paramString = URLEncodedUtils
.format(params, "utf-8");
url += "?" + paramString;
}
HttpGet httpGet = new HttpGet(url);
httpResponse = httpClient.execute(httpGet);
}
httpEntity = httpResponse.getEntity();
response = EntityUtils.toString(httpEntity);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return response;
}
}
package com.example.andromysql;
//Подключаем нужные библиотеки
import java.util.ArrayList;
import java.util.HashMap;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import android.app.ListActivity;
import android.app.ProgressDialog;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
public class MainActivity extends ListActivity {
private ProgressDialog pDialog;
// URL где хранится наш отформатированный JSON
private static String url = "http://www.develsi.com/view.php"; // поменяйте значение на свое
// JSON Теги, чтобы в будущем оброщаться в методах
private static final String TAG_PRODUCTS = "products";
private static final String TAG_ID = "id_product";
private static final String TAG_NAME = "title";
private static final String TAG_SHORT = "short";
private static final String TAG_PRICE = "price";
// JSONArray - тип данных : массив из JSON строки
JSONArray products = null;
// Hashmap для ListView
ArrayList<HashMap<String, String>> productList;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
productList = new ArrayList<HashMap<String, String>>();
ListView lv = getListView();
// Вызываем асинхронное получение JSON
new GetProducts().execute();
}
/**
* Асинхронный класс для получения JSON строки с HTTP страницы
* */
private class GetProducts extends AsyncTask<Void, Void, Void> {
@Override
protected void onPreExecute() {
super.onPreExecute();
// Показываем диалог загрузки на время получения данных
pDialog = new ProgressDialog(MainActivity.this);
pDialog.setMessage("Загрузка...");
pDialog.setCancelable(false);
pDialog.show();
}
@Override
protected Void doInBackground(Void... arg0) {
// Создаем экземпляр класса ServiceHandler
ServiceHandler sh = new ServiceHandler();
// Делаем запрос на наш url и получаем ответ в переменную типа String sh
String jsonStr = sh.makeServiceCall(url, ServiceHandler.GET);
Log.d("Response: ", "> " + jsonStr);// Выводим в консоль результат, то что пришло с сервера
//Лучше читать, что именно пришло, так как бывают ошибки из-за лишних символов, пробел и перенос строки - это тоже символ.
if (jsonStr != null) { //Проверяем не пустой ли нам пришел ответ
try {
JSONObject jsonObj = new JSONObject(jsonStr); // Создаем переменную типа JSONObject
// Получаем массив продуктов из нашего объекта
products = jsonObj.getJSONArray(TAG_PRODUCTS);
// Проходим по всем продуктом циклом, для создания ассоциативного массива
for (int i = 0; i < products.length(); i++) {
JSONObject p = products.getJSONObject(i);
//Создаем некоторые переменные для дальнейшей работы
String id = p.getString(TAG_ID); // достаем номер продукта
String name = p.getString(TAG_NAME); //достаем название продукта
String email = p.getString(TAG_SHORT); //достаем описание продукта
String address = p.getString(TAG_PRICE); //достаем цену продукта
// Временная переменная hashmap для одиночной записи продукта
HashMap<String, String> product = new HashMap<String, String>();
// Добовляем значения в наш HashMap в виде key => value
product.put(TAG_ID, id);
product.put(TAG_NAME, name);
product.put(TAG_EMAIL, email);
// Добовляем продукты в наш лист продуктов
productList.add(product);
}
} catch (JSONException e) {
e.printStackTrace();
}
} else {
Log.e("ServiceHandler", "Не удалось получить никаких данных из адреса");
}
return null;
}
@Override
protected void onPostExecute(Void result) {
super.onPostExecute(result);
// Закрываем наш диалог загрузки
if (pDialog.isShowing())
pDialog.dismiss();
/**
* Обновляем запарсенные данные JSON в наш ListView
* */
ListAdapter adapter = new SimpleAdapter(
MainActivity.this, producttList,
R.layout.list_item, new String[] { TAG_NAME, TAG_SHORT }, new int[] { R.id.name,
R.id.short});
// Я не стал использовать в примере еще 2 переменные так как мне это не нужно на данный момент, но если вы желаете включить их в показ, то просто добавьте строку TAG_PRICE в new String[] {...} и R.id.price в new int[] {...}
setListAdapter(adapter); // Теперь через адаптер добовляем наш получившийся массив в ListView
}
}
}
комментарии (30)