URL Scheme 的作用
URL Scheme 的使用
Scheme协议在Android中使用场景
H5跳转到native页面
客户端获取push消息中后,点击消息跳转到APP内部页面
APP根据URL跳转到另外一个APP指定页面
URL Scheme 的格式
URL语法
URL的一般语法格式为:(带方括号[]的为可选项)
格式说明:
protocol(协议):指定使用的传输协议,下表列出 protocol 属性的有效方案名称。 最常用的是HTTP协议,它也是目前WWW中应用最广的协议。
hostname(主机名):是指存放资源的服务器的域名系统(DNS) 主机名或 IP 地址。有时,在主机名前也可以包含连接到服务器所需的用户名和密码(格式:username:password@hostname)。
port(端口号):整数,可选,省略时使用方案的默认端口,各种传输协议都有默认的端口号,如http的默认端口为80。如果输入时省略,则使用默认端口号。有时候出于安全或其他考虑,可以在服务器上对端口进行重定义,即采用非标准端口号,此时,URL中就不能省略端口号这一项。
path(路径):由零或多个“/”符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。
parameters(参数):这是用于指定特殊参数的可选项。
query(查询) :可选,用于给动态网页(如使用CGI、ISAPI、PHP/JSP/ASP/ASP。NET等技术制作的网页)传递参数,可有多个参数,用“&”符号隔开,每个参数的名和值用“=”符号隔开。
fragment(信息片断):字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。
下面举一个例子:
比如:http://www.sina.com/s?rsv_bp=1&rsv_spt=1&wd=NSurl&inputT=2709,这个URL中,scheme为 http,host为www.sina.com,relativePath为 /s,query 为 rsv_bp=1&rsv_spt=1&wd=NSurl&inputT=2709。
再列举了一个在应用中使用的 URL 例子(该 URL 会调起书籍封面页):sqreader://com.sq.controller/readbook?book_id=123456,其中 scheme 为 sqreader,host 为 com.sq.controller,relativePath 为 /readbook,query 为 book_id=123456。
下面是在Android中是使用说明:
Uri的格式:scheme://host:port/path or pathPrefix or pathPattern
在Android AndroidManifest.xml基本配置如下:
在java中使用通过协议跳转
/**
* (1)在manifest配置文件中配置了scheme参数
* (2)网络端获取url
* (3)跳转
*/
String url = "scheme://hosttest/pathtest?paramId=01010101";
Intent intent = new Intent(Intent.ACTION_VIEW,Uri.parse(url));
startActivity(intent);
在xxxActivity.java中接收协议并解析
public class xxxActivity extends Activity {
private static final String TAG = "xxxActivity";
private TextView tvParam;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
tvParam = (TextView) findViewById(R.id.tv_param);
Uri data = getIntent().getData();
Log.i(TAG, "host = " + data.getHost() + " path = " + data.getPath() + " query = " + data.getQuery());
String param = data.getQueryParameter("paramId");
tvParam.setText("获取的参数为:" + param);
}
}
在AndroidManifest.xml中设置了data属性,data代表数据源,是中最复杂的标签,因为不同的Activity支持的数据来源和类型多种多样,所以需要通过详细的data标签信息来指明。
Data的语法如下:
Uri的格式:scheme://host:port/path or pathPrefix or pathPattern
如果scheme没有指定,那其它的属性均无效;
如果host没有指定,那么port,path,pathPrefix,pathPattern均无效;
如果在manifest里这样写:
那么Uri 需要如下写法才可以匹配
uri = Uri.parse("something://project.example.com");
再如:
等同于这样写:
那么uri应该这样写才可以匹配
Uri uri = Uri.parse("something://project.example.com:80");
可以有多个data,只需匹配其中一个即可,AndroidManifest.xml
java 代码如下写法
Intent in = new Intent();
in.setAction("android.intent.action.leo");
in.addCategory(Intent.CATEGORY_DEFAULT);
in.setData(Uri.parse("something:"));
//或者用这个亦可
//in.setData(Uri.parse("x- id:"));
startActivity(in);
---------------------
作者:火山石
来源:CSDN
原文:https://blog.csdn.net/zhangcanyan/article/details/54743578