sql >> Databáze >  >> RDS >> Mysql

ANDROID&PHP - Jak zobrazit JSONArray z MySql pomocí PHP

Problém

HttpURLConnection nemá podporu JavaScriptu, ale potřebný soubor cookie je generován pomocí JavaScriptu.

Váš hovor

String reqUrl = "http://zxccvvv.cuccfree.com/send_data.php";
URL url = new URL(reqUrl);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();

selže, protože soubor cookie __test chybí.

Opravit

Na první pohled na zdroj JavaScriptu se soubor cookie zdá být pro danou adresu URL konstantní, takže může stačit nastavit konstantní soubor cookie :

String cookie = "__test=2bf7c15501c0ec57f8e41cb84871a69c";

URL url = new URL(reqUrl);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setConnectTimeout(7000);
conn.setRequestMethod("GET");
conn.setRequestProperty("Cookie", cookie);

Alternativa: Pomocí WebView můžeme soubor cookie uchopit, takže toto je upřednostňovaný přístup, protože se nerozbije, pokud se soubor cookie změní a není to příliš dlouhé zpoždění:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    getCookie();

    if(cookie!=null) {
        new GetContacts().execute();
    }
}

private void getCookie(){
    CookieManager.setAcceptFileSchemeCookies(true);
    WebView wv = new WebView(getApplicationContext());
    wv.getSettings().setJavaScriptEnabled(true);
    wv.loadUrl(url);
    cookie = CookieManager.getInstance().getCookie("zxccvvv.cuccfree.com");
}

a nastavte jej jako ve výše uvedeném příkladu:

conn.setRequestProperty("Cookie", cookie);

Výstup v logcat

Response from url: [{"0":"1","id":"1","1":"pertanyaan ke 1","ask":"pertanyaan ke 1"},{"0":"2","id":"2","1":"pertanyaan ke 2","ask":"pertanyaan ke 2"},{"0":"3","id":"3","1":"pertanyaan ke 3","ask":"pertanyaan ke 3"},{"0":"4","id":"4","1":"pertanyaan ke 4","ask":"pertanyaan ke 4"},{"0":"5","id":"5","1":"pertanyaan ke 5","ask":"pertanyaan ke 5"}]



  1. Jak REPLACE() funguje v MariaDB

  2. Jak změnit velikost sloupce v MySQL

  3. Vraťte seznam databází v SQLite

  4. Chyba:mysqlnd se nemůže připojit k MySQL 4.1+ pomocí staré nezabezpečené autentizace