0

Androidフォンを使用して外部MS SQLデータベースに画像をアップロードしようとしています。Java HttpClient を使用して、バイト配列を Web サーバーまたは Web ページに送信しています。これにどのようにアプローチすればよいかわかりません。Web ページは ASP.net にある必要があります。私はASP.Netにかなり慣れていません。ASP.Net を使用してバイト配列を読み取る方法について徹底的に調査しましたが、まだ答えがありません。Web ページまたはサーバーがバイトを読み込んでデータベースに保存するようにします。

以下は、バイトを送信するために使用したいJava関数です(バイトを読み取る方法がまだないため、まだテストされていません)。しかし、ウェブサイト側でそれらを読み込む方法がわかりません。任意の提案をいただければ幸いです。私が何か間違ったことをしているのを見た場合は、私に知らせて、それを修正する方法を教えていただければ幸いです. 私はこれに本当に慣れておらず、Webページについてあまり知らないので、具体的に教えてください. ありがとう。

    private void sendImagesToServer() throws Exception
{
    ImageItem image;
    HttpURLConnection conn = null;
    ImageIterator iterator;
    DataOutputStream dos;
    byte[] byteArray;
    iterator = new ImageIterator(imageAdapter);
    String uploadUrl;

    while(iterator.hasNext())
    {
        image = iterator.getNext();
        Uri uri = Uri.withAppendedPath(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, Integer.toString(image.id));

        Bitmap bmp=BitmapFactory.decodeStream(getContentResolver().openInputStream(uri));
        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        bmp.compress(Bitmap.CompressFormat.JPEG, 100, stream);
        byteArray = stream.toByteArray();

        uploadUrl = "http://localhost:63776/SQLScript.aspx";

        // Send request
        try {
            // Configure connection

            URL url = new URL(uploadUrl);
            conn = (HttpURLConnection) url.openConnection();
            conn.setDoInput(true);
            conn.setDoOutput(true);
            conn.setUseCaches(false);
            conn.setRequestMethod("PUT");
            conn.setRequestProperty("Connection", "Keep-Alive");

            dos = new DataOutputStream(conn.getOutputStream());
            dos.write(byteArray, 0, byteArray.length);
            dos.flush();
            dos.close();

            // Read response
            try {
                if (conn.getResponseCode() == 200) {
                    Toast.makeText(this,"Yay, We Got 200 as Response Code",Toast.LENGTH_SHORT).show();
                }
            } catch (IOException ioex) {
                ioex.printStackTrace();
            } catch (Exception e) {
                e.printStackTrace();
            }

        } finally{

        }   

    }

}   
4

1 に答える 1

0

バイトが Java ファインから外れていることを確認した場合は、この質問を確認してください。必要なものが含まれている可能性があります。

HTTP リクエストをバイト配列に読み込む

それをデータベースに入れる限り、ファイルをバイナリデータベース(別のMSSQLセットアップ)に保存するか、必要に応じて文字列に変換して元に戻すことができます。

于 2012-04-24T18:34:02.490 に答える