├── .gitignore ├── .idea ├── .name ├── compiler.xml ├── copyright │ └── profiles_settings.xml ├── encodings.xml ├── gradle.xml ├── misc.xml ├── modules.xml └── runConfigurations.xml ├── README.md ├── app ├── .gitignore ├── build.gradle ├── proguard-rules.pro └── src │ ├── androidTest │ └── java │ │ └── example │ │ └── com │ │ └── retrofit │ │ └── ApplicationTest.java │ ├── main │ ├── AndroidManifest.xml │ ├── java │ │ └── example │ │ │ └── com │ │ │ └── retrofit │ │ │ ├── api │ │ │ └── ApiService.java │ │ │ ├── callback │ │ │ └── BaseCallback.java │ │ │ ├── model │ │ │ ├── BaseModel.java │ │ │ └── TestModel.java │ │ │ ├── ui │ │ │ ├── BaseActivity.java │ │ │ └── MainActivity.java │ │ │ └── utils │ │ │ ├── Logger.java │ │ │ └── RetrofitUtils.java │ └── res │ │ ├── layout │ │ └── activity_main.xml │ │ ├── mipmap-hdpi │ │ └── ic_launcher.png │ │ ├── mipmap-mdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxxhdpi │ │ └── ic_launcher.png │ │ ├── values-w820dp │ │ └── dimens.xml │ │ └── values │ │ ├── colors.xml │ │ ├── dimens.xml │ │ ├── strings.xml │ │ └── styles.xml │ └── test │ └── java │ └── example │ └── com │ └── retrofit │ └── ExampleUnitTest.java ├── build.gradle ├── gradle.properties ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat └── settings.gradle /.gitignore: -------------------------------------------------------------------------------- 1 | *.iml 2 | .gradle 3 | /local.properties 4 | /.idea/workspace.xml 5 | /.idea/libraries 6 | .DS_Store 7 | /build 8 | /captures 9 | -------------------------------------------------------------------------------- /.idea/.name: -------------------------------------------------------------------------------- 1 | RetrofitUtils -------------------------------------------------------------------------------- /.idea/compiler.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | -------------------------------------------------------------------------------- /.idea/copyright/profiles_settings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | -------------------------------------------------------------------------------- /.idea/encodings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /.idea/gradle.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 22 | 23 | -------------------------------------------------------------------------------- /.idea/misc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 26 | 27 | 28 | 29 | 30 | Android API 23 Platform 31 | 32 | 37 | 38 | 39 | 40 | 41 | 42 | -------------------------------------------------------------------------------- /.idea/modules.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /.idea/runConfigurations.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 11 | 12 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # RetrofitUtils 2 | 3 | 请求: 4 |
5 | 6 | ```Java 7 | RetrofitUtils.getInstance(this) 8 | .create(ApiService.class) 9 | .addPara(2, 20) 10 | .enqueue(new BaseCallback>() { 11 | 12 | @Override 13 | protected void onAfter() { 14 | dismissProgress(); 15 | } 16 | 17 | @Override 18 | protected void onSuccess(BaseModel response) { 19 | 20 | tvResult.setText("status:" + response.isStatus() + "\n" + response.getData().get(0).getDescription()); 21 | } 22 | 23 | @Override 24 | protected void onNoData(String msg) { 25 | showToast(msg); 26 | } 27 | 28 | @Override 29 | protected void onFail(String msg) { 30 | showToast(msg); 31 | } 32 | }); 33 | ``` 34 | -------------------------------------------------------------------------------- /app/.gitignore: -------------------------------------------------------------------------------- 1 | /build 2 | -------------------------------------------------------------------------------- /app/build.gradle: -------------------------------------------------------------------------------- 1 | apply plugin: 'com.android.application' 2 | 3 | android { 4 | compileSdkVersion 23 5 | buildToolsVersion "23.0.3" 6 | 7 | defaultConfig { 8 | applicationId "example.com.retrofit" 9 | minSdkVersion 19 10 | targetSdkVersion 23 11 | versionCode 1 12 | versionName "1.0" 13 | } 14 | 15 | buildTypes { 16 | debug { 17 | buildConfigField "boolean", "ISDEBUG", "true" 18 | } 19 | release { 20 | buildConfigField "boolean", "ISDEBUG", "true" 21 | //混淆 22 | minifyEnabled false 23 | //优化zipAlign 24 | zipAlignEnabled true 25 | //移除无用的resource 26 | shrinkResources true 27 | proguardFiles 'proguard-rules.pro', getDefaultProguardFile('proguard-android.txt') 28 | } 29 | } 30 | } 31 | 32 | dependencies { 33 | compile fileTree(dir: 'libs', include: ['*.jar']) 34 | testCompile 'junit:junit:4.12' 35 | compile 'com.android.support:appcompat-v7:23.4.0' 36 | compile 'com.squareup.retrofit2:retrofit:2.1.0' 37 | compile 'com.squareup.retrofit2:converter-gson:2.1.0' 38 | compile 'com.squareup.okhttp3:logging-interceptor:3.1.2' 39 | compile 'com.apkfuns.logutils:library:1.0.6' 40 | 41 | } 42 | -------------------------------------------------------------------------------- /app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # By default, the flags in this file are appended to flags specified 3 | # in /Users/weihuajian/Library/Android/sdk/tools/proguard/proguard-android.txt 4 | # You can edit the include path and order by changing the proguardFiles 5 | # directive in build.gradle. 6 | # 7 | # For more details, see 8 | # http://developer.android.com/guide/developing/tools/proguard.html 9 | 10 | # Add any project specific keep options here: 11 | 12 | # If your project uses WebView with JS, uncomment the following 13 | # and specify the fully qualified class name to the JavaScript interface 14 | # class: 15 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 16 | # public *; 17 | #} 18 | -------------------------------------------------------------------------------- /app/src/androidTest/java/example/com/retrofit/ApplicationTest.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit; 2 | 3 | import android.app.Application; 4 | import android.test.ApplicationTestCase; 5 | 6 | /** 7 | * Testing Fundamentals 8 | */ 9 | public class ApplicationTest extends ApplicationTestCase { 10 | public ApplicationTest() { 11 | super(Application.class); 12 | } 13 | } -------------------------------------------------------------------------------- /app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 7 | 8 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/api/ApiService.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.api; 2 | 3 | import example.com.retrofit.model.BaseModel; 4 | import example.com.retrofit.model.TestModel; 5 | import retrofit2.Call; 6 | import retrofit2.http.GET; 7 | import retrofit2.http.Query; 8 | 9 | /** 10 | * Created by weihuajian on 16/6/22. 11 | */ 12 | public interface ApiService { 13 | 14 | @GET("top/list") 15 | Call> addPara(@Query("page") int page, @Query("rows") int rows); 16 | } 17 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/callback/BaseCallback.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.callback; 2 | 3 | import example.com.retrofit.model.BaseModel; 4 | import retrofit2.Call; 5 | import retrofit2.Callback; 6 | import retrofit2.Response; 7 | 8 | /** 9 | * Created by weihuajian on 16/6/22. 10 | */ 11 | public abstract class BaseCallback implements Callback { 12 | 13 | @Override 14 | public void onResponse(Call call, Response response) { 15 | 16 | int code = response.raw().code(); 17 | if (code == 200) { 18 | /** 19 | * 这里我只实现了成功和失败的回调,还可以根据接口返回的状态信息实现相应的回调 20 | * */ 21 | T t = (T) response.body(); 22 | if (t.isStatus()) { 23 | onSuccess(t); 24 | } else { 25 | /** 26 | * 如果接口返回了msg,就不要使用自定义的msg 27 | * */ 28 | onFail(ERR_MSG.ERROR_NO_RESULT); 29 | } 30 | } else if (code == 204) { 31 | onNoData(ERR_MSG.NO_DATA); 32 | } else if (code == 400) { 33 | onFail(ERR_MSG.ERR0E_400); 34 | } else if (code == 500) { 35 | onFail(ERR_MSG.ERROR_500); 36 | } else { 37 | onFail(ERR_MSG.ERROR_NO_RESULT); 38 | } 39 | 40 | onAfter(); 41 | } 42 | 43 | @Override 44 | public void onFailure(Call call, Throwable t) { 45 | onFail(t.getMessage()); 46 | onAfter(); 47 | } 48 | 49 | /** 50 | * 请求成功的回调 51 | */ 52 | protected abstract void onSuccess(T response); 53 | 54 | /** 55 | * 请求完的回调,可以在里面停止刷新控件,可以不实现 56 | */ 57 | protected void onAfter() { 58 | } 59 | 60 | /** 61 | * 没有数据的回调,可以不实现 62 | */ 63 | protected void onNoData(String msg) { 64 | 65 | } 66 | 67 | /** 68 | * 请求失败的回调 69 | */ 70 | protected abstract void onFail(String msg); 71 | 72 | 73 | /** 74 | * 自定义的错误信息 75 | */ 76 | class ERR_MSG { 77 | private static final String NO_DATA = "暂无数据"; 78 | private static final String ERR0E_400 = "请求失败"; 79 | private static final String ERROR_500 = "服务器错误"; 80 | private static final String ERROR_NO_RESULT = "未知错误"; 81 | } 82 | 83 | } 84 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/model/BaseModel.java: -------------------------------------------------------------------------------- 1 | /** 2 | * created by jiang, 16/2/18 3 | * Copyright (c) 2016, jyuesong@gmail.com All Rights Reserved. 4 | * * # # 5 | * # _oo0oo_ # 6 | * # o8888888o # 7 | * # 88" . "88 # 8 | * # (| -_- |) # 9 | * # 0\ = /0 # 10 | * # ___/`---'\___ # 11 | * # .' \\| |# '. # 12 | * # / \\||| : |||# \ # 13 | * # / _||||| -:- |||||- \ # 14 | * # | | \\\ - #/ | | # 15 | * # | \_| ''\---/'' |_/ | # 16 | * # \ .-\__ '-' ___/-. / # 17 | * # ___'. .' /--.--\ `. .'___ # 18 | * # ."" '< `.___\_<|>_/___.' >' "". # 19 | * # | | : `- \`.;`\ _ /`;.`/ - ` : | | # 20 | * # \ \ `_. \_ __\ /__ _/ .-` / / # 21 | * # =====`-.____`.___ \_____/___.-`___.-'===== # 22 | * # `=---=' # 23 | * # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # 24 | * # # 25 | * # 佛祖保佑 永无BUG # 26 | * # # 27 | */ 28 | 29 | package example.com.retrofit.model; 30 | 31 | import com.google.gson.annotations.SerializedName; 32 | 33 | import java.io.Serializable; 34 | import java.util.List; 35 | 36 | /** 37 | * Created by weihuajian on 16/6/22. 38 | * 公共的响应体,可以根据自身项目接口的json结构自己定义 39 | */ 40 | public class BaseModel implements Serializable{ 41 | 42 | @SerializedName("status") 43 | private boolean status; 44 | @SerializedName("total") 45 | private int total; 46 | @SerializedName("tngou") 47 | private List data; 48 | 49 | 50 | public boolean isStatus() { 51 | return status; 52 | } 53 | 54 | public void setStatus(boolean status) { 55 | this.status = status; 56 | } 57 | 58 | public int getTotal() { 59 | return total; 60 | } 61 | 62 | public void setTotal(int total) { 63 | this.total = total; 64 | } 65 | 66 | public List getData() { 67 | return data; 68 | } 69 | 70 | public void setData(List data) { 71 | this.data = data; 72 | } 73 | } 74 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/model/TestModel.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.model; 2 | 3 | 4 | import com.google.gson.annotations.SerializedName; 5 | 6 | import java.io.Serializable; 7 | 8 | /** 9 | * Created by weihuajian on 16/6/22. 10 | */ 11 | public class TestModel implements Serializable { 12 | 13 | 14 | /** 15 | * count : 0 16 | * description : “这有一定的随机性,如果一只燕子刚好发现这里气温合适,通风比较好,食物充足,又没人打扰,就会让同伴都到这里来 17 | * fcount : 0 18 | * fromname : 中国青年网 19 | * fromurl : http://news.youth.cn/kj/201606/t20160622_8169789_4.htm 20 | * id : 11133 21 | * img : /top/default.jpg 22 | * keywords : 万只燕子齐聚电线 23 | * rcount : 0 24 | * time : 1466562669000 25 | * title : 万只燕子齐聚电线 保持相等间距似训练有素 26 | * topclass : 0 27 | */ 28 | 29 | @SerializedName("count") 30 | private int count; 31 | @SerializedName("description") 32 | private String description; 33 | @SerializedName("fcount") 34 | private int fcount; 35 | @SerializedName("fromname") 36 | private String fromname; 37 | @SerializedName("fromurl") 38 | private String fromurl; 39 | @SerializedName("id") 40 | private int id; 41 | @SerializedName("img") 42 | private String img; 43 | @SerializedName("keywords") 44 | private String keywords; 45 | @SerializedName("rcount") 46 | private int rcount; 47 | @SerializedName("time") 48 | private long time; 49 | @SerializedName("title") 50 | private String title; 51 | @SerializedName("topclass") 52 | private int topclass; 53 | 54 | public int getCount() { 55 | return count; 56 | } 57 | 58 | public void setCount(int count) { 59 | this.count = count; 60 | } 61 | 62 | public String getDescription() { 63 | return description; 64 | } 65 | 66 | public void setDescription(String description) { 67 | this.description = description; 68 | } 69 | 70 | public int getFcount() { 71 | return fcount; 72 | } 73 | 74 | public void setFcount(int fcount) { 75 | this.fcount = fcount; 76 | } 77 | 78 | public String getFromname() { 79 | return fromname; 80 | } 81 | 82 | public void setFromname(String fromname) { 83 | this.fromname = fromname; 84 | } 85 | 86 | public String getFromurl() { 87 | return fromurl; 88 | } 89 | 90 | public void setFromurl(String fromurl) { 91 | this.fromurl = fromurl; 92 | } 93 | 94 | public int getId() { 95 | return id; 96 | } 97 | 98 | public void setId(int id) { 99 | this.id = id; 100 | } 101 | 102 | public String getImg() { 103 | return img; 104 | } 105 | 106 | public void setImg(String img) { 107 | this.img = img; 108 | } 109 | 110 | public String getKeywords() { 111 | return keywords; 112 | } 113 | 114 | public void setKeywords(String keywords) { 115 | this.keywords = keywords; 116 | } 117 | 118 | public int getRcount() { 119 | return rcount; 120 | } 121 | 122 | public void setRcount(int rcount) { 123 | this.rcount = rcount; 124 | } 125 | 126 | public long getTime() { 127 | return time; 128 | } 129 | 130 | public void setTime(long time) { 131 | this.time = time; 132 | } 133 | 134 | public String getTitle() { 135 | return title; 136 | } 137 | 138 | public void setTitle(String title) { 139 | this.title = title; 140 | } 141 | 142 | public int getTopclass() { 143 | return topclass; 144 | } 145 | 146 | public void setTopclass(int topclass) { 147 | this.topclass = topclass; 148 | } 149 | } 150 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/ui/BaseActivity.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.ui; 2 | 3 | import android.app.ProgressDialog; 4 | import android.support.v7.app.AppCompatActivity; 5 | 6 | /** 7 | * Created by weihuajian on 16/6/25. 8 | */ 9 | public class BaseActivity extends AppCompatActivity { 10 | 11 | public ProgressDialog progress; 12 | 13 | public void showProgress(String title, String msg) { 14 | if (progress != null) { 15 | progress.dismiss(); 16 | } 17 | progress = ProgressDialog.show(this, title, msg, true, false); 18 | progress.setCancelable(true); 19 | progress.setCanceledOnTouchOutside(false); 20 | } 21 | 22 | public void dismissProgress() { 23 | if (progress != null) { 24 | progress.dismiss(); 25 | } 26 | } 27 | 28 | public void showWaitingMessage() { 29 | showProgress("", "加载中..."); 30 | } 31 | 32 | } 33 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/ui/MainActivity.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.ui; 2 | 3 | import android.os.Bundle; 4 | import android.text.TextUtils; 5 | import android.view.View; 6 | import android.view.View.OnClickListener; 7 | import android.widget.TextView; 8 | import android.widget.Toast; 9 | 10 | import example.com.retrofit.R; 11 | import example.com.retrofit.api.ApiService; 12 | import example.com.retrofit.callback.BaseCallback; 13 | import example.com.retrofit.model.BaseModel; 14 | import example.com.retrofit.model.TestModel; 15 | import example.com.retrofit.utils.RetrofitUtils; 16 | 17 | public class MainActivity extends BaseActivity implements OnClickListener { 18 | 19 | private TextView tvGET, tvResult; 20 | 21 | @Override 22 | protected void onCreate(Bundle savedInstanceState) { 23 | super.onCreate(savedInstanceState); 24 | setContentView(R.layout.activity_main); 25 | 26 | tvGET = (TextView) findViewById(R.id.tvGET); 27 | tvResult = (TextView) findViewById(R.id.tvResult); 28 | tvGET.setOnClickListener(this); 29 | 30 | } 31 | 32 | @Override 33 | public void onClick(View v) { 34 | switch (v.getId()) { 35 | case R.id.tvGET: 36 | requestApi(); 37 | break; 38 | } 39 | } 40 | 41 | 42 | private void requestApi() { 43 | showWaitingMessage(); 44 | RetrofitUtils.getInstance(this) 45 | .create(ApiService.class) 46 | .addPara(2, 20) 47 | .enqueue(new BaseCallback>() { 48 | 49 | @Override 50 | protected void onAfter() { 51 | dismissProgress(); 52 | } 53 | 54 | @Override 55 | protected void onSuccess(BaseModel response) { 56 | 57 | tvResult.setText("status:" + response.isStatus() + "\n" + response.getData().get(0).getDescription()); 58 | } 59 | 60 | @Override 61 | protected void onNoData(String msg) { 62 | showToast(msg); 63 | } 64 | 65 | @Override 66 | protected void onFail(String msg) { 67 | showToast(msg); 68 | } 69 | }); 70 | } 71 | 72 | private void showToast(String msg) { 73 | if (TextUtils.isEmpty(msg)) 74 | return; 75 | Toast.makeText(this, msg, Toast.LENGTH_LONG).show(); 76 | } 77 | } 78 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/utils/Logger.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.utils; 2 | 3 | import com.apkfuns.logutils.LogUtils; 4 | 5 | import example.com.retrofit.BuildConfig; 6 | 7 | /** 8 | * Created by weihuajian on 16/5/19. 9 | */ 10 | public class Logger { 11 | private static boolean isDEBUG = true; 12 | 13 | static { 14 | isDEBUG = BuildConfig.ISDEBUG; 15 | LogUtils.configAllowLog = isDEBUG; 16 | } 17 | 18 | public static void i(String value) { 19 | if (isDEBUG) { 20 | LogUtils.i(value); 21 | } 22 | } 23 | 24 | public static boolean isDEBUG() { 25 | return isDEBUG; 26 | } 27 | 28 | public static void d(String value) { 29 | if (isDEBUG) { 30 | LogUtils.d(value); 31 | } 32 | } 33 | 34 | 35 | public static void e(String value) { 36 | if (isDEBUG) { 37 | LogUtils.e(value); 38 | } 39 | } 40 | 41 | 42 | public static void v(String value) { 43 | if (isDEBUG) { 44 | LogUtils.v(value); 45 | } 46 | } 47 | 48 | /** 49 | * 打印json 50 | * 51 | * @param value 52 | */ 53 | public static void json(String value) { 54 | if (isDEBUG) { 55 | LogUtils.json(value); 56 | } 57 | } 58 | 59 | } 60 | -------------------------------------------------------------------------------- /app/src/main/java/example/com/retrofit/utils/RetrofitUtils.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit.utils; 2 | 3 | import android.content.Context; 4 | import android.net.ConnectivityManager; 5 | import android.net.NetworkInfo; 6 | 7 | import com.google.gson.Gson; 8 | import com.google.gson.GsonBuilder; 9 | 10 | import java.io.IOException; 11 | import java.util.concurrent.TimeUnit; 12 | 13 | import okhttp3.CacheControl; 14 | import okhttp3.HttpUrl; 15 | import okhttp3.Interceptor; 16 | import okhttp3.OkHttpClient; 17 | import okhttp3.Request; 18 | import okhttp3.Response; 19 | import retrofit2.Retrofit; 20 | import retrofit2.converter.gson.GsonConverterFactory; 21 | 22 | /** 23 | * Created by weihuajian on 16/6/22. 24 | */ 25 | public class RetrofitUtils { 26 | private static Context mContext; 27 | public static Retrofit retrofit = null; 28 | 29 | public static Retrofit getInstance(Context context) { 30 | mContext = context; 31 | if (retrofit == null) { 32 | OkHttpClient.Builder builder = new OkHttpClient.Builder(); 33 | 34 | // builder.addInterceptor(addQueryParameterInterceptor()); 35 | // builder.addInterceptor(addHeaderInterceptor()); 36 | 37 | //设置缓存 38 | // File cacheFile = new File(mContext.getExternalCacheDir(), "RetrofitCache"); 39 | // Cache cache = new Cache(cacheFile, 1024 * 1024 * 50); 40 | // builder.cache(cache).addInterceptor(addCacheInterceptor()); 41 | 42 | //设置超时 43 | builder.connectTimeout(15, TimeUnit.SECONDS); 44 | builder.readTimeout(20, TimeUnit.SECONDS); 45 | builder.writeTimeout(20, TimeUnit.SECONDS); 46 | //错误重连 47 | builder.retryOnConnectionFailure(true); 48 | 49 | OkHttpClient client = builder.build(); 50 | retrofit = new Retrofit.Builder() 51 | .baseUrl("http://www.tngou.net/api/") 52 | .addConverterFactory(GsonConverterFactory.create()) 53 | .client(client) 54 | .build(); 55 | } 56 | return retrofit; 57 | } 58 | 59 | 60 | /** 61 | * 设置公共参数 62 | */ 63 | private static Interceptor addQueryParameterInterceptor() { 64 | Interceptor addQueryParameterInterceptor = new Interceptor() { 65 | @Override 66 | public Response intercept(Chain chain) throws IOException { 67 | Request originalRequest = chain.request(); 68 | Request request; 69 | HttpUrl modifiedUrl = originalRequest.url().newBuilder() 70 | // Provide your custom parameter here 71 | .addQueryParameter("platform", "android") 72 | .addQueryParameter("version", "1.0.0") 73 | .build(); 74 | request = originalRequest.newBuilder().url(modifiedUrl).build(); 75 | return chain.proceed(request); 76 | } 77 | }; 78 | return addQueryParameterInterceptor; 79 | } 80 | 81 | /** 82 | * 设置头 83 | */ 84 | private static Interceptor addHeaderInterceptor() { 85 | Interceptor headerInterceptor = new Interceptor() { 86 | @Override 87 | public Response intercept(Chain chain) throws IOException { 88 | Request originalRequest = chain.request(); 89 | Request.Builder requestBuilder = originalRequest.newBuilder() 90 | // Provide your custom header here 91 | .header("AppType", "TPOS") 92 | .header("Accept", "application/json") 93 | .method(originalRequest.method(), originalRequest.body()); 94 | Request request = requestBuilder.build(); 95 | return chain.proceed(request); 96 | } 97 | }; 98 | return headerInterceptor; 99 | } 100 | 101 | /** 102 | * 设置缓存 103 | */ 104 | private static Interceptor addCacheInterceptor() { 105 | Interceptor cacheInterceptor = new Interceptor() { 106 | @Override 107 | public Response intercept(Chain chain) throws IOException { 108 | Request request = chain.request(); 109 | if (!isNetworkAvailable(mContext)) { 110 | request = request.newBuilder() 111 | .cacheControl(CacheControl.FORCE_CACHE) 112 | .build(); 113 | } 114 | Response response = chain.proceed(request); 115 | if (isNetworkAvailable(mContext)) { 116 | int maxAge = 0; 117 | // 有网络时 设置缓存超时时间0个小时 118 | response.newBuilder() 119 | .header("Cache-Control", "public, max-age=" + maxAge) 120 | .removeHeader("Retrofit")// 清除头信息,因为服务器如果不支持,会返回一些干扰信息,不清除下面无法生效 121 | .build(); 122 | } else { 123 | // 无网络时,设置超时为4周 124 | int maxStale = 60 * 60 * 24 * 28; 125 | response.newBuilder() 126 | .header("Cache-Control", "public, only-if-cached, max-stale=" + maxStale) 127 | .removeHeader("nyn") 128 | .build(); 129 | } 130 | return response; 131 | } 132 | }; 133 | return cacheInterceptor; 134 | } 135 | 136 | 137 | /** 138 | * 判断网络 139 | */ 140 | public static boolean isNetworkAvailable(Context ct) { 141 | Context context = ct.getApplicationContext(); 142 | // 获取手机所有连接管理对象(包括对wi-fi,net等连接的管理) 143 | ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); 144 | if (connectivityManager == null) { 145 | return false; 146 | } else { 147 | NetworkInfo[] networkInfo = connectivityManager.getAllNetworkInfo(); 148 | if (networkInfo != null && networkInfo.length > 0) { 149 | for (int i = 0; i < networkInfo.length; i++) { 150 | if (networkInfo[i].getState() == NetworkInfo.State.CONNECTED) { 151 | return true; 152 | } 153 | } 154 | } 155 | } 156 | return false; 157 | } 158 | 159 | public static Gson getGson(){ 160 | 161 | Gson gson = new GsonBuilder().excludeFieldsWithModifiers().create(); 162 | return gson; 163 | } 164 | 165 | } 166 | -------------------------------------------------------------------------------- /app/src/main/res/layout/activity_main.xml: -------------------------------------------------------------------------------- 1 | 2 | 9 | 10 | 20 | 21 | 22 | 30 | 31 | -------------------------------------------------------------------------------- /app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WHuaJian/RetrofitUtils/cf268b219e3e949488afb9730ecc866bf1aa61d8/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WHuaJian/RetrofitUtils/cf268b219e3e949488afb9730ecc866bf1aa61d8/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WHuaJian/RetrofitUtils/cf268b219e3e949488afb9730ecc866bf1aa61d8/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WHuaJian/RetrofitUtils/cf268b219e3e949488afb9730ecc866bf1aa61d8/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/mipmap-xxxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WHuaJian/RetrofitUtils/cf268b219e3e949488afb9730ecc866bf1aa61d8/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /app/src/main/res/values-w820dp/dimens.xml: -------------------------------------------------------------------------------- 1 | 2 | 5 | 64dp 6 | 7 | -------------------------------------------------------------------------------- /app/src/main/res/values/colors.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | #3F51B5 4 | #303F9F 5 | #FF4081 6 | 7 | -------------------------------------------------------------------------------- /app/src/main/res/values/dimens.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 16dp 4 | 16dp 5 | 6 | -------------------------------------------------------------------------------- /app/src/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | RetrofitUtils 3 | 4 | -------------------------------------------------------------------------------- /app/src/main/res/values/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /app/src/test/java/example/com/retrofit/ExampleUnitTest.java: -------------------------------------------------------------------------------- 1 | package example.com.retrofit; 2 | 3 | import org.junit.Test; 4 | 5 | import static org.junit.Assert.*; 6 | 7 | /** 8 | * To work on unit tests, switch the Test Artifact in the Build Variants view. 9 | */ 10 | public class ExampleUnitTest { 11 | @Test 12 | public void addition_isCorrect() throws Exception { 13 | assertEquals(4, 2 + 2); 14 | } 15 | } -------------------------------------------------------------------------------- /build.gradle: -------------------------------------------------------------------------------- 1 | // Top-level build file where you can add configuration options common to all sub-projects/modules. 2 | 3 | buildscript { 4 | repositories { 5 | jcenter() 6 | } 7 | dependencies { 8 | classpath 'com.android.tools.build:gradle:2.1.0' 9 | 10 | // NOTE: Do not place your application dependencies here; they belong 11 | // in the individual module build.gradle files 12 | } 13 | } 14 | 15 | allprojects { 16 | repositories { 17 | jcenter() 18 | } 19 | } 20 | 21 | task clean(type: Delete) { 22 | delete rootProject.buildDir 23 | } 24 | -------------------------------------------------------------------------------- /gradle.properties: -------------------------------------------------------------------------------- 1 | # Project-wide Gradle settings. 2 | 3 | # IDE (e.g. Android Studio) users: 4 | # Gradle settings configured through the IDE *will override* 5 | # any settings specified in this file. 6 | 7 | # For more details on how to configure your build environment visit 8 | # http://www.gradle.org/docs/current/userguide/build_environment.html 9 | 10 | # Specifies the JVM arguments used for the daemon process. 11 | # The setting is particularly useful for tweaking memory settings. 12 | # Default value: -Xmx10248m -XX:MaxPermSize=256m 13 | # org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 14 | 15 | # When configured, Gradle will run in incubating parallel mode. 16 | # This option should only be used with decoupled projects. More details, visit 17 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects 18 | # org.gradle.parallel=true -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/WHuaJian/RetrofitUtils/cf268b219e3e949488afb9730ecc866bf1aa61d8/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | #Mon Dec 28 10:00:20 PST 2015 2 | distributionBase=GRADLE_USER_HOME 3 | distributionPath=wrapper/dists 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | distributionUrl=https\://services.gradle.org/distributions/gradle-2.10-all.zip 7 | -------------------------------------------------------------------------------- /gradlew: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | 3 | ############################################################################## 4 | ## 5 | ## Gradle start up script for UN*X 6 | ## 7 | ############################################################################## 8 | 9 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 10 | DEFAULT_JVM_OPTS="" 11 | 12 | APP_NAME="Gradle" 13 | APP_BASE_NAME=`basename "$0"` 14 | 15 | # Use the maximum available, or set MAX_FD != -1 to use that value. 16 | MAX_FD="maximum" 17 | 18 | warn ( ) { 19 | echo "$*" 20 | } 21 | 22 | die ( ) { 23 | echo 24 | echo "$*" 25 | echo 26 | exit 1 27 | } 28 | 29 | # OS specific support (must be 'true' or 'false'). 30 | cygwin=false 31 | msys=false 32 | darwin=false 33 | case "`uname`" in 34 | CYGWIN* ) 35 | cygwin=true 36 | ;; 37 | Darwin* ) 38 | darwin=true 39 | ;; 40 | MINGW* ) 41 | msys=true 42 | ;; 43 | esac 44 | 45 | # Attempt to set APP_HOME 46 | # Resolve links: $0 may be a link 47 | PRG="$0" 48 | # Need this for relative symlinks. 49 | while [ -h "$PRG" ] ; do 50 | ls=`ls -ld "$PRG"` 51 | link=`expr "$ls" : '.*-> \(.*\)$'` 52 | if expr "$link" : '/.*' > /dev/null; then 53 | PRG="$link" 54 | else 55 | PRG=`dirname "$PRG"`"/$link" 56 | fi 57 | done 58 | SAVED="`pwd`" 59 | cd "`dirname \"$PRG\"`/" >/dev/null 60 | APP_HOME="`pwd -P`" 61 | cd "$SAVED" >/dev/null 62 | 63 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar 64 | 65 | # Determine the Java command to use to start the JVM. 66 | if [ -n "$JAVA_HOME" ] ; then 67 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then 68 | # IBM's JDK on AIX uses strange locations for the executables 69 | JAVACMD="$JAVA_HOME/jre/sh/java" 70 | else 71 | JAVACMD="$JAVA_HOME/bin/java" 72 | fi 73 | if [ ! -x "$JAVACMD" ] ; then 74 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME 75 | 76 | Please set the JAVA_HOME variable in your environment to match the 77 | location of your Java installation." 78 | fi 79 | else 80 | JAVACMD="java" 81 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 82 | 83 | Please set the JAVA_HOME variable in your environment to match the 84 | location of your Java installation." 85 | fi 86 | 87 | # Increase the maximum file descriptors if we can. 88 | if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then 89 | MAX_FD_LIMIT=`ulimit -H -n` 90 | if [ $? -eq 0 ] ; then 91 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then 92 | MAX_FD="$MAX_FD_LIMIT" 93 | fi 94 | ulimit -n $MAX_FD 95 | if [ $? -ne 0 ] ; then 96 | warn "Could not set maximum file descriptor limit: $MAX_FD" 97 | fi 98 | else 99 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" 100 | fi 101 | fi 102 | 103 | # For Darwin, add options to specify how the application appears in the dock 104 | if $darwin; then 105 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" 106 | fi 107 | 108 | # For Cygwin, switch paths to Windows format before running java 109 | if $cygwin ; then 110 | APP_HOME=`cygpath --path --mixed "$APP_HOME"` 111 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` 112 | JAVACMD=`cygpath --unix "$JAVACMD"` 113 | 114 | # We build the pattern for arguments to be converted via cygpath 115 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` 116 | SEP="" 117 | for dir in $ROOTDIRSRAW ; do 118 | ROOTDIRS="$ROOTDIRS$SEP$dir" 119 | SEP="|" 120 | done 121 | OURCYGPATTERN="(^($ROOTDIRS))" 122 | # Add a user-defined pattern to the cygpath arguments 123 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then 124 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" 125 | fi 126 | # Now convert the arguments - kludge to limit ourselves to /bin/sh 127 | i=0 128 | for arg in "$@" ; do 129 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` 130 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option 131 | 132 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition 133 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` 134 | else 135 | eval `echo args$i`="\"$arg\"" 136 | fi 137 | i=$((i+1)) 138 | done 139 | case $i in 140 | (0) set -- ;; 141 | (1) set -- "$args0" ;; 142 | (2) set -- "$args0" "$args1" ;; 143 | (3) set -- "$args0" "$args1" "$args2" ;; 144 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;; 145 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; 146 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; 147 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; 148 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; 149 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; 150 | esac 151 | fi 152 | 153 | # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules 154 | function splitJvmOpts() { 155 | JVM_OPTS=("$@") 156 | } 157 | eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS 158 | JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" 159 | 160 | exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" 161 | -------------------------------------------------------------------------------- /gradlew.bat: -------------------------------------------------------------------------------- 1 | @if "%DEBUG%" == "" @echo off 2 | @rem ########################################################################## 3 | @rem 4 | @rem Gradle startup script for Windows 5 | @rem 6 | @rem ########################################################################## 7 | 8 | @rem Set local scope for the variables with windows NT shell 9 | if "%OS%"=="Windows_NT" setlocal 10 | 11 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 12 | set DEFAULT_JVM_OPTS= 13 | 14 | set DIRNAME=%~dp0 15 | if "%DIRNAME%" == "" set DIRNAME=. 16 | set APP_BASE_NAME=%~n0 17 | set APP_HOME=%DIRNAME% 18 | 19 | @rem Find java.exe 20 | if defined JAVA_HOME goto findJavaFromJavaHome 21 | 22 | set JAVA_EXE=java.exe 23 | %JAVA_EXE% -version >NUL 2>&1 24 | if "%ERRORLEVEL%" == "0" goto init 25 | 26 | echo. 27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 28 | echo. 29 | echo Please set the JAVA_HOME variable in your environment to match the 30 | echo location of your Java installation. 31 | 32 | goto fail 33 | 34 | :findJavaFromJavaHome 35 | set JAVA_HOME=%JAVA_HOME:"=% 36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe 37 | 38 | if exist "%JAVA_EXE%" goto init 39 | 40 | echo. 41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 42 | echo. 43 | echo Please set the JAVA_HOME variable in your environment to match the 44 | echo location of your Java installation. 45 | 46 | goto fail 47 | 48 | :init 49 | @rem Get command-line arguments, handling Windowz variants 50 | 51 | if not "%OS%" == "Windows_NT" goto win9xME_args 52 | if "%@eval[2+2]" == "4" goto 4NT_args 53 | 54 | :win9xME_args 55 | @rem Slurp the command line arguments. 56 | set CMD_LINE_ARGS= 57 | set _SKIP=2 58 | 59 | :win9xME_args_slurp 60 | if "x%~1" == "x" goto execute 61 | 62 | set CMD_LINE_ARGS=%* 63 | goto execute 64 | 65 | :4NT_args 66 | @rem Get arguments from the 4NT Shell from JP Software 67 | set CMD_LINE_ARGS=%$ 68 | 69 | :execute 70 | @rem Setup the command line 71 | 72 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar 73 | 74 | @rem Execute Gradle 75 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% 76 | 77 | :end 78 | @rem End local scope for the variables with windows NT shell 79 | if "%ERRORLEVEL%"=="0" goto mainEnd 80 | 81 | :fail 82 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of 83 | rem the _cmd.exe /c_ return code! 84 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 85 | exit /b 1 86 | 87 | :mainEnd 88 | if "%OS%"=="Windows_NT" endlocal 89 | 90 | :omega 91 | -------------------------------------------------------------------------------- /settings.gradle: -------------------------------------------------------------------------------- 1 | include ':app' 2 | --------------------------------------------------------------------------------