私はすでにWordPress APIから返されたJSONの設定を解除することができます(通常の投稿から詳細を削除する)。私は実際にこの例から以下を使用しています: https://css-tricks.com/using-the-wp-api-to-fetch-posts/
私が困っていて理解できないのは、これを変更してデータを カスタム投稿タイプから削除する方法です
考えですか?
function qod_remove_extra_data( $data, $post, $context ) {
// We only want to modify the 'view' context, for reading posts
if ( $context !== 'view' || is_wp_error( $data ) ) {
return $data;
}
// Here, we unset any data we don't want to see on the front end:
unset( $data['author'] );
unset( $data['status'] );
unset( $data['featured_image'] );
//etc etc
return $data;
}
add_filter( 'json_prepare_post', 'qod_remove_extra_data', 12, 3 );
カスタム投稿タイプの新しい例**
function projectPost_remove_extra_data( $data, $post, $context ) {
// We only want to modify the 'view' context, for reading posts
if ( $context !== 'view' || is_wp_error( $data ) ) {
return $data;
}
// Here, we unset any data we don't want to see on the front end:
unset( $data['author'] );
unset( $data['status'] );
return $data;
}
add_filter( 'json_prepare_project', 'projectPost_remove_extra_data', 12, 3 );
可能であれば、インターネットに表示されている例のみです。
qod_remove_extra_data function ($ data, $ post, $ context) {
// We only want to modify the 'view' context, for reading posts
if ($ context! == 'view' || is_wp_error ($ data)) {
return $ data;
}
// Here, we unset any data we do not want to see on the front end:
unset ($data ['author']);
unset ($data ['status']);
// Continue unsetting whatever other fields you want return $ data;
}
add_filter ('json_prepare_post' 'qod remove extra_data', 12, 3);
そして正しいです:
qod_remove_extra_data function ($ data, $ post, $ context) {
// We only want to modify the 'view' context, for reading posts
if ($ context! == 'view' || is_wp_error ($ data)) {
unset ( $data->data ['excerpt']); //Example
unset ($data->data ['content']); //Example
unset ($data->data ['name field to remove'])
//or
unset ($data->data ['name field to remove'] ['name subfield if you only want to delete the sub-field of field' ])
return $data;
}
}
add_filter ('rest_prepare_post', 'qod_remove_extra_data', 12, 3);
重要です:
add_filter ('**rest_prepare_post**', 'qod_remove_extra_data', 12, 3);
ではない:
add_filter ('**json_prepare_post**' 'qod remove extra_data', 12, 3); //WRONG (No underscores)
カスタム投稿タイプの場合:
add_filter ('**rest_prepare_{$post_type}**', 'qod_remove_extra_data', 12, 3);
例:名前投稿タイプ= product;
add_filter ('**rest_prepare_product**', 'qod_remove_extra_data', 12, 3);
このコードを使用すると、JSONが必要なフィールドを削除できます。 rest_prepare} _ {$ post_typeを使用することで、すべてのpost_typeフィールドを削除し、必要なpost_typeにのみ影響を与え、すべてには影響を与えないと決定します。
(カスタム投稿タイプの)ページのwp-apiコードを見てください。
あなたは自分の投稿タイプが呼ばれるものにページを変更して、コードを修正することができます(それらのいくつかはワードプレスの関数呼び出しまたはフィルタであるため、検索をすることとすべての「ページ」を置き換えることに注意してください)
<?php
/**
* Page post type handlers
*
* @package WordPress
* @subpackage JSON API
*/
/**
* Page post type handlers
*
* This class serves as a small addition on top of the basic post handlers to
* add small functionality on top of the existing API.
*
* In addition, this class serves as a sample implementation of building on top
* of the existing APIs for custom post types.
*
* @package WordPress
* @subpackage JSON API
*/
class WP_JSON_Pages extends WP_JSON_CustomPostType {
/**
* Base route
*
* @var string
*/
protected $base = '/pages';
/**
* Post type
*
* @var string
*/
protected $type = 'page';
/**
* Register the page-related routes
*
* @param array $routes Existing routes
* @return array Modified routes
*/
public function register_routes( $routes ) {
$routes = parent::register_routes( $routes );
$routes = parent::register_revision_routes( $routes );
$routes = parent::register_comment_routes( $routes );
// Add post-by-path routes
$routes[ $this->base . '/(?P<path>.+)'] = array(
array( array( $this, 'get_post_by_path' ), WP_JSON_Server::READABLE ),
array( array( $this, 'edit_post_by_path' ), WP_JSON_Server::EDITABLE | WP_JSON_Server::ACCEPT_JSON ),
array( array( $this, 'delete_post_by_path' ), WP_JSON_Server::DELETABLE ),
);
return $routes;
}
/**
* Retrieve a page by path name
*
* @param string $path
* @param string $context
*
* @return array|WP_Error
*/
public function get_post_by_path( $path, $context = 'view' ) {
$post = get_page_by_path( $path, ARRAY_A );
if ( empty( $post ) ) {
return new WP_Error( 'json_post_invalid_id', __( 'Invalid post ID.' ), array( 'status' => 404 ) );
}
return $this->get_post( $post['ID'], $context );
}
/**
* Edit a page by path name
*
* @param $path
* @param $data
* @param array $_headers
*
* @return true|WP_Error
*/
public function edit_post_by_path( $path, $data, $_headers = array() ) {
$post = get_page_by_path( $path, ARRAY_A );
if ( empty( $post ) ) {
return new WP_Error( 'json_post_invalid_id', __( 'Invalid post ID.' ), array( 'status' => 404 ) );
}
return $this->edit_post( $post['ID'], $data, $_headers );
}
/**
* Delete a page by path name
*
* @param $path
* @param bool $force
*
* @return true|WP_Error
*/
public function delete_post_by_path( $path, $force = false ) {
$post = get_page_by_path( $path, ARRAY_A );
if ( empty( $post ) ) {
return new WP_Error( 'json_post_invalid_id', __( 'Invalid post ID.' ), array( 'status' => 404 ) );
}
return $this->delete_post( $post['ID'], $force );
}
/**
* Prepare post data
*
* @param array $post The unprepared post data
* @param string $context The context for the prepared post. (view|view-revision|edit|embed|single-parent)
* @return array The prepared post data
*/
protected function prepare_post( $post, $context = 'view' ) {
$_post = parent::prepare_post( $post, $context );
// Override entity meta keys with the correct links
$_post['meta']['links']['self'] = json_url( $this->base . '/' . get_page_uri( $post['ID'] ) );
if ( ! empty( $post['post_parent'] ) ) {
$_post['meta']['links']['up'] = json_url( $this->base . '/' . get_page_uri( (int) $post['post_parent'] ) );
}
return apply_filters( 'json_prepare_page', $_post, $post, $context );
}
}
あなたのカスタムコードを編集やフィルタ等に入れると、あなたは去ります!
ps - 適切なプラグインに変えることを忘れないでください!あなたは新しいプラグインとして追加し、それを使ってより良い方法でそれを管理することができます:
<?php
/**
* Plugin Name: My JSON App API
* Description: My Route and Endpoint handler for the JSON API
* Dependency: This plugin requires JSON BasicKey Authentication Plugin!!!!
* Author: Blah Blah Blah, plus much original code from the WordPress API Team
* Author URI: https://www.example.com
* Version: 1.2
* Plugin URI: https://www.example.com
*/
if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
if (!defined("MY_JSON_API_VERSION")) {
define ("MY_JSON_API_VERSION", "1.2") ;
}
function my_json_api_init() {
global $my_json_api_mobile_users;
$my_json_api_mobile_users = new my_JSON_API_MobileUsers();
add_filter( 'json_endpoints', array( $my_json_api_mobile_users, 'register_routes' ) );
}
add_action( 'wp_json_server_before_serve', 'my_json_api_init' );