本文主要给大家介绍了关于iOS拦截URL转换成本地路由模块URLRewrite的相关内容,分享出来供各位iOS开发者们参考学习,下面话不多说了,来一起看看详细的介绍:
需求场景
做过电商App的可能都遇到过这样的需求,在商场首页,各种各样动态的跳转,跳转商品详情、秒杀列表、品牌列表、搜索结果、分类结果页面等等等等。同一个位置,可能今天跳这个商品,明天跳转那个商品,运营配的就是一个web端的URL。 拦截webView里面的URL。需求分析
拦截各种各样的URL,跳转到指定的原生页面。 URL的种类可能会一直增加。 指定位置即某个button点击后的URL也不是固定的,可以动态配置。以前的解决方案
接手项目前,已经有这个功能,之前也没有引入路由。这一块的做法是:对url进行path匹配或者字符串匹配,成功后再做特殊的操作。所以经常出现这个url没拦截,那个url跳错了这样的bug。每添加新的URL拦截都得修改代码,发版。
新的解决方案
在客户端引入路由后,我们需要的应该是下面这样一个URLRewrite模块,将输入的各种各样的URL转化为本地可以设别的路由URL。

做法是效仿天猫的Rewrite系统。天猫团队文章看这里:解耦神器---统跳协议和Rewrite引擎](http://www.easck.com/p>
原理
Rewrite引擎的原理非常简单,模拟Web容器(Apache/Nginx等)的Rewrite配置,根据配置把传入的原始URL进行重写,返回重写后的目标URL,交给统跳协议处理。
配置是通过正则表达式描述的Rewrite规则列表,这份列表通过后台接口实现动态更新。
关键点:URL是动态的,跳转的页面也是动态的,所以,URLRewrite中应该也有一个动态的东西来对应这个两个动态的变化。那就是Rewrite的规则。规则可以由接口动态更新,所以可以做到不发版本添加新的URL解析,新的页面跳转。
具体实现
后面会有具体的例子解析,先看一下代码实现。
规则的组成:规则有三个字段组成
pattern 用来匹配原始URL的正则表达式串。 targetUrl 转换后的目标串。 flag 标记位,做一些特殊处理。匹配过程:原始URL通过规则匹配,找到URL中的参数,将targetUrl字段里面的参数占位符替换成url中找到的参数。完成重写。
//
// RewriteRule.h
// YTURLRewrite
//
// Created by brant on 2017/8/3.
// Copyright ? 2017年 瘦不拉机. All rights reserved.
//
#import <foundation foundation.h="">
@interface RewriteRule : NSObject
// 用来匹配的原始URL的正则串
@property (nonatomic, copy) NSString *pattern;
// 转换后的目标串 参数占位用 $0, $1 这样
// 这里是一个标准的本地路由
@property (nonatomic, copy) NSString *targetUrl;
// 标记位
// 值一:k: 保留原url,不做重写
@property (nonatomic, copy) NSString *flag;
// 返回重写后的url
- (NSString *)targetUrlWithParams:(NSArray *)params url:(NSString *)url;
@end</foundation>










