安卓上传头像

网络请求

okhttp的依赖:

          compile 'com.squareup.okhttp3:okhttp:3.4.1'

    网络权限和相机权限:

              

<uses-permission android:name="android.permission.INTERNET"></uses-permission>
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-permission android:name="android.permission.FLASHLIGHT" />
    <uses-feature android:name="android.hardware.camera" />
    <uses-feature android:name="android.hardware.camera.autofocus" />
    <uses-permission android:name="android.permission.VIBRATE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.CAMERA" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.READ_LOGS" />
    <uses-permission android:name="android.permission.CALL_PHONE" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.GET_TASKS" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
对Okhttp的封装:

public class HttpUtils1 {
    private static HttpUtils1 httpUtils;
    private final OkHttpClient client;

    private HttpUtils1() {
        /**
         * 自定义拦截器上传公共参数
         */
        client = new OkHttpClient();
    }
    public static HttpUtils1 getHttpUtils(){
        if(httpUtils==null){
            synchronized (HttpUtils1.class){
                httpUtils=new HttpUtils1();
            }
        }
        return httpUtils;
    }

    /**
     * get请求
     * @param str
     * @param callback
     */
    public void doGet(String str, Callback callback){
        Request build = new Request.Builder().url(str).build();
        client.newCall(build).enqueue(callback);
    }
    /**
     * post请求
     */
    public void doPost(String str, Map<String,String> map, Callback callback){
        FormBody.Builder builder = new FormBody.Builder();
        for (Map.Entry<String,String> entry:map.entrySet()
             ) {
            builder.add(entry.getKey(),entry.getValue());
        }
        FormBody formBody = builder.build();
        Request request = new Request.Builder().url(str).post(formBody).build();
        client.newCall(request).enqueue(callback);
    }
    public void uploadFile(HashMap<String, Object> paramsMap, String filePath, final CallBackListener listener) {

        //http://120.27.23.105/file/upload

        try {
            String actionUrl = "file/upload";
            String sdcardPath = Environment.getExternalStorageDirectory().getPath();
            filePath = sdcardPath + filePath;
            final String requestUrl = String.format("%s%s", "http://120.27.23.105/", actionUrl);
            File file = new File(filePath);
            MultipartBody.Builder builder = new MultipartBody.Builder();
            //设置类型 表单
            builder.setType(MultipartBody.FORM);
            for (String key : paramsMap.keySet()) {
                Object object = paramsMap.get(key);
                builder.addFormDataPart(key, object.toString());
            }//image/jpeg
            // MediaType mediaType = MediaType.parse("application/octet-stream");
            //MediaType mediaType = MediaType.parse("image/jpeg");
            builder.addFormDataPart("file", file.getName(), RequestBody.create(MediaType.parse("multipart/form-data"), file));
            //创建RequestBody
            RequestBody body = builder.build();
            //创建Request
            final Request request = new Request.Builder().url(requestUrl).post(body).build();
            //单独设置参数 比如读取超时时间
            final Call call = getOKHttpClient().newBuilder().build().newCall(request);
            call.enqueue(new Callback() {
                @Override
                public void onFailure(Call call, IOException e) {
                    if (null != listener) {
                        listener.onError("上传失败" + requestUrl + "|" + e.toString());
                    }
                    Log.e("TAG", "上传失败==" + e.toString());
                }

                @Override
                public void onResponse(Call call, Response response) throws IOException {
                    if (response.isSuccessful()) {
                        String string = response.body().string();
                        if (null != listener) {
                            listener.onSuccess("" + string + requestUrl);
                        }
                        Log.e("TAG", "上传成功==" + string);
                    } else {
                        Log.e("TAG", "上传失败------------");
                        if (null != listener) {
                            listener.onError("上传失败" + requestUrl);
                        }
                    }
                }
            });
        } catch (Exception e) {
            if (null != listener) {
                listener.onError("上传失败" + e.getMessage());
            }
        }
    }
    private OkHttpClient getOKHttpClient() {
        OkHttpClient client = new OkHttpClient
                .Builder()
                .connectTimeout(20, TimeUnit.SECONDS)
                .writeTimeout(20, TimeUnit.SECONDS)
                .readTimeout(20, TimeUnit.SECONDS)
                .build();
        return client;
    }
}

写个接口回调的方法:

public interface CallBackListener {
    public void onSuccess(String msg);

    public void onError(String msg);
}
mainactivity的布局:

 

<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.baiwei.shenxuesong.sctx.MainActivity">

    <ImageView
        android:id="@+id/iv_tx"

        android:layout_width="50dp"
        android:layout_height="50dp"

        android:layout_gravity="center_vertical"/>

</android.support.constraint.ConstraintLayout>

dialog_select_photo的布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    android:orientation="vertical"
    xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TextView
        android:layout_gravity="center_horizontal"
        android:id="@+id/tv_select_gallery"
        android:textSize="20sp"
        android:text="从 相册中选取"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <TextView
        android:id="@+id/tv_select_camera"
        android:textSize="20sp"
        android:text="拍照"
        android:layout_gravity="center_horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</LinearLayout>
主要的逻辑代码:

public class MainActivity extends AppCompatActivity implements View.OnClickListener ,CallBackListener{

    private ImageView img;
    private static String path = "/sdcard/myHead/";
    private Bitmap head;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        img = findViewById(R.id.iv_tx);
        img.setOnClickListener(this);

        Bitmap bt = BitmapFactory.decodeFile(path + "head.jpg");// 从SD卡中找头像,转换成Bitmap
        if (bt != null) {
            @SuppressWarnings("deprecation")
            Drawable drawable = new BitmapDrawable(bt);// 转换成drawable
            img.setImageDrawable(drawable);
        } else {
            /**
             * 如果SD里面没有则需要从服务器取头像,取回来的头像再保存在SD中
             *
             */
        }
    }

    @Override
    public void onClick(View view) {
        showTypeDialog();
    }

    private void showTypeDialog() {
        //创建AlertDialog
        AlertDialog.Builder builder = new AlertDialog.Builder(this);
        final AlertDialog dialog = builder.create();
        View view = View.inflate(this, R.layout.dialog_select_photo, null);
        TextView tv_select_gallery = (TextView) view.findViewById(R.id.tv_select_gallery);
        TextView tv_select_camera = (TextView) view.findViewById(R.id.tv_select_camera);
        tv_select_gallery.setOnClickListener(new View.OnClickListener() {// 在相册中选取
            @Override
            public void onClick(View v) {
                Intent intent1 = new Intent(Intent.ACTION_PICK, null);
                intent1.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, "image/*");
                startActivityForResult(intent1, 1);
                dialog.dismiss();
            }
        });
        tv_select_camera.setOnClickListener(new View.OnClickListener() {// 调用照相机
            @Override
            public void onClick(View v) {
                Intent intent2 = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
                intent2.putExtra(MediaStore.EXTRA_OUTPUT,
                        Uri.fromFile(new File(Environment.getExternalStorageDirectory(), "mmexport1511619684769.jpg")));
                startActivityForResult(intent2, 2);// 采用ForResult打开
                dialog.dismiss();
            }
        });
        dialog.setView(view);
        dialog.show();
    }
    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        switch (requestCode) {
            case 1:
                if (resultCode == RESULT_OK) {
                    cropPhoto(data.getData());// 裁剪图片
                }

                break;
            case 2:
                if (resultCode == RESULT_OK) {
                    File temp = new File(Environment.getExternalStorageDirectory() + "/mmexport1511619684769.jpg");
                    cropPhoto(Uri.fromFile(temp));// 裁剪图片
                }

                break;
            case 3:
                if (data != null) {
                    Bundle extras = data.getExtras();
                    head = extras.getParcelable("data");

                    if (head != null) {
                        /**
                         * 上传服务器代码
                         */
                        setPicToView(head);// 保存在SD卡中
                        img.setImageBitmap(head);// 用ImageView显示出来
                    }
                }else{
                    getTu();
                }
                break;
            default:
                break;

        }
        super.onActivityResult(requestCode, resultCode, data);
    }

    /**
     * 调用系统的裁剪功能
     *
     * @param uri
     */
    public void cropPhoto(Uri uri) {
        Intent intent = new Intent("com.android.camera.action.CROP");
        intent.setDataAndType(uri, "image/*");
        intent.putExtra("crop", "true");
        // aspectX aspectY 是宽高的比例
        intent.putExtra("aspectX", 1);
        intent.putExtra("aspectY", 1);
        // outputX outputY 是裁剪图片宽高
        intent.putExtra("outputX", 150);
        intent.putExtra("outputY", 150);
        intent.putExtra("return-data", true);
        startActivityForResult(intent, 3);
    }

    /**
     * 读取
     * @param mBitmap
     */
    private void setPicToView(Bitmap mBitmap) {
        String sdStatus = Environment.getExternalStorageState();
        if (!sdStatus.equals(Environment.MEDIA_MOUNTED)) { // 检测sd是否可用
            return;
        }
        FileOutputStream b = null;
        File file = new File(path);
        file.mkdirs();// 创建文件夹
        String fileName = path + "mmexport1511619684769.jpg";// 图片名字
        try {
            b = new FileOutputStream(fileName);
            mBitmap.compress(Bitmap.CompressFormat.JPEG, 100, b);// 把数据写入文件
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } finally {
            try {
                // 关闭流
                b.flush();
                b.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /*  @Override
      public void showStr(String s) {
          Toast.makeText(getActivity().getApplicationContext(), "", Toast.LENGTH_SHORT).show();
      }
  */
    /**
     * 网络下载
     */
    private void getTu(){
        //上传图片
        HashMap<String, Object> paramsMap = new HashMap<String, Object>();
        paramsMap.put("uid", "71");
        //网络请求
        HttpUtils1.getHttpUtils().uploadFile(paramsMap, "/abc123.jpg", this);
    }
    @Override

    public void onSuccess(String msg) {
        Toast.makeText(getApplicationContext(), msg, Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onError(String msg) {
        // Toast.makeText(getActivity().getApplicationContext(), msg, Toast.LENGTH_SHORT).show();
    }
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android中,可以通过使用Retrofit等网络请求库来实现头像上传和下载,并将头像缓存到本地。以下是一个简单的示例: 1. 添加Retrofit和OkHttp依赖: ```gradle implementation 'com.squareup.retrofit2:retrofit:2.9.0' implementation 'com.squareup.retrofit2:converter-gson:2.9.0' implementation 'com.squareup.okhttp3:okhttp:4.9.0' ``` 2. 定义上传和下载接口: ```java public interface ApiService { @Multipart @POST("upload_avatar") Call<ResponseBody> uploadAvatar(@Part MultipartBody.Part file); @GET("download_avatar") Call<ResponseBody> downloadAvatar(); } ``` 在上述代码中,使用@Multipart注解标记上传的请求,@Part注解标记上传的文件。下载接口使用@GET注解标记,并返回一个ResponseBody对象。 3. 实现上传头像的逻辑: ```java // 选择图片并上传头像 Intent intent = new Intent(Intent.ACTION_GET_CONTENT); intent.setType("image/*"); startActivityForResult(intent, 1); @Override protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == 1 && resultCode == RESULT_OK && data != null) { Uri uri = data.getData(); File file = new File(getRealPathFromUri(this, uri)); RequestBody requestBody = RequestBody.create(MediaType.parse("image/*"), file); MultipartBody.Part filePart = MultipartBody.Part.createFormData("file", file.getName(), requestBody); ApiService apiService = createApiService(); Call<ResponseBody> call = apiService.uploadAvatar(filePart); call.enqueue(new Callback<ResponseBody>() { @Override public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) { Toast.makeText(MainActivity.this, "上传成功", Toast.LENGTH_SHORT).show(); } @Override public void onFailure(Call<ResponseBody> call, Throwable t) { Toast.makeText(MainActivity.this, "上传失败", Toast.LENGTH_SHORT).show(); } }); } } // 获取URI对应的真实路径 public String getRealPathFromUri(Context context, Uri uri) { String[] projection = {MediaStore.Images.Media.DATA}; Cursor cursor = context.getContentResolver().query(uri, projection, null, null, null); if (cursor != null && cursor.moveToFirst()) { int columnIndex = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA); String filePath = cursor.getString(columnIndex); cursor.close(); return filePath; } return ""; } ``` 在上述代码中,使用Intent.ACTION_GET_CONTENT打开文件选择器,选择图片后将图片文件构造成RequestBody和MultipartBody.Part对象,然后使用Retrofit上传头像。 4. 实现下载头像并缓存到本地的逻辑: ```java // 下载头像并缓存到本地 ApiService apiService = createApiService(); Call<ResponseBody> call = apiService.downloadAvatar(); call.enqueue(new Callback<ResponseBody>() { @Override public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) { if (response.isSuccessful()) { try (InputStream inputStream = response.body().byteStream()) { Bitmap bitmap = BitmapFactory.decodeStream(inputStream); imageView.setImageBitmap(bitmap); // 将头像保存到本地文件 File file = new File(getCacheDir(), "avatar.png"); try (FileOutputStream fos = new FileOutputStream(file)) { bitmap.compress(Bitmap.CompressFormat.PNG, 100, fos); } catch (IOException e) { e.printStackTrace(); } } catch (IOException e) { e.printStackTrace(); } } } @Override public void onFailure(Call<ResponseBody> call, Throwable t) { Toast.makeText(MainActivity.this, "下载失败", Toast.LENGTH_SHORT).show(); } }); ``` 在上述代码中,使用Retrofit下载头像,如果下载成功,将头像设置到ImageView中,并将头像保存到本地文件中。需要注意的是,下载头像时需要在异步线程中执行,否则会抛出NetworkOnMainThreadException异常。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值