Загрузить изображение на сервер и сохранить в базе данных MySQL

Я прочитал много сообщений о загрузке изображения на сервер, но у меня все еще есть проблема. Изображение было успешно сохранено в пути к моей папке, но когда я открыл таблицу своей базы данных в phpmyadmin, изображение там не сохранялось.

Мой вопрос: как я могу изменить код, чтобы дополнительно сохранить путь к изображению в базе данных MySql после того, как изображение успешно сохранено в папке назначения? Пожалуйста, помогите в этом.

Для завершения я показываю мой текущий код для загрузки изображения на сервер:

upload.java:

 @Override
     protected void onActivityResult(int requestCode, int resultCode, Intent data) {

         if (requestCode == 1 && resultCode == RESULT_OK) {
                //Bitmap photo = (Bitmap) data.getData().getPath(); 

                Uri selectedImageUri = data.getData();
                imagepath = getPath(selectedImageUri);
                Bitmap bitmap=BitmapFactory.decodeFile(imagepath);
                imageview.setImageBitmap(bitmap);
                messageText.setText("Uploading file path:" +imagepath);

         }
        }
          public String getPath(Uri uri) {
                 String[] projection = { MediaStore.Images.Media.DATA };
                 Cursor cursor = managedQuery(uri, projection, null, null, null);
                 int column_index = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
                 cursor.moveToFirst();
                 return cursor.getString(column_index);
             }

        public int uploadFile(String sourceFileUri) {


           String fileName = sourceFileUri;

              HttpURLConnection conn = null;
              DataOutputStream dos = null;  
              String lineEnd = "\r\n";
              String twoHyphens = "--";
              String boundary = "*****";
              int bytesRead, bytesAvailable, bufferSize;
              byte[] buffer;
              int maxBufferSize = 1 * 512 * 512; 
              File sourceFile = new File(sourceFileUri); 

              if (!sourceFile.isFile()) {

                pDialog.dismiss(); 

                Log.e("uploadFile", "Source File not exist :"+imagepath);

                runOnUiThread(new Runnable() {
                    public void run() {
                     messageText.setText("Source File not exist :"+ imagepath);
                    }
                }); 

                return 0;

              }
              else
              {
                try { 

                   // open a URL connection to the Servlet
                    FileInputStream fileInputStream = new FileInputStream(sourceFile);
                    URL url = new URL(upLoadServerUri);

                    // Open a HTTP  connection to  the URL
                    conn = (HttpURLConnection) url.openConnection(); 
                    conn.setDoInput(true); // Allow Inputs
                    conn.setDoOutput(true); // Allow Outputs
                    conn.setUseCaches(false); // Don't use a Cached Copy
                    conn.setRequestMethod("POST");
                    conn.setRequestProperty("Connection", "Keep-Alive");
                    conn.setRequestProperty("ENCTYPE", "multipart/form-data");
                    conn.setRequestProperty("Content-Type", "multipart/form-data;boundary=" + boundary);
                    conn.setRequestProperty("uploaded_file", fileName); 

                    dos = new DataOutputStream(conn.getOutputStream());

                    dos.writeBytes(twoHyphens + boundary + lineEnd); 
                    dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""
                                        + fileName + "\"" + lineEnd);

                    dos.writeBytes(lineEnd);

                    // create a buffer of  maximum size
                    bytesAvailable = fileInputStream.available(); 

                    bufferSize = Math.min(bytesAvailable, maxBufferSize);
                    buffer = new byte[bufferSize];

                    // read file and write it into form...
                    bytesRead = fileInputStream.read(buffer, 0, bufferSize);  

                    while (bytesRead > 0) {

                      dos.write(buffer, 0, bufferSize);
                      bytesAvailable = fileInputStream.available();
                      bufferSize = Math.min(bytesAvailable, maxBufferSize);
                      bytesRead = fileInputStream.read(buffer, 0, bufferSize);   

                     }

                    // send multipart form data necesssary after file data...
                    dos.writeBytes(lineEnd);
                    dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);

                    // Responses from the server (code and message)
                    serverResponseCode = conn.getResponseCode();
                    String serverResponseMessage = conn.getResponseMessage();

                    Log.i("uploadFile", "HTTP Response is : " 
                      + serverResponseMessage + ": " + serverResponseCode);

                    if(serverResponseCode == 200){

                        runOnUiThread(new Runnable() {
                             public void run() {
                              String msg = "File Upload Completed.\n\n See uploaded file here : \n\n"
                                      +" D:/food/adminweb/foto_berbagi_masakan/";
                              messageText.setText(msg);
                                 Toast.makeText(Berbagi_Resep.this, "File Upload Complete.", Toast.LENGTH_SHORT).show();
                             }
                         });                
                    }    

                    //close the streams //
                    fileInputStream.close();
                    dos.flush();
                    dos.close();

               } catch (MalformedURLException ex) {

                   pDialog.dismiss();  
                   ex.printStackTrace();

                   runOnUiThread(new Runnable() {
                       public void run() {
                        messageText.setText("MalformedURLException Exception : check script url.");
                           Toast.makeText(Berbagi_Resep.this, "MalformedURLException", Toast.LENGTH_SHORT).show();
                       }
                   });

                   Log.e("Upload file to server", "error: " + ex.getMessage(), ex);  
               } catch (Exception e) {

                   pDialog.dismiss();  
                   e.printStackTrace();

                   runOnUiThread(new Runnable() {
                       public void run() {
                        messageText.setText("Got Exception : see logcat ");
                           Toast.makeText(Berbagi_Resep.this, "Got Exception : see logcat ", Toast.LENGTH_SHORT).show();
                       }
                   });
                   Log.e("Upload file to server Exception", "Exception : "  + e.getMessage(), e);  
               }
               pDialog.dismiss();       
               return serverResponseCode; 

               } // End else block 
             }

и это для uploadToServer.php:

    <?php
    include '../config/koneksi.php';

        $file_path = "adminweb/foto_berbagi_resep/";
            $file_path = $file_path . basename( $_FILES['uploaded_file']['name']);
            if(move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $file_path)) {

            $link = mysql_connect($host,$database);
            mysql_query($link, "INSERT INTO 'gambar_upload' (gambar) VALUES('".$file_path."')"); /*or trigger_error($link->error."[ $sql]");*/
            mysql_close($link);

            }

            else{
                    echo "fail";
            }
   ?>

1 ответ

Решение

Как говорит евген, используйте PDO или mysqli. Вы можете использовать mysqli, очень похожий на "старый" адаптер mysql.

$link = mysql_connect($host,$database);
mysql_query($link, "INSERT INTO 'gambar_upload' (gambar) VALUES('".$file_path."')");
mysql_close($link);

это должно выглядеть так:

$link = mysqli_connect("myhost","myuser","mypassw","mybd");
$filepath = mysqli_real_escape_string($link, $file_path);
$query = "INSERT INTO 'gambar_upload' (gambar) VALUES('".$filepath."')";
mysqli_query($link, $query);
mysqli_close($link);

другой пример можно найти здесь: http://php.net/manual/de/mysqli.real-escape-string.php

Другие вопросы по тегам