您的位置:首页 > 汽车 > 时评 > 外包接单网_最近热点新闻素材_手机seo关键词优化_最有效的广告宣传方式

外包接单网_最近热点新闻素材_手机seo关键词优化_最有效的广告宣传方式

2025/1/6 21:52:03 来源:https://blog.csdn.net/xuelian3015/article/details/143064756  浏览:    关键词:外包接单网_最近热点新闻素材_手机seo关键词优化_最有效的广告宣传方式
外包接单网_最近热点新闻素材_手机seo关键词优化_最有效的广告宣传方式

在 ArkTS 中实现文件上传可以通过以下步骤:

一、准备工作

  1. 确定上传目标:明确文件要上传到的服务器地址和接口。确保服务器端已经配置好接收文件上传的功能。

二、引入必要的模块

在 ArkTS 文件中,引入与网络请求和文件操作相关的模块。例如:

import { rcp } from '@kit.RemoteCommunicationKit';
import { picker } from '@kit.CoreFileKit';
import { common } from '@kit.AbilityKit';
import fs from '@ohos.file.fs';

三、实现文件上传逻辑

  1. 创建文件选择器实例:
	  const documentViewPicker = new picker.DocumentViewPicker(context);let documentSelectOptions = new picker.DocumentSelectOptions();documentSelectOptions.maxSelectNumber = 1documentSelectOptions.fileSuffixFilters = ['.png', '.txt', '.mp4', '.jpg'];//选择是否对指定文件或目录授权,true为授权,当为true时,defaultFilePathUri为必选参数,拉起文管授权界面;false为非授权,拉起常规文管界面(可选)documentSelectOptions.authMode = true;
  1. 选择文件,配置上传服务器的参数,代码如下:
      documentViewPicker.select(documentSelectOptions).then(async (documentSelectResult: Array<string>) => {// 文件上传的时候一定要先拷贝一份,然后在进行上传,要不然没权限操作文件const context = getContext(this)const fileType = 'jpg'// (以时间戳)生成一个新的文件名const fileName = Date.now() + '.' + fileType// 通过缓存路径+文件名 拼接出完整的路径const copyFilePath = context.cacheDir + '/' + fileName// 将文件 拷贝到 临时目录const file = fs.openSync(documentSelectResult[0], fs.OpenMode.READ_ONLY)fs.copyFileSync(file.fd, copyFilePath)const formFieldFileValue: rcp.FormFieldFileValue = {contentType: "image/png",remoteFileName: fileName,contentOrPath: copyFilePath,};const formData = new rcp.MultipartForm ({'file': formFieldFileValue // file表示服务器端接收的数据的属性名})axiosInstance.post(CommonConstant.BASE_URL+CommonConstant.UPLOAD_PATH,formData).then((response:AxiosResponse)=>{console.error("上传文件",JSON.stringify(response))}).catch((err:BusinessError)=>{console.info("上传文件接口报错", JSON.stringify(err));})})
  1. 发送请求

以下是一个示例代码:

  async onUpload(){try {let context = getContext(this) as common.Context; // 请确保 getContext(this) 返回结果为 UIAbilityContext// 创建文件选择器实例const documentViewPicker = new picker.DocumentViewPicker(context);let documentSelectOptions = new picker.DocumentSelectOptions();documentSelectOptions.maxSelectNumber = 1documentSelectOptions.fileSuffixFilters = ['.png', '.txt', '.mp4', '.jpg'];//选择是否对指定文件或目录授权,true为授权,当为true时,defaultFilePathUri为必选参数,拉起文管授权界面;false为非授权,拉起常规文管界面(可选)documentSelectOptions.authMode = true;documentViewPicker.select(documentSelectOptions).then(async (documentSelectResult: Array<string>) => {// 文件上传的时候一定要先拷贝一份,然后在进行上传,要不然没权限操作文件const context = getContext(this)const fileType = 'jpg'// (以时间戳)生成一个新的文件名const fileName = Date.now() + '.' + fileType// 通过缓存路径+文件名 拼接出完整的路径const copyFilePath = context.cacheDir + '/' + fileName// 将文件 拷贝到 临时目录const file = fs.openSync(documentSelectResult[0], fs.OpenMode.READ_ONLY)fs.copyFileSync(file.fd, copyFilePath)const formFieldFileValue: rcp.FormFieldFileValue = {contentType: "image/png",remoteFileName: fileName,contentOrPath: copyFilePath,};const formData = new rcp.MultipartForm ({'file': formFieldFileValue // file表示服务器端接收的数据的属性名})// axiosInstance是自定义的请求方法     axiosInstance.post(CommonConstant.BASE_URL+CommonConstant.UPLOAD_PATH,formData).then((response:AxiosResponse)=>{console.error("上传文件",JSON.stringify(response))}).catch((err:BusinessError)=>{console.info("上传文件接口报错", JSON.stringify(err));})})} catch (error) {console.error('文件上传错误:', error);}}

效果如图:
在这里插入图片描述
在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com