我在移动应用程序中使用WooCommerce Rest Api。现在我想更改个人资料图片,但我不知道如何通过WooCommerce Rest Api将图片上传到Wordpress站点,我已经尝试过了,但显示HTTPerror403:
Future<String> uploadImage(File imageFile) async {
final StringBuffer url =
new StringBuffer("$serverName/wp-json/wp/v2/media");
Dio dio = new Dio();
try {
FormData formData = FormData.fromMap(
{"file": await MultipartFile.fromFile(imageFile.path)},
);
dio.options.headers["Authorization"] = "Bearer $token";
var response = await dio.post(
url.toString(),
data: formData,
);
var respon = response.data;
return respon["url"];
} on DioError catch (e) {
print(e.message);
} catch (e) {
print(e);
}
}有谁可以帮我?
发布于 2021-02-01 14:37:20
您的formData阵列必须遵循woo-commerce rest API标准。请查找product properties和product image properties的woocommerce rest API文档
我有PHP代码,与图像一起工作。如果这对你转换成flutter代码有用的话,让我和你分享一下。images将使用src作为url的阵列
$data = [
'name' => 'Premium Quality',
'type' => 'simple',
'regular_price' => '21.99',
'description' => 'Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo.',
'short_description' => 'Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.',
'categories' => [
[
'id' => 9
],
[
'id' => 14
]
],
'images' => [
[
'src' => 'http://demo.woothemes.com/woocommerce/wp-content/uploads/sites/56/2013/06/T_2_front.jpg'
],
[
'src' => 'http://demo.woothemes.com/woocommerce/wp-content/uploads/sites/56/2013/06/T_2_back.jpg'
]
]
];
print_r($woocommerce->post('products', $data));https://stackoverflow.com/questions/65987952
复制相似问题