我一直在努力找出如何通过post请求的主体传递文件。我在网上试了一些东西,但没有什么能和我的用例完全匹配。
这是我的服务器代码的邮递员屏幕截图:
所以,正如你所看到的,“photo”在body部分是一个键(文件),值是一个图像文件。这是一个post请求,在查询成功时不返回任何响应(只显示创建时的状态,如屏幕截图所示)[另请注意:它需要auth token作为header param,userid作为path param)
终结点代码:
static final String ENDPOINT_UPLOAD_PROFILE_PHOTO= BuildConfig.BASE_URL
+ "/service-profile/v1/member/photo/{userId}";
@Override
public Single<JSONObject> doUploadPhoto(String userId, File filepath) {
Rx2ANRequest.MultiPartBuilder post = Rx2AndroidNetworking.upload(ApiEndPoint.ENDPOINT_UPLOAD_PROFILE_PHOTO)
.addMultipartFile("photo",filepath)
.addHeaders("Authorization", mApiHeader.getFormattedProtectedApiHeader())
.addHeaders("content-type", "multipart/form-data")
.setPriority(Priority.HIGH)
.addMultipartParameter("photo",filepath.getAbsolutePath())
.addPathParameter("userId",userId);
return post.build()
.getObjectSingle(JSONObject.class);
File file = new File(AppPreferencesHelper.getInstance().getPhotoFile());
//preferences has the path of the file , something like : /storage/emulated/0/DCIM/1566415330315.jpg
getCompositeDisposable().add(getDataManager().updateCurrentUserPhotoUploadApiCall(file)
.subscribeOn(getSchedulerProvider().io())
.observeOn(getSchedulerProvider().ui())
.subscribe(response -> {
Log.d("fileupload", "it is successful" + response);
if (!isViewAttached()) {
return;
}
}, throwable -> {
if (!isViewAttached()) {
return;
}
Log.d("fileupload", "error: ");
getMvpView().hideLoading();
// handle the profile retrieval error here
//getMvpView().showDialog(R.string.unknown_error, R.string.unknown_error_message);
if (throwable instanceof ANError) {
ANError anError = (ANError) throwable;
Log.d("fileupload", "error: " + anError.getErrorCode());
handleApiError(anError);
}
}));
@Override
public Single<JSONObject> updateCurrentUserPhotoUploadApiCall(File file) {
return mApiHelper.doUploadPhoto(mPreferencesHelper.getCurrentUserId(), file);
}
Rx2ANRequest.PostRequestBuilder post = Rx2AndroidNetworking.post(processUrl(ApiEndPoint.ENDPOINT_UPLOAD_PROFILE_PHOTO)) // Please note : processUrl(ApiEndPoint.ENDPOINT_UPLOAD_PROFILE_PHOTO)) = https://myapps.com/service-profile/v1/member/photo/{userId}
.addHeaders("Authorization", mApiHeader.getFormattedProtectedApiHeader())
.addPathParameter("userId", userId)
.addBodyParameter("photo",filepath.getAbsolutePath());
OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW");
RequestBody body = RequestBody.create(mediaType, "------WebKitFormBoundary7MA4YWxkTrZ\r\nContent-Disposition: form-data; name=\"photo\"; filename=\"1ab6ef77b355e9acd7cc9b82b5c8ec4f.jpg\"\r\nContent-Type: image/jpeg\r\n\r\n\r\n------WebKitFormBoundary7MA4YWxkTrZu0gW--");
Request request = new Request.Builder()
.url("https://myapps.com/api/service-profile/v1/member/photo/9ea899b8-b271-486b-ae64-443a17f06a39")
.post(body)
.addHeader("content-type", "multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW")
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.addHeader("Authorization", "Bearer eyJraWQiOiJXZ3NucHRZekZYMnZsRTJ2TEJlUFpjSlJ4TU93SFRqcGkydDZAwdW03bzU5d2xRTFkxUU1HMGg3Iiwic2NwIjpbIm9mZmxpbmVfYWNjZXNzIiwicHJvZmlsZSIsIm9wZW5pZCIsIm1lbWJlciIsImVtYWlsIl0sInN1YiI6InZhcmFuaGErd3BkZXZsYUBjbnZ3cC5jb20iLCJtZW1iZXIucmVhZCI6dHJ1ZSwibWVtYmVyLndyaXRlIjp0cnVlfQ.LQhea6roQyQNIRnb3XWVuQZjoid2yn7TT-cgbdDeUnbMCUtFnOiHKPOLo_zpRr0bB429-yuLeSLdLjj_mF-PESbr0SfvNj01N-AWtYvyn9gEvcqS3hHHzPI44RDYkU8CtenByxwDBLUTlrdAGW7Xmi-UtGdd2_kaM8zkZoVWRS8dbymCVfZyoYr7DeR9hFZtD8RCtYRMRJrgQGZoMv7_1oCJyo8lAWuMpUmZfsEscOOw44hFoNADv221l70mbTIb-XwA")
.addHeader("User-Agent", "PostmanRuntime/7.15.2")
.addHeader("Accept", "*/*")
.addHeader("Cache-Control", "no-cache")
.addHeader("Postman-Token", "3f81374d-d895-4a55-9122-297,3ff3b3f8-7149-46b9-887e-db1b4")
.addHeader("Host", "myapps.com")
.addHeader("Cookie", "AWSALB=HKdluG7WMh8PQmgNrYwRK+fpDEAE3DKnRQXIWOngg7Tn9kzEy5lQWhSsU45P7aLxk7Y")
.addHeader("Accept-Encoding", "gzip, deflate")
.addHeader("Content-Length", "17805")
.addHeader("Connection", "keep-alive")
.addHeader("cache-control", "no-cache")
.build();
Response response = client.newCall(request).execute();
最佳答案
试试这个。我是根据你的邮递员请求查询来做的,很肯定会成功的。
OkHttpClient okHttpClient = new OkHttpClient();
MultipartBody.Builder builder = new MultipartBody.Builder();
builder.setType(MultipartBody.FORM);
builder.addFormDataPart("photo", filepath.getAbsolutePath());
String url = ApiEndPoint.ENDPOINT_UPLOAD_PROFILE_PHOTO;
RequestBody fileBody = RequestBody.create(MediaType.parse("image/jpeg"), filepath);
builder.addFormDataPart("photo", filepath.getName(), fileBody);
RequestBody requestBody = builder.build();
Request request = new Request.Builder()
.url(processUrl(url))
.addHeader("Authorization",mApiHeader.getFormattedProtectedApiHeader())
.post(requestBody)
.build();
okHttpClient.newCall(request).enqueue(new okhttp3.Callback(){
@Override
public void onFailure(Call call, IOException e) {
Log.e("OkHttp1", "onFailure: "+e.toString());
}
@Override
public void onResponse(Call call, Response response) throws IOException {
ResponseBody body = response.body();
if (body != null) {
Log.e("OkHttp1", "onResponse: " + body.string());
} else {
Log.e("OkHttp1", "onResponse: null");
}
}
});
关于android - 如何为rxjava2 androidnetworking POST请求传递多部分body参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57598276/
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我刚刚为fedora安装了emacs。我想用emacs编写ruby。为ruby提供代码提示、代码完成类型功能所需的工具、扩展是什么? 最佳答案 ruby-mode已经包含在Emacs23之后的版本中。不过,它也可以通过ELPA获得。您可能感兴趣的其他一些事情是集成RVM、feature-mode(Cucumber)、rspec-mode、ruby-electric、inf-ruby、rinari(用于Rails)等。这是我当前用于Ruby开发的Emacs配置:https://github.com/citizen428/emacs
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"
我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)
两者都可以defsetup(options={})options.reverse_merge:size=>25,:velocity=>10end和defsetup(options={}){:size=>25,:velocity=>10}.merge(options)end在方法的参数中分配默认值。问题是:哪个更好?您更愿意使用哪一个?在性能、代码可读性或其他方面有什么不同吗?编辑:我无意中添加了bang(!)...并不是要询问nobang方法与bang方法之间的区别 最佳答案 我倾向于使用reverse_merge方法:option
我有一个只接受一个参数的方法:defmy_method(number)end如果使用number调用方法,我该如何引发错误??通常,我如何定义方法参数的条件?比如我想在调用的时候报错:my_method(1) 最佳答案 您可以添加guard在函数的开头,如果参数无效则引发异常。例如:defmy_method(number)failArgumentError,"Inputshouldbegreaterthanorequalto2"ifnumbereputse.messageend#=>Inputshouldbegreaterthano
我没有找到太多关于如何执行此操作的信息,尽管有很多关于如何使用像这样的redirect_to将参数传递给重定向的建议:action=>'something',:controller=>'something'在我的应用程序中,我在路由文件中有以下内容match'profile'=>'User#show'我的表演Action是这样的defshow@user=User.find(params[:user])@title=@user.first_nameend重定向发生在同一个用户Controller中,就像这样defregister@title="Registration"@user=Use
对于作为String#tr参数的单引号字符串文字中反斜杠的转义状态,我觉得有些神秘。你能解释一下下面三个例子之间的对比吗?我特别不明白第二个。为了避免复杂化,我在这里使用了'd',在双引号中转义时不会改变含义("\d"="d")。'\\'.tr('\\','x')#=>"x"'\\'.tr('\\d','x')#=>"\\"'\\'.tr('\\\d','x')#=>"x" 最佳答案 在tr中转义tr的第一个参数非常类似于正则表达式中的括号字符分组。您可以在表达式的开头使用^来否定匹配(替换任何不匹配的内容)并使用例如a-f来匹配一
我正在使用RubyonRails3.0.9,我想生成一个传递一些自定义参数的link_toURL。也就是说,有一个articles_path(www.my_web_site_name.com/articles)我想生成如下内容:link_to'Samplelinktitle',...#HereIshouldimplementthecode#=>'http://www.my_web_site_name.com/articles?param1=value1¶m2=value2&...我如何编写link_to语句“alàRubyonRailsWay”以实现该目的?如果我想通过传递一些