策略模式实现 retrofit 的get和post请求的公共参数(一)

策略模式的作用,作用是替换if,elst if ,switch case,可是为什么我就替换不了呢?

比如:
图书价格,初级会员9折,高级会员打8折
通常实现:

private double getPrice(int grade, double price) {
        switch (grade) {
            case 1:
                //初级会员
                price = price * 0.9;
                break;
            case 2:
                //高级会员
                price = price * 0.8;
                break;
        }
        return price;
    }

//或者
private double getPrice(int grade, double price) {
        if (grade == 1) {
            price = price * 0.9;
        } else if (grade == 2) {
            price = price * 0.8;
        }
        return price;
    }

//或者
private double getPrice(int grade, double price) {
        if (grade == 1) {
            return price * 0.9;
        }
        if (grade == 2) {
            return price * 0.8;
        }
        return price;
    }

当然第三种写法没必要

策略模式实现:

public interface IPrice {
    public double calcPrice(double price);
}


//初级
public class Primary implements IPrice{
    @Override
    public double calcPrice(double price) {
        return price * 0.9;
    }
}

//高级
public class Senior implements IPrice{
    @Override
    public double calcPrice(double price) {
        return price * 0.8;
    }
}

//上下文
public class PriceContext {
    private IPrice iPrice;
    public PriceContext(IPrice iPrice){
        this.iPrice = iPrice;
    }

    public double count(double price){
        return iPrice.calcPrice(price);
    }
}
//客户端(需求:根据会员等级判断,得到相应的一个价格)
方案一:
private double getPrice(int grade, double price) {
price = new PriceContext(new Primary()).count(price);
price = new PriceContext(new Senior()).count(price);
return price;
}


方案一相当于 
if(1){初级会员} 
if(2){高级会员}
也就是说其中一个方案得到价格后,仍然会去判断第二个,当然不是我想要的

方案二:
private double getPrice(int grade, double price) {
        switch (grade) {
            case 1:
                //初级会员
                price = new PriceContext(new Primary()).count(price);
                break;
            case 2:
                //高级会员
                price = new PriceContext(new Senior()).count(price);
                break;
        }
        return price;
    }

貌似符合要求了,但是策略模式就是为了解决if elseif switch case 的啊,
怎么用了策略模式我还是写了switch case

如果此时我想增加一个中级会员,是不是要再加一个case,说好的开闭原则呢?

我们期望的:
新增一个中级会员,我不想修改客户端

//好办,还有一个上下文可以修改,我们把客户端的代码放在客户端就好了
public class PriceContext {
    private IPrice iPrice;
    private int grade;
    public PriceContext(int grade){
        this.grade = grade;
    }

    public double count(double price){
        switch (grade) {
            case 1:
                //初级会员
                iPrice = new Primary();
                break;
            case 2:
                //高级会员
                iPrice = new Senior();
                break;
        }

        return iPrice.calcPrice(price);
    }
}
//客户端
private double getPrice(int grade, double price) {
price = new PriceContext(grade).count(price);
return price;
}
此时如果增加一个中级会员,直接在Context中增加一个case即可,客户端无需修改

下面进入正题,同样的方法实现retrofit在get和post中的公共参数配置

retrofit中公共参数是通过拦截器进行配置的

OkHttpClient.Builder builder = new OkHttpClient.Builder();
builder.addInterceptor(factory.initQuery(context));

//公共参数
    public Interceptor initQuery(final Context context) {


        Interceptor addQueryParameterInterceptor = new Interceptor() {
            @Override
            public Response intercept(Chain chain) throws IOException {
                Request request = chain.request();
                //配置公共参数
                request = new ParamsContext(request, context).getInRequest();
                return chain.proceed(request);
            }
        };
        return addQueryParameterInterceptor;
    }

照葫芦画瓢

public interface IRequestParam {

    Request getRequest(Request request, Context context);
}

//get
public class GetRequestParams implements IRequestParam {
    @Override
    public Request getRequest(Request request, Context context) {

        //添加公共参数
        HttpUrl modifiedUrl = request.url().newBuilder()
                .addQueryParameter(CLIENT, AppTools.getClient(context))
                .addQueryParameter(VERSION, AppTools.getAppVersion(context))
                .addQueryParameter(TOKEN, AppTools.getToken(context))
                .build();

        return request.newBuilder().url(modifiedUrl).build();
    }
}

//post
public class PostRequestParams implements IRequestParam {
    @Override
    public Request getRequest(Request request, Context context) {

        if (request.body() instanceof FormBody) {
            FormBody.Builder bodyBuilder = new FormBody.Builder();

            FormBody formBody = (FormBody) request.body();

            for (int i = 0; i < formBody.size(); i++) {
                bodyBuilder.addEncoded(formBody.encodedName(i), formBody.encodedValue(i));
            }
            formBody = bodyBuilder.addEncoded(CLIENT, AppTools.getClient(context))
                    .addEncoded(VERSION, AppTools.getAppVersion(context))
                    .addEncoded(TOKEN, AppTools.getToken(context))
                    .build();
            request = request.newBuilder().post(formBody).build();
        }
        return request;
    }
}

//上下文
public class ParamsContext {

    private IRequestParam iRequestParam;
    private Context context;
    private Request request;

    public ParamsContext(Request request, Context context) {
        this.context = context;
        this.request = request;
    }

    public Request getInRequest() {
        switch (request.method()) {
            case "GET":
                iRequestParam = new GetRequestParams();
                break;
            case "POST":
                iRequestParam = new PostRequestParams();
                break;
        }
        return iRequestParam.getRequest(request, context);
    }
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是使用Retrofit2进行POST异步请求的示例代码: 1.首先,在build.gradle文件中添加Retrofit2和Gson的依赖: ```gradle dependencies { // Retrofit2 implementation 'com.squareup.retrofit2:retrofit:2.9.0' 'com.squareup.retrofit2:converter-gson:2.9.0' // Gson implementation 'com.google.code.gson:gson:2.8.6' } ``` 2.创建一个接口,用于定义POST请求的URL和参数: ```java public interface PostRequest_Interface { @POST("translate?doctype=json&jsonversion=&type=&keyfrom=&model=&mid=&imei=&vendor=&screen=&ssid=&network=&abtest=") @FormUrlEncoded Call<Translation1> getCall(@Field("i") String targetSentence); } ``` 3.创建一个实体类,用于接收服务器返回的JSON数据: ```java public class Translation1 { private int errorCode; private String query; private List<String> translation; // 省略getter和setter方法 } ``` 4.在Activity中发起POST异步请求: ```java public class MainActivity extends AppCompatActivity { private TextView mTvResult; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mTvResult = findViewById(R.id.tv_result); // 创建Retrofit对象 Retrofit retrofit = new Retrofit.Builder() .baseUrl("http://fanyi.youdao.com/") .addConverterFactory(GsonConverterFactory.create()) .build(); // 创建网络请求接口实例 PostRequest_Interface request = retrofit.create(PostRequest_Interface.class); // 发起POST异步请求 Call<Translation1> call = request.getCall("hello"); call.enqueue(new Callback<Translation1>() { @Override public void onResponse(Call<Translation1> call, Response<Translation1> response) { Translation1 translation = response.body(); if (translation != null) { mTvResult.setText(translation.getTranslation().get(0)); } } @Override public void onFailure(Call<Translation1> call, Throwable t) { mTvResult.setText("请求失败:" + t.getMessage()); } }); } } ``` 在上述代码中,我们首先创建了一个Retrofit对象,并指定了请求的基础URL和Gson转换器。然后,我们创建了一个网络请求接口实例,并调用其中的getCall()方法发起POST异步请求。最后,我们在回调方法中处理服务器返回的数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哆啦A梦z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值