1 package com.netease.nimlib.sdk.msg.attachment;
3 import android.net.Uri;
4 import android.text.TextUtils;
14 import org.json.JSONObject;
69 private boolean isUri =
false;
86 return new File(path).exists() ?
path : null;
95 if (!isUri && !TextUtils.isEmpty(path)) {
109 return new File(path).exists() ?
path : null;
119 if (!TextUtils.isEmpty(fileName)) {
120 int dotIndex = fileName.lastIndexOf(
".");
122 if (dotIndex >= 0 && dotIndex < fileName.length() - 1) {
123 fileName = fileName.substring(0, dotIndex);
126 return NimStorageUtil.getWritePath(fileName, NimStorageType.TYPE_THUMB_IMAGE);
157 this.path = uri.toString();
253 else if (!TextUtils.isEmpty(path)) {
254 return StringUtil.nameOfPath(path);
256 if (TextUtils.isEmpty(md5)) {
257 return MD5.getStringMD5(url);
298 if (TextUtils.isEmpty(nosTokenSceneKey)) {
327 return NimStorageType.TYPE_FILE;
330 protected void save(JSONObject json) {
334 protected void load(JSONObject json) {
338 private static final String KEY_PATH =
"path";
339 private static final String KEY_NAME =
"name";
340 private static final String KEY_SIZE =
"size";
341 private static final String KEY_MD5 =
"md5";
342 private static final String KEY_URL =
"url";
343 private static final String KEY_EXT =
"ext";
344 private static final String KEY_SCENE =
"sen";
345 private static final String KEY_FORCE_UPLOAD =
"force_upload";
346 private static final String KEY_EXPIRE =
"expire";
351 JSONObject
object =
new JSONObject();
353 if (!send && !TextUtils.isEmpty(path)) {
354 object.put(KEY_PATH, path);
357 if (!TextUtils.isEmpty(md5)) {
358 object.put(KEY_MD5, md5);
361 if (!TextUtils.isEmpty(displayName)) {
362 object.put(KEY_NAME, displayName);
365 object.put(KEY_URL, url);
366 object.put(KEY_SIZE, size);
369 if (!TextUtils.isEmpty(extension)) {
370 object.put(KEY_EXT, extension);
372 if (!TextUtils.isEmpty(nosTokenSceneKey)) {
373 object.put(KEY_SCENE, nosTokenSceneKey);
377 object.put(KEY_EXPIRE, expire);
380 object.put(KEY_FORCE_UPLOAD, forceUpload);
383 }
catch (Exception e) {
387 return object.toString();
390 private void fromJson(String attach) {
391 JSONObject json = JSONHelper.parse(attach);
396 path = JSONHelper.getString(json, KEY_PATH);
402 md5 = JSONHelper.getString(json, KEY_MD5);
403 url = JSONHelper.getString(json, KEY_URL);
404 displayName = JSONHelper.getString(json, KEY_NAME);
405 size = JSONHelper.getLong(json, KEY_SIZE);
406 extension = JSONHelper.getString(json, KEY_EXT);
408 forceUpload = JSONHelper.getBoolean(json, KEY_FORCE_UPLOAD);
409 expire = JSONHelper.getLong(json, KEY_EXPIRE);
String getUrl()
获取文件在服务器上的下载url。若文件还未上传,返回null
String getExtension()
获取文件后缀名
void save(JSONObject json)
String nosTokenSceneKey
上传文件时用的对token对应的场景,默认NimNosSceneKeyConstant#NIM_DEFAULT_IM
static String getFileNameFromUri(Context context, Uri uri)
void setExtension(String extension)
设置文件后缀名
boolean setUri(Uri uri)
设置文件uri, 仅支持ContentResolver.SCHEME_FILE类型和ContentResolver.SCHEME_CONTENT类型的uri 仅支持发...
String getFileName()
获取文件名。
static boolean isFileOrContentUri(String uriString)
判断URI是否为File或者Content类型URI File类型URI表示私有文件 Content类型URI表示共享文件,如图片,音频...
static Uri string2Uri(String uriString)
String getPath()
获取文件本地路径,若文件不存在,返回null
void setForceUpload(boolean forceUpload)
设置文件是否强制重新上传,默认false
String getThumbPath()
获取缩略图文件的本地路径,若文件不存在,返回null
String getDisplayName()
获取文件的显示名。可以和文件名不同,仅用于界面展示
boolean forceUpload
如果服务器存在相同的附件文件,是否强制重新上传 , 默认false
boolean isForceUpload()
文件是否强制重新上传
void setMd5(String md5)
设置文件内容MD5
NimStorageType storageType()
void setPath(String path)
设置文件路径
void setNosTokenSceneKey(String nosTokenSceneKey)
设置文件上传时的nos scene
String getThumbPathForSave()
获取用于保存缩略图文件的位置
void load(JSONObject json)
void setDisplayName(String displayName)
设置文件显示名
FileAttachment(String attach)
void setUrl(String url)
设置文件在服务器上的下载url
long getSize()
获取文件大小,单位为byte
String toJson(boolean send)
将消息附件序列化为字符串,存储到消息数据库或发送到服务器。
String getPathForSave()
获取用于保存该文件的位置
String getNosTokenSceneKey()
获取文件上传时的nos scene
void setSize(long size)
设置文件大小,单位为byte