Wordpress

Como adicionar uma imagem a Biblioteca “media library” do WordPress

Tutorial ensinando a como adicionar uma imagem a Biblioteca “media library” do pelo .

Você irá criar uma formulário para enviar a imagem e um arquivo PHP que irá processar o arquivo e “inseri-lo” no WordPress.

Quando você carrega arquivos da área de administração do WordPress, eles aparecerão automaticamente em Media> Library. Mas e se você quiser criar um carregador de arquivos personalizado especialmente para os visitantes do seu site?

Passo 1. Como de costume, começamos com um Formulário HTML

<form action="<?php echo get_stylesheet_directory_uri() ?>/process_upload.php" method="post" enctype="multipart/form-data">
 Your Photo: <input type="file" name="profilepicture" size="25" />
 <input type="submit" name="submit" value="Submit" />
</form>

Observações importantes

Coloquei o arquivo PHP process_upload.php no diretório do tema, se você deseja movê-lo para o outro local, não se esqueça de fazer alterações na próxima parte do código na linha 4.

2). O formulário deve ter enctype = atributo “multipart / form-data”. Muitos esquecem disso.

Você também pode criar um código curto para este formulário, basta inserir isso no arquivo do que está sendo utilizado.

add_shortcode( 'misha_uploader', 'misha_uploader_callback' );
 
function misha_uploader_callback(){
 return '<form action="' . get_stylesheet_directory_uri() . '/process_upload.php" method="post" enctype="multipart/form-data">
 Your Photo: <input type="file" name="profilepicture" size="25" />
 <input type="submit" name="submit" value="Submit" />
 </form>';
}

Passo 2. Processe o arquivo carregado em PHP e adicione os metadados do arquivo ao banco de dados do WordPress

<?php
 
// WordPress environment
require( dirname(__FILE__) . '/../../../wp-load.php' );
 
$wordpress_upload_dir = wp_upload_dir();
// $wordpress_upload_dir['path'] is the full server path to wp-content/uploads/2017/05, for multisite works good as well
// $wordpress_upload_dir['url'] the absolute URL to the same folder, actually we do not need it, just to show the link to file
$i = 1; // number of tries when the file with the same name is already exists
 
$profilepicture = $_FILES['profilepicture'];
$new_file_path = $wordpress_upload_dir['path'] . '/' . $profilepicture['name'];
$new_file_mime = mime_content_type( $profilepicture['tmp_name'] );
 
if( empty( $profilepicture ) )
 die( 'File is not selected.' );
 
if( $profilepicture['error'] )
 die( $profilepicture['error'] );
 
if( $profilepicture['size'] > wp_max_upload_size() )
 die( 'It is too large than expected.' );
 
if( !in_array( $new_file_mime, get_allowed_mime_types() ) )
 die( 'WordPress doesn\'t allow this type of uploads.' );
 
while( file_exists( $new_file_path ) ) {
 $i++;
 $new_file_path = $wordpress_upload_dir['path'] . '/' . $i . '_' . $profilepicture['name'];
}
 
// looks like everything is OK
if( move_uploaded_file( $profilepicture['tmp_name'], $new_file_path ) ) {
 
 
 $upload_id = wp_insert_attachment( array(
  'guid'           => $new_file_path, 
  'post_mime_type' => $new_file_mime,
  'post_title'     => preg_replace( '/\.[^.]+$/', '', $profilepicture['name'] ),
  'post_content'   => '',
  'post_status'    => 'inherit'
 ), $new_file_path );
 
 // wp_generate_attachment_metadata() won't work if you do not include this file
 require_once( ABSPATH . 'wp-admin/includes/image.php' );
 
 // Generate and save the attachment metas into the database
 wp_update_attachment_metadata( $upload_id, wp_generate_attachment_metadata( $upload_id, $new_file_path ) );
 
 // Show the uploaded file in browser
 wp_redirect( $wordpress_upload_dir['url'] . '/' . basename( $new_file_path ) );
 
}

Conclusão de Como adicionar uma imagem a Biblioteca

Opcionalmente, podemos definir o terceiro parâmetro do wp_insert_attachment () como uma identificação de postagem principal e definir a imagem desta publicação com set_post_thumbnail ().

Evite fazer alterações ou novas implementações no ambiente de produção.

Faça uma cópia do seu WordPress em ambiente local e execute todos os testes necessários.

Não se esqueça de realizar um Backup completo dos arquivos e .

Post Recentes

Por que devo sempre manter o Magento 2 atualizado?

Segurança: Atualizações frequentes geralmente incluem patches de segurança para corrigir vulnerabilidades identificadas. Ao manter o Magento atualizado, você reduz significativamente…

1 mês atrás

Adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2

Como adicionar uma mensagem de Alerta ou Aviso do Admin do Magento 2 Injete o Magento\Framework\Message\ManagerInterface no construtor da sua…

1 mês atrás

Exibir mensagens erro/sucesso da Classe: Magento\Framework\Message\ManagerInterface

Para exibir as mensagens adicionadas na classe Magento\Framework\Message\ManagerInterface em um arquivo .phtml, você pode usar o seguinte código: <?php $objectManager…

1 mês atrás

Exportar as categorias do Magento 2 em um XML

Para criar um script no Magento 2 que exporte as categorias para um arquivo XML com o nome da categoria,…

2 meses atrás

Colocar um video como Background utilizando HTML + CSS

Para definir um vídeo MP4 como plano de fundo em um <div> usando HTML e CSS, você pode seguir estas…

4 meses atrás

Desativar o “lastname” no Magento 2

Como desativar o "lastname" no Magento 2 e Adobe Commerce Desativando a obrigatoriedade do campo Execute a SQL abaixo diretamente…

4 meses atrás