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

JSON a nahrajte obrázek na server

Ve svém přístupu jsem použil org.apache.http.entity.mime.MultipartEntity a přidal předaný název souboru obrázku jako FileBody

entity.addPart("image_" + photo_count, new FileBody(
                        new File(failed.getFilenames()[i])));

poté předejte MultiPartEntity do HttpPost. Nezveřejnil jsem celý kód, protože má spoustu komentářů a kódu, který nesouvisí s vaší otázkou. Předáním obrázku jako FileBody je možné získat obrázek pomocí stand php kódu pro zpracování souboru (viz níže).

  if ((!empty($_FILES[$im])) && ($_FILES[$im]['error'] == 0)) {
              $newname = dirname(__FILE__) . '/../photo/' . $campaign . '/' . $fn;
              if (!file_exists($newname)) {
                  if (move_uploaded_file($_FILES[$im]['tmp_name'], $newname)) {
                      //$resp = "The file " . $fn . " has been uploaded";
                      //printf("%s", $resp);
                  } else {
                    $error = $error + 1;      
                  } 
              }else{
                //image file already exists
                $error = $error + 1;
              }
          } else {
              $error = $error +1;
          }

Pro můj účel byl výše uvedený kód ve smyčce, protože jsem se zabýval více obrázky

$im = 'image_' . $i;

odkazuje na název obrázku v entitě.

Omlouvám se za krátký příspěvek, spěchám.

Zapomněl jsem zmínit důvod, proč jsem nepoužil přístup pomocí řetězce Base64, je to omezení velikosti obrázku, který můžete odeslat. Přístup FileBody v entitě byl nejlepší přístup, který jsem našel.

Řetězce můžete předávat pomocí:

entity.addPart("address", new StringBody(failed[0].getAddress()));

HttpClient client = new DefaultHttpClient();
HttpConnectionParams.setConnectionTimeout(client.getParams(), 20000); // Timeout

MultipartEntity entity = new MultipartEntity(HttpMultipartMode.BROWSER_COMPATIBLE);
entity.addPart("address", new StringBody("my address example"));
entity.addPart("image_0", new FileBody(new File("filename of image")));

HttpPost post = new HttpPost("server address");
post.setEntity(entity);

HttpResponse response  = client.execute(post);


  1. Jak spočítat všechny záznamy, ale načíst (LIMIT) pouze konkrétní číslo pro zobrazení?

  2. Název tabulky Mysql nefunguje velkými písmeny

  3. MySQL zobrazuje všechna data v rozmezí

  4. Jak přenést datum a čas na čas