Php 从android上传一个文件加字符串到服务器不工作
我想用php从android设备上传一个文件到服务器。我还想用WHERE语句将文件名发送到数据库。我可以上传我的文件,但我不能发送WHERE语句,我不知道在哪里以及如何将其放入android源代码中 以下是我的php代码:Php 从android上传一个文件加字符串到服务器不工作,php,android,file,upload,webserver,Php,Android,File,Upload,Webserver,我想用php从android设备上传一个文件到服务器。我还想用WHERE语句将文件名发送到数据库。我可以上传我的文件,但我不能发送WHERE语句,我不知道在哪里以及如何将其放入android源代码中 以下是我的php代码: <form action="FileUp.php" method="post" enctype="multipart/form-data"> </form> <?php mysql_connect('localhost','root','ro
<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'");
?>
请帮助我在哪里需要把我的识别字符串发送到php端!
非常感谢 您可以通过
多端口
上传图像
MultipartEntity
,httpime 4.0
及更高版本的一部分。允许您将由边界字符串分隔并使用给定字符集编码的多个部分放入httppost请求中
有关更多信息以及如何使用多部分,请参阅和。您可以通过
多部分
上传图像
MultipartEntity
,httpime 4.0
及更高版本的一部分。允许您将由边界字符串分隔并使用给定字符集编码的多个部分放入httppost请求中
有关更多信息以及如何使用Multipart,请参阅和。谢谢您的回复!这是一个很好的解决方案,但对我来说不起作用。每次我遇到Dalvik错误,我已经尝试过建议的技巧。。。所以我提出要求,这不是优雅,但工作。谢谢我认为jar文件导致了Dalvik问题,但事实并非如此。每次都会发生,我不知道如何解决。我已经解决了这个问题,现在它与您的解决方案一起工作。很抱歉,谢谢你的帮助!谢谢你的回复!这是一个很好的解决方案,但对我来说不起作用。每次我遇到Dalvik错误,我已经尝试过建议的技巧。。。所以我提出要求,这不是优雅,但工作。谢谢我认为jar文件导致了Dalvik问题,但事实并非如此。每次都会发生,我不知道如何解决。我已经解决了这个问题,现在它与您的解决方案一起工作。很抱歉,谢谢你的帮助!
@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);
}