通过本地路径获取的文件是否为照片Util

本文介绍了一个使用Java进行图片验证的方法,通过读取本地图片并检查其宽度和高度来判断图片是否有效。此方法适用于多种常见图片格式,如bmp、gif、jpg和png。
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
 /**
     * 
     * @param pathImg 本地图片路径
     * @return
     */
    public boolean checkImage(String pathImg) {
        BufferedImage image = null;
        boolean valid =true;
        try {
            image= ImageIO.read(new File(pathImg));
            if (image == null || image.getWidth() <= 0 || image.getHeight() <= 0) {
                valid = false;

            }
        } catch(IOException ex) {
            ex.printStackTrace();
            valid=false;
        }
        return valid;
    }
  • 注意: 该方法适用的图片格式为 bmp/gif/jpg/png
在 Android 手机端开发中,获取用户选择的 PPT 文件路径是一个常见的需求。由于现代 Android 系统(尤其是 Android 10+)对文件访问权限进行了严格限制(Scoped Storage),**不能直接通过路径访问任意文件**,必须使用系统提供的文档选择器(`Intent.ACTION_GET_CONTENT` 或 `Storage Access Framework`)来让用户授权文件访问。 --- ### ✅ 解决方案:使用 `ACTION_GET_CONTENT` 获取 PPT 文件并读取内容 以下是完整的 Java 示例代码(适用于 Android App),展示如何: 1. 启动文件选择器 2. 过滤只显示 `.ppt` 和 `.pptx` 3. 获取用户选中的文件 URI 4. 将其转换为可上传的 `FileDescriptor` 或缓存到临时文件用于 OkHttp 上传 --- ### 📱 Android 客户端代码示例(Activity 中实现) ```java import android.app.Activity; import android.content.Intent; import android.database.Cursor; import android.net.Uri; import android.os.Bundle; import android.provider.OpenableColumns; import android.util.Log; import androidx.annotation.Nullable; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; public class FilePickerActivity extends Activity { private static final int PICK_PPT_REQUEST = 1; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 启动文件选择器 showFileChooser(); } private void showFileChooser() { Intent intent = new Intent(Intent.ACTION_GET_CONTENT); intent.setType("application/vnd.ms-powerpoint"); // .ppt intent.putExtra(Intent.EXTRA_MIME_TYPES, new String[]{ "application/vnd.openxmlformats-officedocument.presentationml.presentation" // .pptx }); intent.addCategory(Intent.CATEGORY_OPENABLE); intent.putExtra(Intent.EXTRA_LOCAL_ONLY, true); // 只显示本地文件 startActivityForResult(Intent.createChooser(intent, "选择PPT文件"), PICK_PPT_REQUEST); } @Override protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == PICK_PPT_REQUEST && resultCode == RESULT_OK && data != null) { Uri uri = data.getData(); if (uri != null) { try { // 获取文件名 String fileName = getFileName(uri); Log.d("PPT_UPLOAD", "Selected file: " + fileName); // 将文件复制到应用私有目录以供上传 File cacheFile = copyUriToFile(uri, fileName); if (cacheFile != null) { // 成功获取本地可访问路径 String pptFilePath = cacheFile.getAbsolutePath(); Log.d("PPT_UPLOAD", "Cached at: " + pptFilePath); // 调用之前写的上传方法 PptUploader uploader = new PptUploader(); uploader.uploadPpt(pptFilePath); } } catch (Exception e) { Log.e("PPT_UPLOAD", "Error reading file", e); } } } else { Log.d("PPT_UPLOAD", "未选择文件或取消操作"); finish(); } } // 根据 URI 查询真实文件名 private String getFileName(Uri uri) { String result = null; if (uri.getScheme().equals("content")) { try (Cursor cursor = getContentResolver().query(uri, null, null, null, null)) { if (cursor != null && cursor.moveToFirst()) { int nameIndex = cursor.getColumnIndex(OpenableColumns.DISPLAY_NAME); result = cursor.getString(nameIndex); } } } if (result == null) { result = uri.getPath(); int cut = result.lastIndexOf('/'); if (cut != -1) { result = result.substring(cut + 1); } } return result; } // 将 URI 指向的内容复制到应用缓存目录下 private File copyUriToFile(Uri uri, String displayName) throws IOException { InputStream inputStream = getContentResolver().openInputStream(uri); if (inputStream == null) return null; File outputFile = new File(getCacheDir(), displayName); FileOutputStream outputStream = new FileOutputStream(outputFile); byte[] buffer = new byte[1024]; int length; while ((length = inputStream.read(buffer)) > 0) { outputStream.write(buffer, 0, length); } inputStream.close(); outputStream.close(); return outputFile; } } ``` --- ### 🔍 关键点解释: | 功能 | 说明 | |------|------| | `Intent.ACTION_GET_CONTENT` | 弹出系统文件选择器,支持过滤 MIME 类型 | | `EXTRA_MIME_TYPES` | 同时支持 `.ppt` 和 `.pptx` | | `getContentResolver().openInputStream(uri)` | 即使没有真实路径,也能通过 URI 流式读取文件内容 | | `copyUriToFile(...)` | 把选中的文件复制到 App 私有目录(无需额外权限) | | `getCacheDir()` | 缓存目录如 `/data/data/com.yourpackage/cache/xxx.pptx`,安全且自动清理 | --- ### ✅ 最终结果: 你将获得一个真正的、可被 OkHttp 访问的文件路径: ```text pptFilePath = "/data/user/0/com.example/cache/myfile.pptx" ``` 然后就可以传给之前的 `PptUploader.uploadPpt(pptFilePath)` 方法进行上传。 --- ### 🧩 权限说明(无需额外声明!) - 使用 `ACTION_GET_CONTENT` 和 `content://` URI 的方式 **不需要申请 `READ_EXTERNAL_STORAGE` 权限** - 用户主动授权单个文件,符合 Google Play 政策要求(尤其 Android 10+) > ✅ 推荐做法:始终使用 SAF(Storage Access Framework)而不是请求全局读写权限。 --- ### 💡 提示:更优雅的做法(推荐进阶) 你可以不缓存整个文件,而是直接从 `InputStream` 构建 OkHttp 的 `RequestBody`,节省空间: ```java RequestBody createRequestBody(Uri uri) { return new RequestBody() { @Override public MediaType contentType() { return MediaType.get("application/vnd.openxmlformats-officedocument.presentationml.presentation"); } @Override public void writeTo(BufferedSink sink) throws IOException { try (InputStream is = getContentResolver().openInputStream(uri)) { if (is == null) throw new IOException("Cannot open input stream"); byte[] buffer = new byte[8192]; int n; while ((n = is.read(buffer)) != -1) { sink.write(buffer, 0, n); } } } }; } ``` 这样可以避免复制大文件本地缓存。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值