easyswoole - 基于swoole扩展实现的一款高性能php框架

EasySwoole 驗證碼組件

EasySwoole 提供了獨立的 驗證碼組件 ,幾行代碼即可實現輸出一個驗證碼,支持用戶自定義驗證碼字體

組件要求

  • php: >=7.1
  • ext-gd: *
  • easyswoole/spl: ^1.0

安裝方法

composer require easyswoole/verifycode=3.x

倉庫地址

easyswoole/verifycode=3.x

基本使用

配置

生成驗證碼前需要傳入 \EasySwoole\VerifyCode\Conf 的對象實例,\EasySwoole\VerifyCode\Conf 類實例化后會有默認配置,無需配置也可生成驗證碼圖片。

下面是 \EasySwoole\VerifyCode\Conf 類提供的相關配置方法。

<?php
// +----------------------------------------------------------------------
// | easySwoole [ use swoole easily just like echo "hello world" ]
// +----------------------------------------------------------------------
// | WebSite: http://www.zbjtqy.com
// +----------------------------------------------------------------------
// | Welcome Join QQGroup 853946743
// +----------------------------------------------------------------------

namespace EasySwoole\VerifyCode;

use EasySwoole\Spl\SplBean;

/**
 * 驗證碼配置文件
 * Class VerifyCodeConf
 * @author  : evalor <master@evalor.cn>
 * @package Vendor\VerifyCode
 */
class Conf extends SplBean
{

    public $charset   = '1234567890AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz'; // 字母表
    public $useCurve  = false;         // 混淆曲線
    public $useNoise  = false;         // 隨機噪點
    public $useFont   = null;          // 指定字體
    public $fontColor = null;          // 字體顏色
    public $backColor = null;          // 背景顏色
    public $imageL    = null;          // 圖片寬度
    public $imageH    = null;          // 圖片高度
    public $fonts     = [];            // 額外字體
    public $fontSize  = 25;            // 字體大小
    public $length    = 4;             // 生成位數
    public $mime      = MIME::PNG;     // 設置類型
    public $temp      = '/tmp';  // 設置緩存目錄

    public function setTemp($temp){
        if (!is_dir($temp)) mkdir($temp,0755) && chmod($temp,0755);
        $this->temp = $temp;
    }

    /**
     * 設置圖片格式
     * @param $MimeType
     * @author : evalor <master@evalor.cn>
     * @return Conf
     */
    public function setMimeType($MimeType)
    {
        $allowMime = [ MIME::PNG, MIME::GIF, MIME::JPG ];
        if (in_array($MimeType, $allowMime)) $this->mime = $MimeType;
        return $this;
    }

    /**
     * 設置字符集
     * @param string $charset
     * @return Conf
     */
    public function setCharset($charset)
    {
        is_string($charset) && $this->charset = $charset;
        return $this;
    }

    /**
     * 開啟混淆曲線
     * @param bool $useCurve
     * @return Conf
     */
    public function setUseCurve($useCurve = true)
    {
        is_bool($useCurve) && $this->useCurve = $useCurve;
        return $this;
    }

    /**
     * 開啟噪點生成
     * @param bool $useNoise
     * @return Conf
     */
    public function setUseNoise($useNoise = true)
    {
        is_bool($useNoise) && $this->useNoise = $useNoise;
        return $this;
    }

    /**
     * 使用自定義字體
     * @param string $useFont
     * @return Conf
     */
    public function setUseFont($useFont)
    {
        is_string($useFont) && $this->useFont = $useFont;
        return $this;
    }

    /**
     * 設置文字顏色
     * @param array|string $fontColor
     * @return Conf
     */
    public function setFontColor($fontColor)
    {
        if (is_string($fontColor)) $this->fontColor = $this->HEXToRGB($fontColor);
        if (is_array($fontColor)) $this->fontColor = $fontColor;
        return $this;
    }

    /**
     * 設置背景顏色
     * @param null $backColor
     * @return Conf
     */
    public function setBackColor($backColor)
    {
        if (is_string($backColor)) $this->backColor = $this->HEXToRGB($backColor);
        if (is_array($backColor)) $this->backColor = $backColor;
        return $this;
    }

    /**
     * 設置圖片寬度
     * @param int|string $imageL
     * @return Conf
     */
    public function setImageWidth($imageL)
    {
        $this->imageL = intval($imageL);
        return $this;
    }

    /**
     * 設置圖片高度
     * @param null $imageH
     * @return Conf
     */
    public function setImageHeight($imageH)
    {
        $this->imageH = intval($imageH);
        return $this;
    }

    /**
     * 設置字體集
     * @param array|string $fonts
     * @return Conf
     */
    public function setFonts($fonts)
    {
        if (is_string($fonts)) array_push($this->fonts, $fonts);
        if (is_array($fonts) && !empty($fonts)) {
            if (empty($this->fonts)) {
                $this->fonts = $fonts;
            } else {
                array_merge($this->fonts, $fonts);
            }
        }
        return $this;
    }

    /**
     * 設置字體尺寸
     * @param int $fontSize
     * @return Conf
     */
    public function setFontSize($fontSize)
    {
        $this->fontSize = intval($fontSize);
        return $this;
    }

    /**
     * 設置驗證碼長度
     * @param int $length
     * @return Conf
     */
    public function setLength($length)
    {
        $this->length = intval($length);
        return $this;
    }

    /**
     * 獲取配置值
     * @param $name
     * @author : evalor <master@evalor.cn>
     * @return mixed
     */
    public function __get($name)
    {
        return $this->$name;
    }

    /**
     * 十六進制轉RGB
     * @param $hexColor
     * @author : evalor <master@evalor.cn>
     * @return array
     */
    function HEXToRGB($hexColor)
    {
        $color = str_replace('#', '', $hexColor);
        if (strlen($color) > 3) {
            $rgb = array(
                hexdec(substr($color, 0, 2)),
                hexdec(substr($color, 2, 2)),
                hexdec(substr($color, 4, 2))
            );
        } else {
            $color = $hexColor;
            $r = substr($color, 0, 1) . substr($color, 0, 1);
            $g = substr($color, 1, 1) . substr($color, 1, 1);
            $b = substr($color, 2, 1) . substr($color, 2, 1);
            $rgb = array(
                hexdec($r),
                hexdec($g),
                hexdec($b)
            );
        }
        return $rgb;
    }
}

配置方法

需要對驗證碼進行自定義配置可以使用上文提到的組件提供的 \EasySwoole\VerifyCode\Conf 類進行動態配置。

use EasySwoole\VerifyCode\Conf;
$Conf = new Conf();

設置字符集合

可以自定義驗證碼生成時使用的字符集合,設置后從集合中隨機選取,不設置則從 [0-9A-Za-z] 中隨機選取

$Conf->setCharset('123456ABCD');

設置背景色

設置驗證碼的背景顏色,不設置則默認使用白色,支持使用完整 HEX、縮寫 HEX 和 RGB 值設置

$Conf->setBackColor('#3A5FCD');
$Conf->setBackColor('CCC');
$Conf->setBackColor([30, 144, 255]);

設置文字顏色

設置驗證碼的文字顏色,不設置則隨機生成一個顏色,支持使用完整 HEX、縮寫 HEX 和 RGB 值設置

$Conf->setFontColor('#3A5FCD');
$Conf->setFontColor('CCC');
$Conf->setFontColor([30, 144, 255]);

設置混淆

支持兩種混淆方式,默認兩種混淆都是關閉的,需要手動開啟

// 開啟或關閉混淆曲線
$Conf->setUseCurve();
// 開啟或關閉混淆噪點
$Conf->setUseNoise();

設置字體

默認驗證碼類已經帶有 6 種字體,如果需要增加自己的字體庫來提高識別難度,或者指定使用的字體,可以進行如下設置,注意字體路徑需要使用絕對路徑,即文件的完整路徑

// 增加單個字體傳入路徑字符串
$Conf->setFonts('path/to/file.ttf');
// 增加多個字體傳入路徑的數組
$Conf->setFonts(['path/to/file1.ttf', 'path/to/file2.ttf']);
// 指定生成使用的字體文件
$Conf->setUseFont('path/to/file.ttf');

其他設置

可以指定驗證碼圖片寬高,字體大小,隨機生成的驗證碼位數等

// 設置驗證碼圖片的寬度
$Conf->setImageWidth(400);
// 設置驗證碼圖片的高度
$Conf->setImageHeight(200);
// 設置生成字體大小
$Conf->setFontSize(30);
// 設置生成驗證碼位數
$Conf->setLength(4);

鏈式調用

為了更流暢的進行設置,所有的配置項均支持鏈式調用

$Conf = new Conf();
$Conf->setUseNoise()->setUseCurve()->setFontSize(30);

可以使用上方的動態配置,將設置好的配置類傳入給驗證碼類。

$Conf = new \EasySwoole\VerifyCode\Conf();
$Conf->setFontSize(30);
$VCode = new \EasySwoole\VerifyCode\VerifyCode($Conf);

如果配置比較多,也需要全站統一驗證碼配置,可以將驗證碼的配置放入配置文件,在生成時讀取配置,驗證碼的配置類繼承自 \EasySwoole\Spl\SplBean,可以在設置好后使用配置類的 toArray 方法直接獲得配置數組,實例化驗證碼時,讀取數組重新生成 \EasySwoole\VerifyCode\Conf 類即可。

驗證碼生成

\EasySwoole\VerifyCode\VerifyCode 驗證碼操作類,如果不傳入 \EasySwoole\VerifyCode\Conf 實例,則自動實例化一個 \EasySwoole\VerifyCode\Conf 實例。

<?php
$config = new \EasySwoole\VerifyCode\Conf([
    // 以下配置均為可選配置,用戶可根據需求自行配置
    # 'charset'  => '1234567890AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz', # 設置驗證碼字符集合,默認為 數字 + 大小寫字母
    # 'useCurve'  => false, # 設置不開啟 混淆曲線,默認不開啟
    # 'useNoise'  => false, # 設置不開啟 隨機噪點,默認不開啟
    # 'useFont'   => null,  # 設置驗證碼使用的字體,默認隨機獲取內置字體
    # 'fontColor' => null,  # 設置 字體顏色,默認隨機獲取,支持使用完整 HEX,縮寫 HEX 和 RGB 值設置
    # 'backColor' => null,  # 設置 背景顏色,默認白色,支持使用完整 HEX,縮寫 HEX 和 RGB 值設置
    # 'imageL'    => null,  # 設置 驗證碼寬度,默認 162.5px
    # 'imageH'    => null,  # 設置 驗證碼高度,默認 50px
    # 'fonts'     => [],    # 設置 驗證碼可能使用的字體集合,默認組件內置支持 5 種
    # 'fontSize'  => 25,    # 設置 驗證碼字體大小,默認 25px
    # 'length'    => 4,     # 設置 驗證碼位數,默認 4 位
]);

# 使用方法單獨配置 和 上述在構造函數中配置 等價
// 設置驗證碼長度為 4 【其他配置方法請看上文 \EasySwoole\VerifyCode\Conf 類】
# $config->setLength(4);

$code = new \EasySwoole\VerifyCode\VerifyCode($config);
$code->DrawCode();// 生成驗證碼,返回一個 \EasySwoole\VerifyCode\Result 對象

驗證碼結果類

驗證碼結果類,由 VerifyCode 驗證碼操作類調用 DrawCode() 方法時創建并返回。

下面是 \EasySwoole\VerifyCode\Result 類的具體實現,可獲取創建驗證碼之后得到相關結果。

<?php
// +----------------------------------------------------------------------
// | easySwoole [ use swoole easily just like echo "hello world" ]
// +----------------------------------------------------------------------
// | WebSite: http://www.zbjtqy.com
// +----------------------------------------------------------------------
// | Welcome Join QQGroup 853946743
// +----------------------------------------------------------------------

namespace EasySwoole\VerifyCode;

/**
 * 驗證碼結果類
 * Class Result
 * @author : evalor <master@evalor.cn>
 * @package easySwoole\VerifyCode
 */
class Result
{
    private $captchaByte;  // 驗證碼圖片
    private $captchaMime;  // 驗證碼類型
    private $captchaCode;  // 驗證碼內容
    private $createTime;

    function __construct($Byte, $Code, $Mime)
    {
        $this->captchaByte = $Byte;
        $this->captchaMime = $Mime;
        $this->captchaCode = $Code;
        $this->createTime = time();
    }

    function getCreateTime():int
    {
        return $this->createTime;
    }

    function getCodeHash($code = null,$time = null)
    {
        if(!$code){
            $code = $this->captchaCode;
        }
        if(!$time){
            $time = $this->createTime;
        }
        return substr(md5($code.$time),8,16);
    }

    /**
     * 獲取驗證碼圖片
     * @author : evalor <master@evalor.cn>
     * @return mixed
     */
    function getImageByte()
    {
        return $this->captchaByte;
    }

    /**
     * 返回圖片Base64字符串
     * @author : evalor <master@evalor.cn>
     * @return string
     */
    function getImageBase64()
    {
        $base64Data = base64_encode($this->captchaByte);
        $Mime = $this->captchaMime;
        return "data:{$Mime};base64,{$base64Data}";
    }

    /**
     * 獲取驗證碼內容
     * @author : evalor <master@evalor.cn>
     * @return mixed
     */
    function getImageCode()
    {
        return $this->captchaCode;
    }

    /**
     * 獲取Mime信息
     * @author : evalor <master@evalor.cn>
     */
    function getImageMime()
    {
        return $this->captchaMime;
    }
}

使用示例

<?php
/**
 * Created by PhpStorm.
 * User: Apple
 * Date: 2018/11/12 0012
 * Time: 16:30
 */

namespace App\HttpController;
use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\VerifyCode\Conf;

class VerifyCode extends Controller
{
    function index()
    {
        // 配置驗證碼
        $config = new Conf();
        $code = new \EasySwoole\VerifyCode\VerifyCode($config);

        // 生成驗證碼
        $drawCode = $code->DrawCode();

        // 獲取生成的驗證碼內容字符串 string(4) "0rnh"
        // 可存儲起來和用戶輸入的驗證碼比對
        $codeStr = $drawCode->getImageCode();

        // 設置響應文件內容類型
        $this->response()->withHeader('Content-Type','image/png');

        // 向客戶端輸出驗證碼圖片
        $this->response()->write($drawCode->getImageByte());
    }

    function getBase64()
    {
        // 配置驗證碼
        $config = new Conf();
        $code = new \EasySwoole\VerifyCode\VerifyCode($config);

        // 生成驗證碼
        $drawCode = $code->DrawCode();

        // 獲取生成的驗證碼內容字符串 string(4) "0rnh"
        // 可存儲起來和用戶輸入的驗證碼比對
        $codeStr = $drawCode->getImageCode();

        // 向客戶端輸出驗證碼的 base64 編碼,前端可用來生成圖片
        $this->response()->write($drawCode->getImageBase64());
    }
}

訪問 http://localhost:9501/VerifyCode/index (示例請求地址) 即可看到驗證碼圖片,訪問 http://localhost:9501/VerifyCode/getBase64 (示例請求地址) 即可得到驗證碼圖片的 base64 編碼結果。

進階使用

生成二維碼圖片并返回,然后進行校驗。

首先新建一個驗證碼工具類 \App\Utility\VerifyCodeTools,內容如下所示:

<?php
/**
 * User: luffyQAQ
 * Date: 2019/9/5 15:29
 * Email: <1769360227@qq.com>
 */

namespace App\Utility;

class VerifyCodeTools
{
    const DURATION = 5 * 60;

    // 校驗驗證碼
    public static function checkVerifyCode($code, $time, $hash)
    {
        if ($time + self::DURATION < time()) {
            return false;
        }
        $code = strtolower($code);
        return self::getVerifyCodeHash($code, $time) == $hash;
    }

    // 生成驗證碼 hash 字符串
    public static function getVerifyCodeHash($code, $time)
    {
        return md5($code . $time);
    }
}

生成驗證碼及對驗證碼進行校驗。

<?php
/**
 * User: luffyQAQ
 * Date: 2019/9/5 15:29
 * Email: <1769360227@qq.com>
 */

namespace App\HttpController;

use App\Utility\VerifyCodeTools;
use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\Http\Message\Status;
use EasySwoole\Utility\Random;
use EasySwoole\VerifyCode\Conf;

class VerifyCode extends Controller
{
    static $VERIFY_CODE_TTL = 120;
    static $VERIFY_CODE_LENGTH = 4;

    // 生成驗證碼
    public function verifyCode()
    {
        // 配置驗證碼
        $config = new Conf();
        $code = new \EasySwoole\VerifyCode\VerifyCode($config);

        // 獲取隨機數(即驗證碼的具體值)
        $random = Random::character(self::$VERIFY_CODE_LENGTH, '1234567890abcdefghijklmnopqrstuvwxyz');
        // var_dump($random);    string(4) "m02t"

        // 繪制驗證碼
        $code = $code->DrawCode($random);

        // 獲取驗證碼的 base64 編碼及設置驗證碼有效時間
        $time = time();
        $result = [
            'verifyCode' => $code->getImageBase64(), // 得到繪制驗證碼的 base64 編碼字符串
            'verifyCodeTime' => $time,
        ];

        // 將驗證碼加密存儲在 Cookie 中,方便進行后續驗證。用戶也可以把驗證碼保存在 Session 或者 Redis中,方便后續驗證。
        $this->response()->setCookie("verifyCodeHash", VerifyCodeTools::getVerifyCodeHash($random, $time), $time + self::$VERIFY_CODE_TTL, '/');
        $this->response()->setCookie('verifyCodeTime', $time, $time + self::$VERIFY_CODE_TTL, '/');
        $this->writeJson(Status::CODE_OK, $result, 'success');
    }

    // 校驗驗證碼
    public function checkVerifyCode()
    {
        $code = $this->request()->getRequestParam('code');
        $verifyCodeHash = $this->request()->getRequestParam('verifyCodeHash');
        $verifyCodeTime = $this->request()->getRequestParam('verifyCodeTime');
        if (!VerifyCodeTools::checkVerifyCode($code, $verifyCodeTime, $verifyCodeHash)) {
            $this->writeJson(Status::CODE_OK, '驗證碼錯誤!', []);
            return false;
        }
        $this->writeJson(Status::CODE_OK, '驗證碼正確!', []);
    }
}

調用對應的路徑接口(即訪問 http://localhost:9501/VerifyCode/verifyCode [示例請求地址]),即可實現前臺驗證碼顯示。在 http://localhost:9501/VerifyCode/checkVerifyCode [示例請求地址] 接口中傳遞參數即可校驗驗證碼是否正確。

主站蜘蛛池模板: 频闪仪,便携式频闪仪厂家_灯管,频闪仪之父-杭州品拓电子技术有限公司 | 呕吐毒素快速检测仪-黄曲霉毒素测定仪-玉米赤霉烯酮快速检测卡-南京微测生物科技有限公司 | 直流电机调速器,直流电机控制器,直流电机调速电源-淄博诚铖创惠电子有限公司 | 无锡新源润不锈钢官网|304不锈钢平板|316L冷轧宽幅|2米卷分条开平 | 内蒙古燕雕机械设备有限公司| 上海纳美鞋业有限公司| 磨刀机厂家,全自动磨刀机-山东威海富田磨具 | 聚丙烯酰胺,聚合氯化铝,重金属捕捉剂,污泥调理剂,活性氧化铝,生石灰,反渗透阻垢剂,工业葡萄糖,硫酸铝,果壳活性炭,柱状活性炭,蜂窝活性炭,石英砂,锰砂-北京雁归来环保科技有限公司-以真诚为立足之本,以质量为生存之本,愿与海内外同仁共创双赢。雁归来人一路走来,气贯长虹,勇锐盖过怯弱,进取压倒苟安!我们紧扣时代脉搏,专注水处理、继往开来! | 永康微网站建设、永康手机网站建设、永康营销型网站建设、永康外贸网站建设、永康网站托管、永康网络公司—英汇网络 - 永康市英汇网络技术有限公司 | 深圳浪琴维修服务中心_浪琴售后保养服务网点_地址 | 江西佛像厂 江西法器厂 江西抚州东乡江弘法器有限公司 东乡江弘法器厂 佛像厂 法器厂 | 水热反应釜厂家_水热反应釜价格_水热合成反应釜批发-仪贝尔仪器 - 水热釜,水热反应釜,水热反应釜厂家,水热反应釜价格,水热反应釜型号,水热反应釜内衬,水热反应釜25ml,水热反应釜50ml,水热反应釜100ml,水热合成反应釜 | 通风方式信号控制箱_人防呼叫按钮_人防设备厂家–西安鼎兴自控工程有限公司 | 全自动冷冻研磨仪-高通量组织研磨仪厂家-「杭州宋慈智能科技」 | 智能访客系统 - 来访登记系统_微信预约系统_人员出入管理系统_访客机_人脸识别系统门禁闸机 | 双合金螺杆|注塑机螺杆|挤出机螺杆|双合金料管—东莞市精耐螺杆机械有限公司 | 意大利留学-意大利语培训-马来西亚留学【长青藤海外】 | 沼气池-沼气设备-沼气工程-山东达禹环境工程有限公司 | 氧化膜测厚仪-瓶壁测厚仪-QNIX菲尼克斯膜厚仪-深圳市时代之峰科技有限公司 | 湖南净声源环保科技有限公司是一家专业从事噪声治理和建筑声学设计生态环境综合治理服务的企业,专业从事株洲电梯隔音治理,湘潭中央空调降噪处理,衡阳邵阳冷却塔噪音治理,岳阳常德大型风机噪声隔音降噪,张家界空压机噪声治理,益阳配电房变压器噪声治理,专业郴州永州工厂企业车间噪声治理,怀化娄底专业机械设备减振降治理,武汉噪音治理隔音降噪公司,孝感噪音治理,立式球磨机的噪声控制,专业隔音降噪公司,、以及各类机械动力设备减振降噪噪声治理的公司,同时为客户提供咨询与解决方案 | 宿迁代账公司,专业会计查账,代理工商注册,商标注册,专利申请,公司注册哪家好-中方会计事务所 | 监控工程,安防监控公司,北京监控安装,北京安装监控,安装摄像头,北京监控维保,监控施工,北京监控维修,监控弱电工程,监控器安装,监控维护保养,监控工程设计,北京监控设备维修,监控报警安装,北京北方合力科技有限公司 | 无线计量仪表-电力物联网仪表-CE认证电表 | 陶瓷颗粒厂家_彩色路面_彩色陶瓷颗粒-山东顺驰道路材料有限公司 陶瓷复合钢管-专业提供江苏陶瓷钢管和陶瓷内衬复合钢管的生产厂家 | 水性漆_水性漆厂家_水性涂料加盟代理_两只璧琥全漆定制官网 | 室内儿童乐园定制_淘气堡订做_蹦床公园订制厂家-乐奇多 | 江阴市卡泰机械设备有限公司| 中国焊接协会网站—中国焊接信息网;焊接行业最权威访问量最大的专业网站:焊接信息、焊接材料,焊接机器,焊接设备,焊机,焊材,辅助设备,焊机配件,仪器仪表,电动工具,钎焊,送丝机,表面处理,自动化专机,焊锡丝,助焊剂 | 青岛熔喷过滤芯_青岛过滤器生产厂家_青岛净水滤料厂家_青岛净达过滤技术有限公司 | 山东洗地机_工业洗地机_驾驶式扫地机_扫地车厂家_鼎洁盛世官网 | 兰州沙盘模型公司_兰州模型公司_兰州沙盘模型厂家_地形沙盘制作_兰州沙盘模型制作公司 | 昆明塑料包装袋|云南塑料包装袋|昆明塑料袋厂家|云南茶叶大米蔬菜种子食品包装袋就来阮门包装有限公司 | 吉林省创智汇成包装有限公司,长春高档礼盒,长春包装盒厂家,长春精品包装盒 | 绝缘纸板-3240环氧板-酚醛布板-FR4环氧板-沈阳友达绝缘材料有限公司 | 钎头_球齿钎头_一字钎头 - 铜陵狮达矿山机械有限公司 | 河南车用尿素设备_郑州车用尿素设备_河南江宇环保车用尿素液厂家 | 一体式电磁流量计_分体式电磁流量计_卫生级电磁流量计_卫生型电磁流量计_电池供电电磁流量计_卡箍式电磁流量计_废水电磁流量计_德克森仪表(淮安)有限公司官网 | 江苏鹤心食品有限公司-茶叶_果浆果酱_固体饮料 | 在线腐蚀率仪,在线污垢热阻仪,靶式光源仪-北京同德创业科技有限公司 | 木材粉碎机-树枝秸秆粉碎机价格-双轴金属撕碎机生产线-金禾机械厂家 | 液体粉末包装机_颗粒粉剂自动包装机-上海巧慈自动化设备有限公司 |