is_protected_endpoint

函数
is_protected_endpoint ( No parameters )
返回值
  • (bool) True if the current endpoint should be protected.
定义位置
相关方法
is_protected_metaadd_rewrite_endpointis_protected_ajax_action_deprecated_argumentget_oembed_endpoint_url
引入
5.2.0
弃用
-

is_protected_endpoint – 这个函数检查一个给定的REST API端点是否被保护。如果该端点是受保护的,该函数返回true。

确定我们当前是否在一个应该被保护的端点上,以防止WSOD。

function is_protected_endpoint() {
	// Protect login pages.
	if ( isset( $GLOBALS['pagenow'] ) && 'wp-login.php' === $GLOBALS['pagenow'] ) {
		return true;
	}

	// Protect the admin backend.
	if ( is_admin() && ! wp_doing_ajax() ) {
		return true;
	}

	// Protect Ajax actions that could help resolve a fatal error should be available.
	if ( is_protected_ajax_action() ) {
		return true;
	}

	/**
	 * Filters whether the current request is against a protected endpoint.
	 *
	 * This filter is only fired when an endpoint is requested which is not already protected by
	 * WordPress core. As such, it exclusively allows providing further protected endpoints in
	 * addition to the admin backend, login pages and protected Ajax actions.
	 *
	 * @since 5.2.0
	 *
	 * @param bool $is_protected_endpoint Whether the currently requested endpoint is protected.
	 *                                    Default false.
	 */
	return (bool) apply_filters( 'is_protected_endpoint', false );
}

常见问题

FAQs
查看更多 >