Ich möchte eine .db (SQLite) -Datei von meiner Android-App auf einen Server hochladen und ich frage mich, ob ich "multipart/form-data" als Inhaltstyp verwenden kann. Gibt es einen bestimmten Typ für .db-Dateien wie für PDF-Dateien, der "application/pdf" lautet?Welcher Content-Typ wird verwendet, wenn sqlite .db-Datei auf einen Server hochgeladen wird?
0
A
Antwort
0
Ich habe es tatsächlich nur mit dem "multipart/form-data" als Inhaltstyp arbeiten. Als ich die 'application/x-sqlite3' ausprobiert habe, hatte ich einen Fehler. Hier
ist das Code-Snippet ich verwendet, um die Db-Datei an den Server zu senden, von diesem link entlehnt:
public int uploadFile(String sourceFileUri) {
String fileName = sourceFileUri; // the path to my .db file
HttpURLConnection connection = null;
DataOutputStream dataOutputStream = null;
String lineEnd = "\r\n";
String twoHyphens = "--";
String boundary = "*****";
int bytesRead, bytesAvailable, bufferSize;
byte[] buffer;
int maxBufferSize = 1 * 1024 * 1024;
File sourceFile = new File(sourceFileUri);
if (!sourceFile.isFile()) {
Log.e("uploadFile", "Source File not exist ");
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
connection = (HttpURLConnection) url.openConnection();
connection.setDoInput(true); // Allow Inputs
connection.setDoOutput(true); //Triggers http POST method.
connection.setUseCaches(false); // Don't use a Cached Copy
connection.setRequestMethod("POST");
connection.setRequestProperty("Connection", "Keep-Alive");
connection.setRequestProperty("ENCTYPE", "multipart/form-data");
connection.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + boundary);
//conn.setRequestProperty("Content-Type", "application/x-sqlite3; boundary=" + boundary);// when I tried this it didn't work, so you can delete this line
connection.setRequestProperty("uploadedfile", fileName);
dataOutputStream = new DataOutputStream(connection.getOutputStream());
dataOutputStream.writeBytes(twoHyphens + boundary + lineEnd);
dataOutputStream.writeBytes("Content-Disposition: form-data; name=\"uploadedfile\";filename=" + fileName + "" + lineEnd);
dataOutputStream.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) {
dataOutputStream.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...
dataOutputStream.writeBytes(lineEnd);
dataOutputStream.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);
// Responses from the server (code and message)
serverResponseCode = connection.getResponseCode();
String serverResponseMessage = connection.getResponseMessage();
Log.i("uploadFile", "HTTP Response is : " + serverResponseMessage + ": " + serverResponseCode);
if (serverResponseCode == 200) {
String msg = "server respose code ";
Log.i(TAG, msg + serverResponseCode);
StringBuilder result = new StringBuilder();
InputStream in = new BufferedInputStream(connection.getInputStream());
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String line;
while ((line = reader.readLine()) != null) {
result.append(line);
}
//JSONObject mResponseJSONObject = new JSONObject(String.valueOf(result)); //convert the respons in json
Log.i(TAG, msg + result);
}
//close the streams //
fileInputStream.close();
dataOutputStream.flush();
dataOutputStream.close();
} catch (MalformedURLException ex) {
ex.printStackTrace();
Log.e(TAG, "MalformedURLException Exception : check script url.");
Log.e("Upload file to server", "error: " + ex.getMessage(), ex);
} catch (Exception e) {
e.printStackTrace();
Log.e(TAG, "Upload file to server Exception : " + e.getMessage(), e);
}
return serverResponseCode;
} // End else block
} //[End uploadFileToServer method]
Dies ist PHP-Skript, das ich auf der Serverseite verwendet:
<?php
if(isset($_FILES)) {
if(move_uploaded_file($_FILES["uploadedfile"]["tmp_name"], "./data/".$_FILES["uploadedfile"]["name"]."_".time())) {
echo " file recieved successfully"
exit;
}
}
echo "Error";
?>
Verwandte Themen
- 1. Welcher Klassenlader wird verwendet?
- 2. Wofür wird Sqlite verwendet?
- 3. Ermitteln, welcher Webserver verwendet wird
- 4. Wie kann man wissen, welcher Typ verwendet wird, wenn foreach auf einem IEnumerable-Typ verwendet wird?
- 5. Welcher C++ - Profiler wird verwendet?
- 6. WebRTC: Ermitteln, welcher TURN-Server in PeerConnection verwendet wird
- 7. Welcher "Cache" wird in sqlhelperparametercache verwendet
- 8. Welcher Servername wird für MS SQL Server Management Studio verwendet?
- 9. Wie entscheidet gitlab, welcher Runner für einen Job verwendet wird?
- 10. Welcher Datentyp wird für die Ordinalzahl verwendet?
- 11. Welcher Serializer wird in RDLC-Berichten verwendet?
- 12. Wie wird die Datei umbenannt, wenn sie mit Angular auf den Server hochgeladen wird?
- 13. Welcher Dokumentationsgenerator wird für lodash.com verwendet?
- 14. Welcher Port wird mit socket.io verwendet?
- 15. Welcher "kompatible" Schlüssel wird im Gerätebaum verwendet?
- 16. Welcher Typ wird für einen Select verwendet: mehrere im Frühling?
- 17. Welcher IntelliJ-Hub wird noch nicht verwendet?
- 18. WPF WebBrowser-Steuerelement: Welcher Browser wird verwendet?
- 19. Welcher Sortieralgorithmus wird von LINQ "OrderBy" verwendet?
- 20. C++ - Vererbungsklasse. Welcher Destruktor wird verwendet?
- 21. Welcher Cache-Algorithmus wird in Ccache verwendet?
- 22. Herauszufinden, welcher Typ in HashMap verwendet wird
- 23. Welcher Typ von Begrenzer wird verwendet?
- 24. Welcher Komprimierungsalgorithmus für hochredundante Daten verwendet wird
- 25. Welcher Partitionsalgorithmus wird verwendet? (für Quicksort)
- 26. Wie wird die Datenbanksicherungsdatei auf den Server hochgeladen?
- 27. Warum wird meine Leinwand nicht auf den Server hochgeladen?
- 28. PHP: Bilder Datei wird nicht auf dem Server hochgeladen?
- 29. Unterscheiden Sie, welcher Authentifizierungsmechanismus verwendet wird
- 30. Welcher Typ wird automatisch für Container verwendet?
" multipart/form-data "wird für HTML-Formulare verwendet. Hast du die [Wikipedia] (https://en.wikipedia.org/wiki/Internet_media_type) gelesen? –
ja ich habe die wikipedia Seite gelesen, aber die [RFC] (https://www.ietf.org/rfc/rfc2388.txt) besagt, dass es auch für nicht HTML-Formulare wie Tabellenkalkulation, PDF, etc verwendet werden kann. – ctu
Aber dann müssten Sie die Datei in die Multipart-Struktur einbetten. –