preface
With the rapid development of the Internet, people spend more and more time in App, and gradually rely on it more and more. However, each App is independent from each other, and we have to open different mobile phone clients to obtain different information, which cannot be spread and shared. Therefore, an important way to build a communication bridge for App is through THE H5 page, and it has become a common technical requirement to wake up the App page directly from H5.
Behind this technical requirement, it is more important to optimize user experience, because the daily activity of the App is linked to the growth and activity of users. No matter registering new users or activating old users, the operation cost of users needs to be saved as much as possible. Therefore, the guidance of “open from other browser” in wechat or the manual search of the target page after downloading the App are not very comfortable for users.
If you want to open the App from H5 and directly jump to the specified page within the App, the easiest way is to use Deep linking technology developed by mobile terminal. Deep link can solve the problem of free jump between apps, so as to shorten the user’s operation path and directly reach the corresponding page of App.
Common scenario
- Click H5 page button to open App page;
- Click the URL in the message (game invitation link/news/event landing page, etc.) to open the App page;
What is Deep Link?
Deep Link is a Link concept that we actually use every day to open a web page, but it is a bit more complicated than normal links. In Web development, a deep link is a link that opens not just to a site, but directly to a specific page of content within the site. Generally speaking, a lot of links are deep links, but we are used to calling them links.
Both Android and iOS have introduced concepts for deep linking. So you have Universal Links, App Links, URL Scheme.
Scene: the process
Let’s take a brief look at the entire wake up process, as shown below:
Several ways to wake up your App
Here are a few ways to wake up your App directly for your reference.
URL Scheme
URL Scheme is a page hopping protocol and the first generation of Deep Link solutions. It can be used in mobile development from the Web page or other App to evoke the corresponding App function.
Link format
[scheme]://[host][:port]/[path]? [query]
The property name | meaning |
---|---|
scheme | Protocol name (defined by the developer) |
host | The domain name |
port | The port number |
path | Page path |
query | Request parameters |
Each big platform
I have simply searched the scheme of each major platform. If you are interested, you can open it directly from the mobile browser and have a try.
QQ: QQ :// wechat: weixin:// Taobao :// weibo: sinaWeibo :// billionbottle://
Page call mode
window.location.href = schemeUrl;
Copy the code
Direct jump link, simple and convenient.
disadvantages
Although it is very simple to use, it also has the following disadvantages:
- Opening this link will cause an error when the App to be invoked is not installed. There are many things that can go wrong in Korea’s very cluttered mobile browsers. Such as:
- Currently, there is no way to distinguish the case where multiple apps are registered with the same scheme;
- It is not supported to jump directly from WebView in other App to target App;
- Wechat on Android can not evoke App directly through Scheme, but can be solved by bootstrap or wechat open label.
- Only through
hidden
,blur
Wait for events to monitor whether the App is installed;
Therefore, in order to solve the above problems, iOS and Android have their own second solutions, which are Universal Links of iOS and App Links of Android respectively.
Universal Links
After iOS 9, Apple launched a new concept to replace the previous URL Scheme in 2015, which is Universal Links.
The following is the official function description:
In iOS 9 and later, universal links let users open your app when they tap links to your Website within WKWebView and UIWebView views and Safari pages, in addition to links that result in a call to openURL:, such as those that occur in Mail, Messages, and other apps.
In iOS 9 and later, universal links lets the user call openURL when clicking on a link to your website in WKWebView, UIWebView, or Safari: You can also open your App through your system’s apps, such as those that appear in email, messaging, and other apps.
In short, its implementation mechanism is similar to that of Deep Link, except that instead of defining a URL scheme, it matches multiple pages in the App. When a user opens a matching page, iOS automatically redirects it to the App. In addition, because the current built-in browser of wechat does not support the way of openURL to jump between applications, many apps connect to Universal Links to realize the function of one-click jump to their own apps, such as Zhihu and Dewu.
Working mode and process
- Open the domain name link configured by the App developer in the apple-app-site-association file (the link must support HTTPS);
- parsingapple-app-site-associationFile, get the
bundleId
,paths
Such as configuration information; - When the App is opened for the first time after installation, it will request the configuration file, receive the corresponding path, and jump to the corresponding function according to the logic of the path.
Apple – the app – site – association file
{
"applinks": {
"apps": []."details": [{"appID": "appID"."paths": ["appShare/app/link"."appShare/app/link/*"]]}},"appclips": {
"apps": ["appID.Clip"]}}Copy the code
Verify the configuration
After a series of operations, how do we verify that the configuration is successful?
Debugging locally or copying configured links to the mobile browser doesn’t work directly.
If you want to verify that the configuration is successful, you can try the following two methods:
- Type the link in the phone’s memo, click to go straight to the App, or hold down the prompt to open it in Safari.
- When the page is opened in the mobile browser, there will be a prompt to open it from the App at the top of the drop-down page.
advantages
The official documentation provides several advantages over the Custom URL Scheme:
- Uniqueness: In contrast to custom URL links, generic links cannot be accessed by other applications because they link to your site using standard HTTP or HTTPS.
- Security: When a user installs your app, iOS checks the files you upload to the web server to make sure your site allows your app to open urls on its behalf. Only you can create and upload this file, so your site’s association with your application is secure.
- Flexibility: Universal Links works even without an App installed. Tap your website link to open the content in Safari, just as users expect.
- Simplicity: One URL applies to both your website and your App.
- Privacy: Other apps can also communicate with your App without knowing if your App is installed.
defects
You need at least iOS 9 to support it. As can be seen from the figure below, by September 2021, iOS 14.7 is still the mainstream version worldwide, accounting for 57.26%. Therefore, despite the version restriction of iOS 9, people can feel free to use it boldly.
To prevent trampling pits must be highlighted
- You need to make sure that the links you use are cross-domain. Without cross-domain, you cannot wake up your App.
- Plugging Universal Links directly into the browser does not work;
- In wechat on iOS, if the wechat version is earlier than 7.0.5, the App cannot be invoked directly through Universal links, which requires compatibility processing. Specifically, it can be opened by guiding to an external browser.
App Links
At Google I/O 2015, Android M announced a new feature: App Links. It allows users to click on a regular Web link to open the corresponding page of the specified App, provided that the App is installed and verified, otherwise a dialog box will be displayed to open the confirmation option. Currently, it only supports Android M or higher.
In fact, the emergence of App Links is also to optimize user experience. When using it to wake up the App, a dialog box will pop up to remind users whether to open it or not. The disadvantage is that if users check cancel, they may not be able to wake up again.
Working mode and process
- Configuration AndroidManifest. XML;
- Configure json file;
[{
"relation": ["delegate_permission/common.handle_all_urls"]."target": {
"namespace": "android_app"."package_name": "Package name"."sha256_cert_fingerprints": ["Signature"]}}]Copy the code
- Upload the JSON file to the. Well-known path of the specified domain name and define the file name as assetlinks.json.
- To verify App Links, you can use Test App Links in the App Links Assistant in AndroidStudio or you can type in a link in a text message and click Test. If the App is directly evoked without pop-up dialog box selection, App Links verification is successful;
In general, the configuration and validation is similar to Universal Links, but not different.
Third Party services
To make a scheme with good compatibility, it is necessary to consider various situations and adapt different schemes in different situations, such as whether users open it in mobile browser or wechat, or open it in PC, whether Universal Links is closed, etc., which makes the code implementation complicated and error-prone. There are also compatibility issues caused by the large number of Android platforms and mobile browsers.
The magic window MLink
Has now been aurora data acquisition, and changed its name to the aurora magic chain (docs. Jiguang. Cn/jmlink/guid…
OpenInstall
OpenInstall is a third-party SDK that improves App promotion capabilities. The SDK can bind the relationship between the superior and the subordinate in the process of App promotion, so as to automatically identify the invitation source without manually filling in the invitation code and other functions. It can also be installed with arbitrary parameters to obtain accurate statistical data. Ultimately improve App installation rate and conversion rate.
OpenInstall (www.openinstall.io/)
Wechat related friendship tips
Wechat has become an indispensable daily communication tool for everyone. It is best to promote apps, but it is usually impossible to jump directly to other apps inside wechat. In addition to the technical solutions listed above, how can we achieve this technical requirement?
Wechat internal whitelist
This white list is equivalent to wechat’s son, as long as the need to wake up the App added to the white list, you can unimpeded jump in the major App, high difficulty to achieve.
Application of treasure
If your page needs to be able to directly open the App store, you can upload your App to the AppStore platform, because AppStore has cooperation with AppStore and has implemented its own internal process. It is also an optional solution to directly jump to AppStore link in wechat.
Wechat open tabs
Wechat launched the wechat open label function in May 2020, which is used to wake up the App directly in the wechat browser and directly enter the corresponding page of the App by carrying parameters. As long as you access the wechat SDK according to the provisions of the document, you can directly use this function.
Apply to the environment
- Wechat version requirements: 7.0.12 or above;
- The system version must be iOS 10.3 or later, Android 5.0 or later.
Specific requirements can refer to official open platform: WeChat official documentation (developers.weixin.qq.com/doc/oplatfo…). .
Access to the process
- Log in to wechat public platform and fill in “JS interface security domain name”;
- Access the following wechat JS files:
http://res.wx.qq.com/open/js/jweixin-1.6.0.js
(at least version 1.6.0); - Injection permission configuration through the Config interface;
wx.config({
debug: true.// Debug mode switch
appId: ' '.// Public id
timestamp:,/ / timestamp
nonceStr: ' '.// Generate a random string of signatures
signature: ' '.// Only check
jsApiList: [].// List of JS interfaces
openTagList: ['open-tag-launch-app'] // List of open labels to use
});
Copy the code
- Reference tag, using the component to wrap the component that needs to trigger the event;
<open-tag-launch-app extinfo="extinfo">
<button>Open the App</button>
</open-tag-launch-app>
Copy the code
API
attribute | instructions | type | The default value |
---|---|---|---|
extinfo | Parameters that the wechat SDK passes to the APP | String | “” |
The event
attribute | instructions | The callback parameter |
---|---|---|
launch | Triggered after the user clicks the jump button and operates the confirm popup | () => void |
error | An error occurred after the user clicked the jump button | (event) => void |
Existing problems
- Because the Web has no way to monitor whether the App is installed, it is necessary to use some means to tune up the App or download the page;
- If the App is not installed on the device, the context in which the user stays cannot be retained after the installation.
summary
This paper combines some experience of the development of the bottle and each big platform developers point of view, hope can help to you, if you want to explore the specific process of bottle can download the App to view (web.billionbottle.com/download).
More exciting, please pay attention to our public number “100 bottle technology”, there are not regular benefits!