|
38 | 38 | import io.reactivex.schedulers.Schedulers; |
39 | 39 | import me.jessyan.retrofiturlmanager.RetrofitUrlManager; |
40 | 40 | import me.jessyan.retrofiturlmanager.onUrlChangeListener; |
| 41 | +import me.jessyan.retrofiturlmanager.parser.AdvancedUrlParser; |
| 42 | +import me.jessyan.retrofiturlmanager.parser.DomainUrlParser; |
| 43 | +import me.jessyan.retrofiturlmanager.parser.SuperUrlParser; |
41 | 44 | import okhttp3.HttpUrl; |
42 | 45 | import okhttp3.ResponseBody; |
43 | 46 |
|
|
47 | 50 |
|
48 | 51 | /** |
49 | 52 | * ================================================ |
| 53 | + * RetrofitUrlManager 以简洁的 Api, 让 Retrofit 不仅支持多 BaseUrl |
| 54 | + * 还可以在 App 运行时动态切换任意 BaseUrl, 在多 BaseUrl 场景下也不会影响到其他不需要切换的 BaseUrl |
| 55 | + * <p> |
| 56 | + * 想要更深入的使用本框架必须要了解2个术语 pathSegments 和 PathSize |
| 57 | + * "https://www.github.com/wiki/part?name=jess" 其中的 "/wiki" 和 "/part" 就是 pathSegment, PathSize 就是 pathSegment 的 Size |
| 58 | + * 这个 Url 的 PathSize 就是 2, 可以粗略理解为域名后面跟了几个 "/" PathSize 就是几 |
| 59 | + * <p> |
| 60 | + * 本框架分为三种模式, 普通模式 (默认)、高级模式 (需要手动开启)、超级模式 (需要手动开启) |
| 61 | + * <p> |
| 62 | + * 普通模式: |
| 63 | + * 普通模式只能替换域名, 比如使用 "https:www.google.com" 作为 Retrofit 的 BaseUrl 可以被替换 |
| 64 | + * 但是以 "https:www.google.com/api" 作为 BaseUrl 还是只能替换其中的域名 "https:www.google.com" |
| 65 | + * 详细替换规则可以查看 {@link DomainUrlParser} |
| 66 | + * <p> |
| 67 | + * 高级模式: |
| 68 | + * 高级模式只能替换 {@link RetrofitUrlManager#startAdvancedModel(String)} 中传入的 BaseUrl, 但可以替换拥有多个 pathSegments 的 BaseUrl |
| 69 | + * 如 "https:www.google.com/api", 需要手动开启高级模式 {@link RetrofitUrlManager#startAdvancedModel(String)} |
| 70 | + * 详细替换规则可以查看 {@link AdvancedUrlParser} |
| 71 | + * <p> |
| 72 | + * 超级模式: |
| 73 | + * 详细替换规则可以查看 {@link SuperUrlParser} |
| 74 | + * 超级模式属于高级模式的加强版, 优先级高于高级模式, 在高级模式中, 需要传入一个 BaseUrl (您传入 Retrofit 的 BaseUrl) 作为被替换的基准 |
| 75 | + * 如这个传入的 BaseUrl 为 "https://www.github.com/wiki/part" (PathSize = 2), 那框架会将所有需要被替换的 Url 中的 域名 以及 域名 后面的前两个 pathSegments |
| 76 | + * 使用您传入 {@link RetrofitUrlManager#putDomain(String, String)} 方法的 Url 替换掉 |
| 77 | + * 但如果突然有一小部分的 Url 只想将 "https://www.github.com/wiki" (PathSize = 1) 替换掉, 后面的 pathSegment '/part' 想被保留下来 |
| 78 | + * 这时项目中就出现了多个 PathSize 不同的需要被替换的 BaseUrl |
| 79 | + * <p> |
| 80 | + * 使用高级模式实现这种需求略显麻烦, 所以我创建了超级模式, 让每一个 Url 都可以随意指定不同的 BaseUrl (PathSize 自己定) 作为被替换的基准 |
| 81 | + * 使 RetrofitUrlManager 可以从容应对各种复杂的需求 |
| 82 | + * <p> |
| 83 | + * 超级模式也需要手动开启, 但与高级模式不同的是, 开启超级模式并不需要调用 API, 只需要在 Url 中加入 {@link RetrofitUrlManager#IDENTIFICATION_PATH_SIZE} + PathSize |
| 84 | + * <p> |
| 85 | + * 至此三种模式替换 BaseUrl 的自由程度 (可扩展性) 排名, 从小到大依次是: |
| 86 | + * 普通模式 (只能替换域名) < 高级模式 (只能替换 {@link RetrofitUrlManager#startAdvancedModel(String)} 中传入的 BaseUrl) < 超级模式 (每个 Url 都可以随意指定可被替换的 BaseUrl, pathSize 随意变换) |
| 87 | + * <p> |
| 88 | + * 三种模式在使用上的复杂程度排名, 从小到大依次是: |
| 89 | + * 普通模式 (无需做过多配置) < 高级模式 (App 初始化时调用一次 {@link RetrofitUrlManager#startAdvancedModel(String)} 即可) < 超级模式 (每个需要被替换 BaseUrl 的 Url 中都需要加入 {@link #IDENTIFICATION_PATH_SIZE} + PathSize) |
| 90 | + * <p> |
| 91 | + * 由此可见,自由度越强, 操作也越复杂, 所以可以根据自己的需求选择不同的模式, 并且也可以在需求变化时随意升级或降级这三种模式 |
| 92 | + * <p> |
50 | 93 | * Created by JessYan on 18/07/2017 17:03 |
51 | 94 | * <a href="mailto:jess.yan.effort@gmail.com">Contact me</a> |
52 | 95 | * <a href="https://github.com/JessYanCoding">Follow me</a> |
|
0 commit comments