通常情况下我们使用
Uri uri = Uri.parse(requesturl);
来对一个链接进行解析,通过解析后得到的uri,可以得到链接各个部分的数据
但是对于包含了哈希路由的网址,使用parse方法会得到意想不到的结果
如下源码为例
String requesturl = "https://my.vivo.com.cn/#/home?sign=12345678";
System.out.println("requesturl:" + requesturl);
Uri uri = Uri.parse(requesturl);
System.out.println("getQueryParameter:" + uri.getQueryParameter("sign"));
System.out.println("getHost:" + uri.getHost());
System.out.println("getScheme:" + uri.getScheme());
System.out.println("getPath:" + uri.getPath());
代码运行后打印的结果是
I/System.out: requesturl:https://my.vivo.com.cn/#/home?sign=12345678
I/System.out: getQueryParameter:null
I/System.out: getHost:my.vivo.com.cn
I/System.out: getScheme:https
I/System.out: getPath:/
可以看出来路径,参数得到的都是错误值
针对这种情况,需要对链接先进行一次encode,注意encode时使用了『/:?&=』来做为参数
requesturl = Uri.encode(requesturl, "/:?&=");
将链接中的#转义后再进行parse
如下源码为例
String requesturl = "https://my.vivo.com.cn/#/home?sign=12345678";
requesturl = Uri.encode(requesturl, "/:?&=");
System.out.println("requesturl:" + requesturl);
Uri uri = Uri.parse(requesturl);
System.out.println("getQueryParameter:" + uri.getQueryParameter("sign"));
System.out.println("getHost:" + uri.getHost());
System.out.println("getScheme:" + uri.getScheme());
System.out.println("getPath:" + uri.getPath());
代码运行后
I/System.out: requesturl:https://my.vivo.com.cn/%23/home?sign=12345678
I/System.out: getQueryParameter:12345678
I/System.out: getHost:my.vivo.com.cn
I/System.out: getScheme:https
I/System.out: getPath:/#/home
可以得到正常结果了