目錄
建立自訂欄位
#使用欄位填入元框
#儲存自訂欄位資料
讀取自訂欄位資料
安全
下一个...
首頁 web前端 html教學 WordPress中建立一個簡單的CRM:建立自訂字段

WordPress中建立一個簡單的CRM:建立自訂字段

Aug 29, 2023 pm 03:49 PM
wordpress crm 自訂字段

在本系列中,我們一直在研究如何在 WordPress 中建立簡單的 CRM 系統。在本系列的第一部分中,我們建立了一個註冊「聯絡人」自訂貼文類型的 WordPress 插件,但我們尚未介紹如何儲存聯絡人的其他資訊。

建立自訂欄位

WordPress 具有 add_meta_box() 函數,該函數允許外掛程式和主題開發人員針對各種 WordPress 管理畫面註冊自訂元框。

WordPress 會註冊一些自己的元框,以便在您建立貼文或頁面時顯示。例如,在頁面上,您有頁面屬性元框:

WordPress中建立一個簡單的CRM:建立自訂字段

#讓我們為聯絡人自訂貼文類型新增一個元框。開啟您在本系列第一篇教學中建立的插件檔案。然後,在插件的建構函式中,更新程式碼以符合以下內容。這將我們的 register_meta_boxes() 函數註冊到 add_meta_boxes 操作:

/**
* Constructor. Called when plugin is initialised
*/
function __construct() {

	add_action( 'init', array( $this, 'register_custom_post_type' ) );
	add_action( 'add_meta_boxes', array( $this, 'register_meta_boxes' ) ); 
    
}
登入後複製

接下來,在我們的 register_meta_boxes() 函數中,我們加入對 add_meta_box() 的呼叫。這告訴 WordPress 我們需要一個名為 Contact Details 的元框,它由 output_meta_box() 函數呈現。在建構函式後加入以下程式碼:

/**
* Registers a Meta Box on our Contact Custom Post Type, called 'Contact Details'
*/
function register_meta_boxes() {
	add_meta_box( 'contact-details', 'Contact Details', array( $this, 'output_meta_box' ), 'contact', 'normal', 'high' );	
}
登入後複製

最後,我們需要一個output_meta_box()函數,該函數是由上面的add_meta_box呼叫的。在register_meta_boxes()函數後面加入以下程式碼:

/**
* Output a Contact Details meta box
*
* @param WP_Post $post WordPress Post object
*/
function output_meta_box($post) {

}
登入後複製

讓我們檢查一下我們的聯絡人自訂貼文類型上是否出現了一個元框。前往聯絡人 > 新增聯絡人

,在 WordPress 儀表板中建立新聯絡人。

如果所有內容都正確編寫,您應該會看到類似於以下螢幕截圖的內容:

WordPress中建立一個簡單的CRM:建立自訂字段

#使用欄位填入元框

讓我們繼續在此元框中新增一個電子郵件地址欄位。將 output_meta_box 函數更改為以下程式碼:

/**
* Output a Contact Details meta box
*
* @param WP_Post $post WordPress Post object
*/
function output_meta_box( $post ) {
	// Output label and field
    echo ( '<label for="contact_email">' . __( 'Email Address', 'tuts-crm' ) . '</label>'  );
	echo ( '<input type="text" name="contact_email" id="contact_email" value="' . esc_attr( $email ) . '" />'  );
    
}
登入後複製

儲存您的外掛程式碼,然後重新載入「新增聯絡人」畫面。您應該會看到我們的新電子郵件地址欄位出現在「聯絡資訊」元框中:

WordPress中建立一個簡單的CRM:建立自訂字段

#儲存自訂欄位資料

我們還沒有完全完成。我們需要告訴 WordPress 保存使用者在該欄位中輸入的內容。在 WordPress 中,我們透過針對 save_post 作業註冊一個函數來實現此目的。

與大多數操作一樣,我們將在插件的建構子中註冊我們的操作:

/**
* Constructor. Called when plugin is initialised
*/
function __construct() {

	add_action( 'init', array( $this, 'register_custom_post_type' ) );
	add_action( 'add_meta_boxes', array( $this, 'register_meta_boxes' ) ); 
	add_action( 'save_post', array( $this, 'save_meta_boxes' ) );
    
}
登入後複製

接下來,讓我們建立 save_meta_boxes() 函數:

/**
* Saves the meta box field data
*
* @param int $post_id Post ID
*/
function save_meta_boxes( $post_id ) {

	// Check this is the Contact Custom Post Type
	if ( 'contact' != $_POST['post_type'] ) {
		return $post_id;
	}

	// Check the logged in user has permission to edit this post
	if ( ! current_user_can( 'edit_post', $post_id ) ) {
		return $post_id;
	}

	// OK to save meta data
	$email = sanitize_text_field( $_POST['contact_email'] );
	update_post_meta( $post_id, '_contact_email', $email );
    
}
登入後複製

此函數執行多個操作,因為 WordPress 和其他外掛程式可以非常頻繁地呼叫 save_post 操作(例如,當定期自動儲存草稿或儲存不同的貼文類型時)。我們需要確保僅在使用者儲存或更新聯絡人時才保存自訂欄位資料。

如果我們要儲存聯絡人,我們會清理電子郵件地址。來自 WordPress 法典:

檢查無效的 UTF-8,將單一 < 字元轉換為實體,剝離所有標籤,刪除換行符、製表符和額外的空格,剝離八位元組。 < 字符转换为实体,剥离所有标签,删除换行符、制表符和额外的空格,剥离八位字节。

簡而言之,我們確保文字字串中沒有任何時髦的格式。

最後,我們使用 update_post_meta 將電子郵件地址儲存在貼文元資料中。將帖子元視為附加到帖子的一系列鍵/值對。您可以根據自己的喜好選擇任意數量。在我們的範例中,我們根據鍵 _contact_email 儲存自訂欄位的值。

讀取自訂欄位資料

建立新的聯絡人並輸入電子郵件地址。儲存新的聯絡人,您會發現電子郵件地址沒有出現在欄位中:

WordPress中建立一個簡單的CRM:建立自訂字段

#我們需要編輯 output_meta_box() 函數來讀取 Post 元,並將其顯示在輸入欄位中。將 output_meta_box() 函數更改為以下程式碼:

/**
* Output a Contact Details meta box
*
* @param WP_Post $post WordPress Post object
*/
function output_meta_box($post) {

	$email = get_post_meta( $post->ID, '_contact_email', true );
	
	// Output label and field
    echo ( '<label for="contact_email">' . __( 'Email Address', 'tuts-crm' ) . '</label>' );
	echo ( '<input type="text" name="contact_email" id="contact_email" value="' . esc_attr( $email ) . '" />' );
    
}
登入後複製

我們使用 get_post_meta() 來取得給定貼文 ID 和元鍵組合的值。我們知道元鍵是 _contact_email,因為這就是我們在 update_post_meta()

中保存自定义字段值时使用的键

安全

提交和处理表单数据时,安全性极其重要。我们在保存数据时需要知道数据的来源是可信的。如果我们不能信任数据的来源,我们就不能存储它——数据可能会因试图利用错误或安全缺陷而受到损害或损坏。

WordPress 为我们提供了随机数(“使用一次的数字”),可以与表单数据一起发送。当我们的保存例程运行时,可以检查这个随机数,以确保它与我们期望的值匹配。

这有助于防止跨站点请求伪造 (CSRF) 攻击,即有人试图从不同的网站向我们的保存例程提交表单数据。

我们需要在上面的代码的两个地方添加安全性:

  1. output_meta_box():向表单添加随机数
  2. save_meta_boxes():验证提交的随机数值

让我们编辑 output_meta_box() 函数,将其替换为以下代码:

/**
* Output a Contact Details meta box
*
* @param WP_Post $post WordPress Post object
*/
function output_meta_box($post) {

    $email = get_post_meta( $post->ID, '_contact_email', true );
	
	// Add a nonce field so we can check for it later.
	wp_nonce_field( 'save_contact', 'contacts_nonce' );
	
	// Output label and field
	echo ( '<label for="contact_email">' . __( 'Email Address', 'tuts-crm' ) . '</label>' );
	echo ( '<input type="text" name="contact_email" id="contact_email" value="' . esc_attr( $email ) . '" />' );
    
}
登入後複製

这使用 wp_nonce_field() 生成一个名为 contacts_nonce 的隐藏字段,并执行名为 save_contact 的操作。它的价值是由WordPress产生的。

接下来,让我们在 save_meta_boxes() 中编辑保存例程:

/**
* Saves the meta box field data
*
* @param int $post_id Post ID
*/
function save_meta_boxes( $post_id ) {

	// Check if our nonce is set.
	if ( ! isset( $_POST['contacts_nonce'] ) ) {
		return $post_id;	
	}

	// Verify that the nonce is valid.
	if ( ! wp_verify_nonce( $_POST['contacts_nonce'], 'save_contact' ) ) {
		return $post_id;
	}

	// Check this is the Contact Custom Post Type
	if ( 'contact' != $_POST['post_type'] ) {
		return $post_id;
	}

	// Check the logged in user has permission to edit this post
	if ( ! current_user_can( 'edit_post', $post_id ) ) {
		return $post_id;
	}

	// OK to save meta data
	$email = sanitize_text_field( $_POST['contact_email'] );
	update_post_meta( $post_id, '_contact_email', $email );
    
}
登入後複製

这为我们的保存例程添加了两项检查:

  1. 检查我们的表单中是否设置了随机数字段。如果没有,请不要保存任何内容。
  2. 检查随机数字段的值是否符合我们的预期。如果没有,请不要保存任何内容。

创建或编辑您的联系人,并确保电子邮件地址现已保存。

下一个...

在下一篇文章中,我们将使用高级自定义字段将自定义字段添加到我们的联系人自定义帖子类型中,从而使我们能够创建具有更广泛输入类型的丰富用户界面.

以上是WordPress中建立一個簡單的CRM:建立自訂字段的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

wordpress文章列表怎麼調 wordpress文章列表怎麼調 Apr 20, 2025 am 10:48 AM

有四種方法可以調整 WordPress 文章列表:使用主題選項、使用插件(如 Post Types Order、WP Post List、Boxy Stuff)、使用代碼(在 functions.php 文件中添加設置)或直接修改 WordPress 數據庫。

wordpress屏蔽ip的插件有哪些 wordpress屏蔽ip的插件有哪些 Apr 20, 2025 am 08:27 AM

WordPress 屏蔽 IP 的插件選擇至關重要。可考慮以下類型:基於 .htaccess:高效,但操作複雜;數據庫操作:靈活,但效率較低;基於防火牆:安全性能高,但配置複雜;自行編寫:最高控制權,但需要更多技術水平。

wordpress編輯日期怎麼取消 wordpress編輯日期怎麼取消 Apr 20, 2025 am 10:54 AM

WordPress 編輯日期可以通過三種方法取消:1. 安裝 Enable Post Date Disable 插件;2. 在 functions.php 文件中添加代碼;3. 手動編輯 wp_posts 表中的 post_modified 列。

wordpress主題頭部圖片如何更換 wordpress主題頭部圖片如何更換 Apr 20, 2025 am 10:00 AM

更換 WordPress 主題頭部圖片的分步指南:登錄 WordPress 儀錶盤,導航至“外觀”&gt;“主題”。選擇要編輯的主題,然後單擊“自定義”。打開“主題選項”面板並尋找“網站標頭”或“頭部圖片”選項。單擊“選擇圖像”按鈕並上傳新的頭部圖片。裁剪圖像並單擊“保存並裁剪”。單擊“保存並發布”按鈕以更新更改。

wordpress主機怎麼建站 wordpress主機怎麼建站 Apr 20, 2025 am 11:12 AM

要使用 WordPress 主機建站,需要:選擇一個可靠的主機提供商。購買一個域名。設置 WordPress 主機帳戶。選擇一個主題。添加頁面和文章。安裝插件。自定義您的網站。發布您的網站。

wordpress怎麼寫頁頭 wordpress怎麼寫頁頭 Apr 20, 2025 pm 12:09 PM

在WordPress中創建自定義頁頭的步驟如下:編輯主題文件“header.php”。添加您的網站名稱和描述。創建導航菜單。添加搜索欄。保存更改並查看您的自定義頁頭。

wordpress出現錯誤怎麼辦 wordpress出現錯誤怎麼辦 Apr 20, 2025 am 11:57 AM

WordPress 錯誤解決指南:500 內部服務器錯誤:禁用插件或檢查服務器錯誤日誌。 404 未找到頁面:檢查 permalink 並確保頁面鏈接正確。白屏死機:增加服務器 PHP 內存限制。數據庫連接錯誤:檢查數據庫服務器狀態和 WordPress 配置。其他技巧:啟用調試模式、檢查錯誤日誌和尋求支持。預防錯誤:定期更新 WordPress、僅安裝必要插件、定期備份網站和優化網站性能。

wordpress評論怎麼顯示 wordpress評論怎麼顯示 Apr 20, 2025 pm 12:06 PM

WordPress 網站中啟用評論功能:1. 登錄管理面板,轉到 "設置"-"討論",勾選 "允許評論";2. 選擇顯示評論的位置;3. 自定義評論表單;4. 管理評論,批准、拒絕或刪除;5. 使用 &lt;?php comments_template(); ?&gt; 標籤顯示評論;6. 啟用嵌套評論;7. 調整評論外形;8. 使用插件和驗證碼防止垃圾評論;9. 鼓勵用戶使用 Gravatar 頭像;10. 創建評論指

See all articles