wp_post_mime_type_where

函数
wp_post_mime_type_where ( $post_mime_types, $table_alias = '' )
参数
  • (string|string[]) $post_mime_types List of mime types or comma separated string of mime types.
    Required:
  • (string) $table_alias Optional. Specify a table alias, if needed. Default empty.
    Required:
    Default: (empty)
返回值
  • (string) The SQL AND clause for mime searching.
定义位置
相关方法
get_post_mime_typeget_post_mime_typeswp_get_mime_typeswp_match_mime_typeswp_mime_type_icon
引入
2.5.0
弃用
-

wp_post_mime_type_where。这个过滤器用于过滤SQL WHERE子句,以按mime类型查询附件: 当WordPress按mime类型查询附件时,它被触发。

将MIME类型转换为SQL。

function wp_post_mime_type_where( $post_mime_types, $table_alias = '' ) {
	$where     = '';
	$wildcards = array( '', '%', '%/%' );
	if ( is_string( $post_mime_types ) ) {
		$post_mime_types = array_map( 'trim', explode( ',', $post_mime_types ) );
	}

	$wheres = array();

	foreach ( (array) $post_mime_types as $mime_type ) {
		$mime_type = preg_replace( '/s/', '', $mime_type );
		$slashpos  = strpos( $mime_type, '/' );
		if ( false !== $slashpos ) {
			$mime_group    = preg_replace( '/[^-*.a-zA-Z0-9]/', '', substr( $mime_type, 0, $slashpos ) );
			$mime_subgroup = preg_replace( '/[^-*.+a-zA-Z0-9]/', '', substr( $mime_type, $slashpos + 1 ) );
			if ( empty( $mime_subgroup ) ) {
				$mime_subgroup = '*';
			} else {
				$mime_subgroup = str_replace( '/', '', $mime_subgroup );
			}
			$mime_pattern = "$mime_group/$mime_subgroup";
		} else {
			$mime_pattern = preg_replace( '/[^-*.a-zA-Z0-9]/', '', $mime_type );
			if ( false === strpos( $mime_pattern, '*' ) ) {
				$mime_pattern .= '/*';
			}
		}

		$mime_pattern = preg_replace( '/*+/', '%', $mime_pattern );

		if ( in_array( $mime_type, $wildcards, true ) ) {
			return '';
		}

		if ( false !== strpos( $mime_pattern, '%' ) ) {
			$wheres[] = empty( $table_alias ) ? "post_mime_type LIKE '$mime_pattern'" : "$table_alias.post_mime_type LIKE '$mime_pattern'";
		} else {
			$wheres[] = empty( $table_alias ) ? "post_mime_type = '$mime_pattern'" : "$table_alias.post_mime_type = '$mime_pattern'";
		}
	}

	if ( ! empty( $wheres ) ) {
		$where = ' AND (' . implode( ' OR ', $wheres ) . ') ';
	}

	return $where;
}

常见问题

FAQs
查看更多 >