Android scheme使用

URL Scheme 的作用

  • android中的scheme是一种页面内跳转协议。
  • 通过定义自己的scheme协议,可以非常方便跳转app中的各个页面;
  • 通过scheme协议,服务器可以定制化告诉App跳转到APP内部页面。

URL Scheme 的使用

  • 客户端应用可以向操作系统注册一个 URL Scheme,该 Scheme 用于从浏览器或其他应用中启动本应用。
  • 通过指定的 URL 字段,可以让应用在被调起后直接打开某些特定页面,比如:首页、详情页和广告页等等。也可以执行某些指定动作,如订单支付等。也可以在应用内或者应用外,通过 html 页来直接调用显示 app 内的某个页面。

Scheme协议在Android中使用场景

  • H5跳转到native页面

  • 客户端获取push消息中后,点击消息跳转到APP内部页面

  • APP根据URL跳转到另外一个APP指定页面

URL Scheme 的格式

  • 客户端自定义的 URL 作为从一个应用调用另一个的基础,遵循 RFC 1808 (Relative Uniform Resource Locators) 标准。这跟我们常见的网页内容 URL 格式一样。
  • 一个普通的 URL 分为几个部分,scheme、host、port、relativePath、query、fragment。

URL语法

  • URL由三部分组成:资源类型、存放资源的主机域名、资源文件名。

URL的一般语法格式为:(带方括号[]的为可选项)

  • protocol :// hostname[:port] / path / [;parameters][?query]#fragment

格式说明:
protocol(协议):指定使用的传输协议,下表列出 protocol 属性的有效方案名称。 最常用的是HTTP协议,它也是目前WWW中应用最广的协议。

  • file 资源是本地计算机上的文件。格式file:///,注意后边应是三个斜杠。
  • ftp 通过 FTP访问资源。格式 FTP://
  • gopher 通过 Gopher 协议访问该资源。
  • http 通过 HTTP 访问该资源。 格式 HTTP://
  • https 通过安全的 HTTPS 访问该资源。 格式 HTTPS://
  • mailto 资源为电子邮件地址,通过 SMTP 访问。 格式 mailto:
  • MMS 通过 支持MMS(流媒体)协议的播放该资源。(代表软件:Windows Media Player)格式 MMS://
  • ed2k 通过 支持ed2k(专用下载链接)协议的P2P软件访问该资源。(代表软件:电驴) 格式 ed2k://
  • Flashget 通过 支持Flashget:(专用下载链接)协议的P2P软件访问该资源。(代表软件:快车) 格式 Flashget://
  • thunder 通过 支持thunder(专用下载链接)协议的P2P软件访问该资源。(代表软件:迅雷) 格式 thunder://
  • news 通过 NNTP 访问该资源。

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基本配置如下:

<!-- scheme协议 -->
<activity
    android:name=".xxxActivity"
    android:label="@string/app_name">

    <!-- 要想在别的App上能成功调起App,必须添加intent过滤器 -->

    <!-- 协议部分,随便设置 -->
    <intent-filter>
         <!--协议部分,随便设置-->
         <data android:scheme="scheme" android:host="hosttest" android:path="/pathtest" />
         <!--下面这几行也必须得设置-->
         <category android:name="android.intent.category.DEFAULT"/>
         <action android:name="android.intent.action.VIEW"/>
         <!--浏览器调用-->
         <category android:name="android.intent.category.BROWSABLE"/>
    </intent-filter>
</activity>

在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的语法如下:

<data android:host="string"
      android:mimeType="string"
      android:path="string"
      android:pathPattern="string"
      android:pathPrefix="string"
      android:port="string"
      android:scheme="string" />

Uri的格式:scheme://host:port/path or pathPrefix or pathPattern
 
如果scheme没有指定,那其它的属性均无效;
 
如果host没有指定,那么port,path,pathPrefix,pathPattern均无效;
 
如果在manifest里这样写:

<data android:scheme="something" android:host="project.example.com" />

那么Uri 需要如下写法才可以匹配

uri = Uri.parse("something://project.example.com"); 

再如:

<data android:scheme="something" android:host="project.example.com" android:port="80"/>

等同于这样写:

<data android:scheme="something"/>
<data android:host="project.example.com"/>
<data android:port="80"/>

那么uri应该这样写才可以匹配

Uri uri = Uri.parse("something://project.example.com:80");

可以有多个data,只需匹配其中一个即可,AndroidManifest.xml

<activity android:name=".MyActivityTwo" android:label="@string/activityTwo">
<intent-filter>
    <action android:name="android.intent.action.leo"></action>
    <category android:name="android.intent.category.DEFAULT"></category>
    <data android:scheme="x-id"/>
    <data android:scheme="something"/>
</intent-filter>
</activity>

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 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值