andriod图片上传到php,android + php 上传图片到服务器

一、添加权限

tools:ignore="ProtectedPermissions" />

tools:ignore="ProtectedPermissions" />

二、服务器php 程序

$target_path = "./test/";//接收文件目录

$target_path = $target_path . 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!" . $_FILES['uploadedfile']['error'];

}

三、Android  java程序

private static final String CHARST ="UTF-8";

public boolean uploadFile(File file,String RequestURL,String imgname) {

String BOUNDARY =UUID.randomUUID().toString();// 边界标识 随机生成

String PREFIX ="--",LINE_END ="\r\n";

String CONTENT_TYPE ="multipart/form-data";// 内容类型

try {

URL url =new URL(RequestURL);

HttpURLConnection conn = (HttpURLConnection)url.openConnection();

conn.setReadTimeout(50000);

conn.setConnectTimeout(50000);

conn.setDoInput(true);// 允许输入流

conn.setDoOutput(true);// 允许输出流

conn.setUseCaches(false);// 不允许使用缓存

conn.setRequestMethod("POST");// 请求方式

conn.setRequestProperty("Charset",CHARST);

// 设置编码

conn.setRequestProperty("connection","keep-alive");

conn.setRequestProperty("Content-Type",CONTENT_TYPE +";boundary="

+BOUNDARY);

if (file !=null) {

/** * 当文件不为空,把文件包装并且上传 */

OutputStream outputSteam =conn.getOutputStream();

DataOutputStream dos =new DataOutputStream(outputSteam);

StringBuffer sb =new StringBuffer();

sb.append(PREFIX);

sb.append(BOUNDARY);

sb.append(LINE_END);

/**

* 这里重点注意: name里面的值为服务器端需要key 只有这个key 才可以得到对应的文件

*/

sb.append("Content-Disposition: form-data; name=\"uploadedfile\"; filename=\""

+imgname +".png" +"\"" +LINE_END);//file.getName()

sb.append("Content-Type: application/octet-stream; charset="

+CHARST +LINE_END);

sb.append(LINE_END);

dos.write(sb.toString().getBytes());

InputStream is =new FileInputStream(file);

byte[]bytes =new byte[1024];

int len =0;

// ImageView img = (ImageView) findViewById(R.id.imageView);

// Bitmap bitmap  = BitmapFactory.decodeStream(is);

// img.setImageBitmap(bitmap);

while ((len =is.read(bytes)) != -1) {

dos.write(bytes,0, len);

}

is.close();

dos.write(LINE_END.getBytes());

byte[]end_data = (PREFIX +BOUNDARY +PREFIX +LINE_END).getBytes();

dos.write(end_data);

dos.flush();

dos.close();

/**

* 获取响应码 200=成功 当响应成功,获取响应的流

*/

int res =conn.getResponseCode();

Log.e("111","response code:" +res);

if (res ==200) {

return true;

}

}

}catch (MalformedURLException e) {

e.printStackTrace();

}catch (IOException e) {

e.printStackTrace();

}

return false;

}

四、新建线程调用

new Thread() {

@Override

public void run() {

String fileName =Environment.getExternalStorageDirectory().getAbsolutePath() +"/facepass/001.png";

File filePic =new File(fileName);

// uploadFile(filePic, "http://10.100.72.152/uploadimg1.php");

// uploadFile(filePic, "http://10.100.72.152/uploadimg1.php");

uploadFile(filePic,"http://10.100.72.152/?c=preson&a=addimg","img");

}

}.start();

五、动态获取权限

if (Build.VERSION.SDK_INT >=23) {

int REQUEST_CODE_CONTACT =101;

String[]permissions = {

Manifest.permission.WRITE_EXTERNAL_STORAGE};

//验证是否许可权限

for (String str :permissions) {

if (MainActivity.this.checkSelfPermission(str) !=PackageManager.PERMISSION_GRANTED) {

//申请权限

MainActivity.this.requestPermissions(permissions,REQUEST_CODE_CONTACT);

return;

}else {

//这里就是权限打开之后自己要操作的逻辑

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值