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{
}
}
}