1

PHPを使用してAndroidデバイスからサーバーにファイルをアップロードしたいと思います。また、ファイルの名前を WHERE ステートメントを使用してデータベースに送信したいと考えています。ファイルをアップロードできますが、WHERE ステートメントを送信できません。Android ソースのどこにどのように配置すればよいかわかりません。

これが私のphpコードです:

<form action="FileUp.php" method="post" enctype="multipart/form-data">
</form>

<?php

mysql_connect('localhost','root','root');
mysql_select_db('db');

$target_path  = "./";
$target_path = $target_path . basename( $_FILES['uploadedfile']['name']);
$file = basename( $_FILES['uploadedfile']['name']);
if(move_uploaded_file($_FILES['uploadedfile']['tmp_name'], $target_path)){
echo "The file ".  basename( $_FILES['uploadedfile']['name']).
" has been uploaded";
} else{
echo "There was an error uploading the file, please try again!";
}
$ident=addslashes($_POST['ident']);

mysql_query ("UPDATE table SET column = CONCAT(column,'$file') WHERE id = '$ident'");

?>

そして、ここにJavaコードがあります:

@Override
        public void onClick(View v) {
            // TODO Auto-generated method stub

            String exsistingFileName = file.getText().toString();
            String lineEnd = "\r\n";
            String twoHyphens = "--";
            String boundary = "*****";
            try {
                // ------------------ CLIENT REQUEST

                Log.e(Tag, "Inside second Method");

                FileInputStream fileInputStream = new FileInputStream(new File(
                        exsistingFileName));

                // open a URL connection to the Servlet

                URL url = new URL(urlString);

                // Open a HTTP connection to the URL

                conn = (HttpURLConnection) url.openConnection();

                // Allow Inputs
                conn.setDoInput(true);

                // Allow Outputs
                conn.setDoOutput(true);

                // Don't use a cached copy.
                conn.setUseCaches(false);

                // Use a post method.
                conn.setRequestMethod("POST");

                conn.setRequestProperty("Connection", "Keep-Alive");

                conn.setRequestProperty("Content-Type",
                        "multipart/form-data;boundary=" + boundary);

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

                dos.writeBytes(twoHyphens + boundary + lineEnd);
                dos
                        .writeBytes("Content-Disposition: post-data; name=uploadedfile;filename="
                                + exsistingFileName + "" + lineEnd);
                dos.writeBytes(lineEnd);

                Log.e(Tag, "Headers are written");

                // create a buffer of maximum size

                int bytesAvailable = fileInputStream.available();
                int maxBufferSize = 1000;
                // int bufferSize = Math.min(bytesAvailable, maxBufferSize);
                byte[] buffer = new byte[bytesAvailable];

                // read file and write it into form...

                int bytesRead = fileInputStream.read(buffer, 0, bytesAvailable);

                while (bytesRead > 0) {
                    dos.write(buffer, 0, bytesAvailable);
                    bytesAvailable = fileInputStream.available();
                    bytesAvailable = Math.min(bytesAvailable, maxBufferSize);
                    bytesRead = fileInputStream.read(buffer, 0, bytesAvailable);
                }

                // send multipart form data necesssary after file data...

                dos.writeBytes(lineEnd);
                dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);

                // close streams
                Log.e(Tag, "File is written");
                fileInputStream.close();
                dos.flush();
                dos.close();

            } catch (MalformedURLException ex) {
                Log.e(Tag, "error: " + ex.getMessage(), ex);
            }

            catch (IOException ioe) {
                Log.e(Tag, "error: " + ioe.getMessage(), ioe);
            }

            try {
                BufferedReader rd = new BufferedReader(new InputStreamReader(conn
                        .getInputStream()));
                String line;
                while ((line = rd.readLine()) != null) {
                    Log.e("Dialoge Box", "Message: " + line);
                }
                rd.close();

            } catch (IOException ioex) {
                Log.e("MediaPlayer", "error: " + ioex.getMessage(), ioex);
            }

PHP側に送信するためにident文字列をどこに置く必要があるか教えてください! どうもありがとう!

4

1 に答える 1

1

経由で画像をアップロードできますMultipartEntity

MultipartEntity、一部HttpMime 4.0以降。境界文字列で区切られ、特定の文字セットを使用してエンコードされた複数の部分を httppost リクエストに入れることができます。

マルチパートの詳細と使用方法については、こちらこちらをご覧ください。

于 2012-10-13T08:47:14.487 に答える