WordPress開發(fā) - 怎么在前臺頁面添加自定義用戶頭像功能?

    主題默認使用的 gravatar頭像 在國內(nèi)不怎么方便(雖然全球都在用),為了適應(yīng)國內(nèi)的環(huán)境,我們得來修改下,這次分享的WordPress開發(fā)教程是在前臺操作的,有點麻煩

    主題默認使用的 gravatar頭像 在國內(nèi)不怎么方便(雖然全球都在用),為了適應(yīng)國內(nèi)的環(huán)境,我們得來修改下,這次分享的WordPress開發(fā)教程是在前臺操作的,有點麻煩,需要簡便后臺操作的可以看這篇文章《純代碼實現(xiàn)用戶添加自定義頭像功能

    思路:我們可以給 wordpress主題數(shù)據(jù)庫添加一個用戶自定義字段,然后把前臺上傳的圖片保存到這個自定義字段中,在前臺模板中需要用戶頭像的地方,就調(diào)用這個自定義字段就可以了。

    WordPress開發(fā) - 怎么在前臺頁面添加自定義用戶頭像功能?
    背景圖片 - wordpress開發(fā)

    第一步:在 wp 主題用戶中心的個人資料修改頁面添加用戶頭像上傳表單:

        <form action="" method="post" enctype="multipart/form-data">
        <!-- 用戶圖像 -->
        <div class="change-photo-btn">
        <div class="photoUpload">
           <span><i class="fa fa-upload"></i> 上傳圖像</span>
           <input type="file" class="upload" name="simple_local_avatar"/>
        </div>
        </div>

    這里的 simple_local_avatar 就是用戶頭像自定義字段鍵名。注:上傳圖片的表單必須要加上 enctype=”multipart/form-data” 這個,沒有這個就無法上傳。

    第二步:在WordPress主題的 functions.php 文件中添加上傳圖片的處理函數(shù)代碼:

    //圖片上傳函數(shù):上傳單張圖片
    //參數(shù)1:圖片信息; 參數(shù)2:存放圖片路徑
    function upload_image($info,$path){
    //獲取圖片后綴
    $pre = strrchr($info["name"],".");
    $img_name = date("YmdHis").$pre;
    //錯誤過濾
    if($info["error"]>0){
    switch($info["error"]){
    case 1: echo "文件大小超過php.ini設(shè)置的大小 2M。"; break;
    case 2: echo "文件大小超過表單設(shè)置的大小。"; break;
    case 3: echo "文件只有部分被上傳。"; break;
    case 4: echo "沒有文件被上傳。"; break;
    case 6: echo "找不到臨時文件夾。"; break;
    case 7: echo "文件寫入失敗。"; break;
    }
    echo '<script>alert("返回添加圖片頁面。"); window.history.back(); </script>';
    exit;
    }
    //圖片類型過濾
    $pic_arr = array("image/jpeg","image/jpg","image/pjpeg","image/png","image/x-png","image/gif");
    if(!in_array($info["type"],$pic_arr)){
    echo '<script>alert("上傳的文件必須是 jpg、png、gif格式的。"); window.history.back();</script>';
    exit;
    }
    //圖片大小過濾
    if($info["size"]>(10*1024*1024)){
    echo '<script>alert("上傳圖片的大小不能超過 10M。"); window.history.back();</script>';
    exit;
    }
    if(is_uploaded_file($info["tmp_name"])){
    move_uploaded_file($info["tmp_name"],$path.$img_name);
    return $img_name;
    }
    }

    第三步:上傳圖片并保存到數(shù)據(jù)庫:

        $path = WP_CONTENT_DIR.'/uploads/users_avagar/'; //在 uploads目錄下創(chuàng)建一個 users_avagar目錄
        if(!is_dir($path)){
        mkdir($path);
        }
        //組合 圖片url
        $img_url['full'] = WP_CONTENT_URL.'/uploads/users_avagar/'.upload_image($files,$path);
        update_user_meta($uid,'simple_local_avatar',$img_url); //寫入數(shù)據(jù)庫

    通過上面的 3 步,我們就對wordPress主題實現(xiàn)了用戶在前臺頁面就可以上傳修改自定義頭像了,然后在需要調(diào)用頭像的地方,使用 get_user_meta() 方法來調(diào)用。不過,這種方法也有一個缺陷:就是沒有跟 gravatar 頭像調(diào)用方法通用,調(diào)用 gravatar 頭像的方法:get_avatar() ,如查想使用 get_avatar 來調(diào)用我們這個自定義頭像,可以添加一些判斷處理,這里就不多做介紹了。

    • 參考來源: http://naivet.xintheme.cn/wp_course/13.html

    這套教程對于需要開發(fā)前臺用戶中心很有用處,如果只是簡單的想要個自定義頭像功能,那么可以參考這篇wordpress開發(fā)教程:

    WordPress開發(fā) - 怎么在前臺頁面添加自定義用戶頭像功能?-Npcink
    WordPress開發(fā) - 怎么在前臺頁面添加自定義用戶頭像功能?-Npcink

    純代碼實現(xiàn)用戶添加自定義頭像功能 - wordpres開發(fā)

    教程

    94設(shè)計素材網(wǎng)vip界面表格 - B2主題WordPress美化

    2020-7-9 16:13:01

    軟件

    Imagine - 圖片壓縮軟件

    2019-11-28 1:26:00

    ??
    Npcink上的部份代碼及教程來源于互聯(lián)網(wǎng),僅供網(wǎng)友學(xué)習(xí)交流,若您喜歡本文可附上原文鏈接隨意轉(zhuǎn)載。
    無意侵害您的權(quán)益,請發(fā)送郵件至 1355471563#qq.com 或點擊右側(cè) 私信:Muze 反饋,我們將盡快處理。
    0 條回復(fù) A文章作者 M管理員
      暫無討論,說說你的看法吧
    ?
    個人中心
    購物車
    優(yōu)惠劵
    今日簽到
    有新私信 私信列表
    搜索
    主站蜘蛛池模板: 国产伦精品一区二区免费 | 国产伦精品一区二区三区四区| 亚洲国产一区二区三区青草影视| 国产精品美女一区二区视频| 久久无码AV一区二区三区| 色屁屁一区二区三区视频国产| 亚洲国产综合精品一区在线播放| 亚洲一区二区三区免费在线观看 | 无码AV中文一区二区三区| 国产精品熟女视频一区二区| 人妻激情偷乱视频一区二区三区| 免费国产在线精品一区| 国产成人亚洲综合一区| 亚州日本乱码一区二区三区| 高清一区二区在线观看| 国产日韩高清一区二区三区| 亚洲熟妇av一区二区三区| 亚洲欧美国产国产一区二区三区| 国产免费伦精品一区二区三区| 交换国产精品视频一区| 国产一区二区免费在线| 无码人妻精品一区二区| 日本精品一区二区三区在线视频 | 国产精品丝袜一区二区三区| 玩弄放荡人妻一区二区三区| 中文无码精品一区二区三区| 亚洲欧美国产国产一区二区三区 | 免费无码一区二区三区蜜桃大| 一区二区三区在线看| 91精品一区二区综合在线 | 精品欧洲av无码一区二区14 | 亚洲综合无码一区二区三区| 老鸭窝毛片一区二区三区 | 精品人妻少妇一区二区三区| 国产成人精品无码一区二区 | 国产伦精品一区二区三区免.费 | 免费观看一区二区三区| 久久精品无码一区二区三区免费| 国产一区二区精品久久| 老湿机一区午夜精品免费福利| 国产精品一区二区久久精品|