【问题标题】:What kind of method to storage data on Android learn applicationAndroid学习应用程序上存储数据的方法有哪些
【发布时间】:2016-06-11 04:26:59
【问题描述】:

我将编写一个允许学习语言编程的 android 应用程序。一个例子,它是 PHP: 我的应用程序将有两个功能:

使用函数 A,我为每篇文章创建 html 页面,将 html 页面存储在项目中,然后通过 webview 显示它,如下所示:

webView.loadUrl("file:///android_asset/" + value);

注意:值是保存在asset文件夹中的html文件。

对于功能 B,有很多问题和答案。创建html文件太长了。我考虑过 XML 或 JSON 格式。这样做合适吗?您还有其他更好的解决方案吗?

p/s: 抱歉标签,我不能完全用我的声誉做标签。

【问题讨论】:

  • 为什么创建一个 HTML 文件太长了? HTML 文件有限制吗?
  • @user3793589:如果我有100个问题和答案,创建html文件需要很长时间吗?我会遇到一些未知的内存问题。
  • 所以基本上你正在创建一个网站,并在应用程序中显示它。这可能看起来不太好,或者真的看起来像一个 Android 应用程序!我的建议是忘记 HTML,为你的课程考虑真正的设计指南(章节、标题、标题......),然后创建你自己的格式来存储这些结构化内容(我会使用 sqlite 或 Json,压缩) .如果你做对了,外观和感觉会更好!
  • 看起来你只需要一个 ExpandableListView。您正在尝试编写 Android 应用程序,而不是 Web 应用程序
  • @kidsoul,这些问题目前存储在哪里?

标签: android html json xml display


【解决方案1】:

基于:
Home » Android JSON Parsing – Retrieve From MySQL Database Android JSON Parsing
从 2015 年 4 月 20 日起,作者 Belal Khan

您可以将数据存储在 MySQL 数据库中并使用 PHP JSON 加载它。
例如,对 JSON 进行编码的 PHP 文件是:

<?php
define('HOST','localhost');
define('USER','user');
define('PASS','pass');
define('DB','dbname');
$con = mysqli_connect(HOST,USER,PASS,DB);
$sql = "select * from questions";
$res = mysqli_query($con,$sql);
$result = array(); 
while($row = mysqli_fetch_array($res)){
    array_push($result,
        array('id'=>$row[0],
              'question'=>$row[1],
              'answer'=>$row[2]
    ));
}
echo json_encode(array("result"=>$result));
mysqli_close($con);
?>

Java 代码是:

public class MainActivity extends ActionBarActivity {

String myJSON;

private static final String TAG_RESULTS="result";
private static final String TAG_ID = "id";
private static final String TAG_QUESTION = "question";
private static final String TAG_ANSWER ="answer";

JSONArray peoples = null;

ArrayList<HashMap<String, String>> QuestionList;

ListView list;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    list = (ListView) findViewById(R.id.listView);
    QuestionList = new ArrayList<HashMap<String,String>>();
    getData();
}


protected void showList(){
    try {
        JSONObject jsonObj = new JSONObject(myJSON);
        results = jsonObj.getJSONArray(TAG_RESULTS);

        for(int i=0;i<results.length();i++){
            JSONObject c = peoples.getJSONObject(i);
            String id = c.getString(TAG_ID);
            String question = c.getString(TAG_QUESTION);
            String answer = c.getString(TAG_ANSWER);

            HashMap<String,String> questions = new HashMap<String,String>();

            questions.put(TAG_ID,id);
            questions.put(TAG_QUESTION,question);
            questions.put(TAG_ANSWER,answer);

            QuestionList.add(questions);
        }

        ListAdapter adapter = new SimpleAdapter(
                MainActivity.this, personList, R.layout.list_item,
                new String[]{TAG_ID,TAG_QUESTION,TAG_ANSWER},
                new int[]{R.id.id, R.id.question, R.id.answer}
        );

        list.setAdapter(adapter);

    } catch (JSONException e) {
        e.printStackTrace();
    }

}

public void getData(){
    class GetDataJSON extends AsyncTask<String, Void, String>{

        @Override
        protected String doInBackground(String... params) {
            DefaultHttpClient httpclient = new DefaultHttpClient(new BasicHttpParams());
            HttpPost httppost = new HttpPost("http://10.0.2.2/get-data.php");

            // Depends on your web service
            httppost.setHeader("Content-type", "application/json");

            InputStream inputStream = null;
            String result = null;
            try {
                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();

                inputStream = entity.getContent();
                // json is UTF-8 by default
                BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, "UTF-8"), 8);
                StringBuilder sb = new StringBuilder();

                String line = null;
                while ((line = reader.readLine()) != null)
                {
                    sb.append(line + "\n");
                }
                result = sb.toString();
            } catch (Exception e) {
                // Oops
            }
            finally {
                try{if(inputStream != null)inputStream.close();}catch(Exception squish){}
            }
            return result;
        }

        @Override
        protected void onPostExecute(String result){
            myJSON=result;
            showList();
        }
    }
    GetDataJSON g = new GetDataJSON();
    g.execute();
}

您必须在布局中添加列表视图 并且不要忘记在清单中添加互联网权限。

【讨论】:

  • @king-il:感谢您的详细回答。但我只想在本地申请,先生。我看到了你的参考教程网站。它只是使用 JSON 格式将数据从服务器加载到客户端,不是吗?如果我制作 JSON 文件,然后加载到应用程序,这很好吗?
  • @king-il:还有一个问题,谷歌服务器呢?
  • @kidsoul 如果你想制作本地应用程序,你可以使用 SQLite
【解决方案2】:

如果您正在制作一个可以访问互联网的 Android 应用程序,您可以创建一个数据库来存储所有问题和答案。因此,每次用户查看问题时,它都会向您的 Web 服务器发送一个请求,Web 服务器通过发送数据库中的数据来响应。

如果您只想使用本地数据库制作应用程序,您可以实现 Android SQLite 数据库。这是关于 SQLite 数据库的 Android 文档:http://developer.android.com/training/basics/data-storage/databases.html

但是,关于创建 html 文件或数据库需要多长时间的问题,将所有数据放入数据库总是需要一段时间,除非您已经拥有某种格式的所有数据,转换。

希望这会有所帮助!

【讨论】:

  • 关于本地数据库,JSON更好吗?
  • SQLite 数据库通常用于本地存储静态数据。 JSON 是一种格式而不是一种数据库类型,它通常用于在 Web 服务器和客户端之间传输数据。您可以使用内部存储将所有内容存储到一个或多个 JSON 格式的文件中。但是,在进行本地存储时,SQLite 是通常的选择
猜你喜欢
  • 2012-02-21
  • 1970-01-01
  • 2010-10-22
  • 1970-01-01
  • 1970-01-01
  • 2014-12-03
  • 1970-01-01
  • 1970-01-01
  • 2011-05-03
相关资源
最近更新 更多