Home Web Front-end uni-app How to turn off Uniapp's default restriction on external link browsers

How to turn off Uniapp's default restriction on external link browsers

Apr 20, 2023 am 09:10 AM

With the rise of the mobile Internet, web applications have gradually become the first choice for users to experience products, and Uniapp, as a high-performance cross-platform development tool, has received widespread attention when implementing enterprise mobile application development. However, because developers need to consider issues such as application security, Uniapp prohibits external browsers by default, which will cause great problems for some applications that need to use the functions of the browser core (such as payment functions). Troubled. Therefore, this article will introduce how to turn off Uniapp’s default settings that restrict external link browsers.

1. Modify manifest.json

In Uniapp, manifest.json is the main file of the configuration file. By modifying the configuration content in this file, you can realize the opening restrictions of external link browsers. In the manifest.json file, you can find the following code:

"condition": {
      "appType": [
        "normal"
      ]
    }
Copy after login

Among them, appType defines the application type, and normal means that the link is only opened in the application. To turn off the restriction, you only need to add the following code after the code block:

"launch_path": ".pg",
    "extern": {
      "allow_external": [
        "https://*",
        "http://*",
        "tel:*",
        "mailto:*"
      ]
    }
Copy after login

Among them, launch_path defines the page path where the application is launched. Here, it is set to ".pg" to indicate the current page. extern defines the restrictions on external link access. The items in allow_external represent the protocols and addresses of allowed external link access, which can be modified according to actual needs.

The modified manifest.json should look like the following:

"condition": {
      "appType": [
        "normal"
      ]
    },
    "launch_path": ".pg",
    "extern": {
      "allow_external": [
        "https://*",
        "http://*",
        "tel:*",
        "mailto:*"
      ]
    }
Copy after login

After the above modifications are completed, save the manifest.json.

2. Modify uni-config.json

Uniapp provides the uni-config.json file in the first-level directory, which can be used to set the global configuration of the application. It also provides modification options. How to chain access settings. The following code can be found in the file:

"condition": { "openWebviewCheck": true }
Copy after login

Among them, openWebviewCheck is true, which means that external link detection is enabled by default. To turn off the restriction, just modify the code to:

"condition": { "openWebviewCheck": false }
Copy after login

Save the file after the modification is completed.

3. Modify the page code

If there are pages in the application that need to be opened with an external browser, you can modify them through the following steps:

1. Add in the template Elements used for jumping such as buttons or a tags;

2. Add the following code in the script:

export default {
  methods: {
    jumpExternalUrl() {
      uni.navigateTo({
        url: "/pages/webview/index?url=" + encodeURIComponent(
          "https://blog.csdn.net/xxxxxx")
      })
    },
  },
}
Copy after login

Among them, the url is the jump link and needs to be encoded by encodeURIComponent.

Through the above steps, you can open the external link browser web page in the Uniapp application.

In short, to turn off Uniapp’s default setting of restricting external link browsers, you need to add corresponding code to the manifest.json and uni-config.json files and the page code. I hope this article can help developers who need to use browser kernel functions.

The above is the detailed content of How to turn off Uniapp's default restriction on external link browsers. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How do I handle local storage in uni-app? How do I handle local storage in uni-app? Mar 11, 2025 pm 07:12 PM

This article details uni-app's local storage APIs (uni.setStorageSync(), uni.getStorageSync(), and their async counterparts), emphasizing best practices like using descriptive keys, limiting data size, and handling JSON parsing. It stresses that lo

How to rename UniApp download files How to rename UniApp download files Mar 04, 2025 pm 03:43 PM

This article details workarounds for renaming downloaded files in UniApp, lacking direct API support. Android/iOS require native plugins for post-download renaming, while H5 solutions are limited to suggesting filenames. The process involves tempor

How to handle file encoding with UniApp download How to handle file encoding with UniApp download Mar 04, 2025 pm 03:32 PM

This article addresses file encoding issues in UniApp downloads. It emphasizes the importance of server-side Content-Type headers and using JavaScript's TextDecoder for client-side decoding based on these headers. Solutions for common encoding prob

How do I manage state in uni-app using Vuex or Pinia? How do I manage state in uni-app using Vuex or Pinia? Mar 11, 2025 pm 07:08 PM

This article compares Vuex and Pinia for state management in uni-app. It details their features, implementation, and best practices, highlighting Pinia's simplicity versus Vuex's structure. The choice depends on project complexity, with Pinia suita

How do I make API requests and handle data in uni-app? How do I make API requests and handle data in uni-app? Mar 11, 2025 pm 07:09 PM

This article details making and securing API requests within uni-app using uni.request or Axios. It covers handling JSON responses, best security practices (HTTPS, authentication, input validation), troubleshooting failures (network issues, CORS, s

How do I use uni-app's geolocation APIs? How do I use uni-app's geolocation APIs? Mar 11, 2025 pm 07:14 PM

This article details uni-app's geolocation APIs, focusing on uni.getLocation(). It addresses common pitfalls like incorrect coordinate systems (gcj02 vs. wgs84) and permission issues. Improving location accuracy via averaging readings and handling

How do I use uni-app's social sharing APIs? How do I use uni-app's social sharing APIs? Mar 13, 2025 pm 06:30 PM

The article details how to integrate social sharing into uni-app projects using uni.share API, covering setup, configuration, and testing across platforms like WeChat and Weibo.

How do I use uni-app's easycom feature for automatic component registration? How do I use uni-app's easycom feature for automatic component registration? Mar 11, 2025 pm 07:11 PM

This article explains uni-app's easycom feature, automating component registration. It details configuration, including autoscan and custom component mapping, highlighting benefits like reduced boilerplate, improved speed, and enhanced readability.

See all articles