我从我的图库中获取图像,现在想在使用Multipart
请求的Http 正文参数中使用此图像。我无法弄清楚应该在 Multipart 请求中为 Image 传递什么。
我的变量image
在方法调用后包含我的画廊图像。
final ImagePicker _picker = ImagePicker();
File? image;
var fileContent;
var fileContentBase64;
在我的应用程序中显示图像
Padding(
padding: const EdgeInsets.all(18.0),
child: image == null? Text("No file chosen"): Image.file(
File(image!.path),
width: 150,
fit: BoxFit.cover,
),
),
从图库中获取图像的功能
void filePicker() async {
final File? selectedImage =
await ImagePicker.pickImage(source: ImageSource.gallery);
print(selectedImage!.path);
setState(() {
image = selectedImage;
fileContent = image!.readAsBytesSync();
fileContentBase64 = base64.encode(fileContent);
});
}
现在在 Api 函数中我应该如何使用它?
Future<void> SaveCustomTestBooking() async {
var jsonResponse;
if (EncUserId.isNotEmpty) {
var postUri = Uri.parse("http://myAPIstomTestBooking");
var request = http.MultipartRequest('POST',postUri);
request.fields['VisitDate'] = '_selectedDate';
request.fields['EncUserId'] = 'EncUserId';
request.files.add(new http.MultipartFile.fromBytes(
"UserFile", File(image!.path).readAsBytesSync(),
filename:"Image.jpg",
contentType: MediaType('image', 'jpg')));
request.send().then((response){
if (response.statusCode == 200) {
print("Uploaded!");
Navigator.push(context, MaterialPageRoute(builder: (context) => DieticianAfterDateSelectPage(rresponse:DieticianEncBookingIdModel.fromJson(jsonResponse),)));
} else {
ScaffoldMessenger.of(context).showSnackBar(
SnackBar(content: Text("Somthing went wrong")));
throw Exception("Faild to fetch");
}
}
);}
}
这是使用多部分请求在 Http 正文参数中使用图像的代码示例。
request.files.add(new http.MultipartFile.fromBytes(
"thumbnail", File(thumbnailImage.path).readAsBytesSync(),
filename:"Image.jpg",
contentType: MediaType('image', 'jpg')));
这里的“缩略图”是 json 关键字名称。用你自己的。谢谢
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句