鍍金池/ 問答/ PHP問答
使勁操 回答

我理解的是,只要在用戶打開頁面時渲染他未讀的消息條數進行提示即可。

爛人 回答

存儲過程的優(yōu)點主要包括以下幾點:

第一點,性能提高。這是相對于不適用存儲過程來說的,因為存儲過程在創(chuàng)建的時候就編譯好了,而后每次調用都不會再次編譯,這相對于傳統(tǒng)的SQL語句中每次調用都需要編譯的情況來說,性能提高了何止一點兩點。

第二點,重用性強。存儲過程使用名字即可使用,也就是傳說中的“一次編寫,隨便調用”。這樣不僅提高了重用性,還減少了出錯的幾率,也會加快開發(fā)速度,可以說是一件非常好的事情。

第三點,減少網絡流量。這一點對于小數據量的時候一般體現不出來,那么當數據量較大的時候,我們會發(fā)現由于使用存儲過程比使用SQL語句會使用更少的字節(jié)數,因此它會降低傳輸的數據量。

第四點,安全性提高。由于存儲過程也可以使用權限控制,而且參數化的存儲過程可以防止SQL注入攻擊,也在一定程度上保證了安全性。

第五點,靈活性增強。由于存儲過程可以使用流程控制語句來編寫,導致它有著很強的靈活性,可以根據實際情況來執(zhí)行不同的SQL語句,而不是只能單純的簡單的執(zhí)行命令。而且該存儲過程還可以修改其邏輯而其他部分不用改變,也就是說,我們的表的結構改變了,我們只需要修改相應的存儲過程即可,我們的Java或者PHP等程序不需要改變。

第六點,當業(yè)務復雜的時候,存儲過程會減少工作量,為什么呢,原因很簡單,如果我們不適用存儲過程,那么就會導致我們先從數據庫中取出來數據,然后經過計算,再放入到數據庫中,這個開銷還是蠻大的,這中間的開銷包括我們的Java或者PHP程序連接數據庫獲取結果集等若干操作,如果我們使用了存儲過程,那么就沒有那么多事了,直接在mysql內就搞定了。

缺點:
第一點,工作量加大。這里并不是說我們把程序該做的事讓mysql去做不好,而是mysql本身并沒有很像樣的IDE來開發(fā)我們的存儲過程,我們很多時候還是需要手寫,這樣就會比較麻煩,而且存儲過程的調試也是一個問題,沒有很像樣的調試工具。

第二點,優(yōu)勢不明顯。運行速度上,對于大多數的語句緩存來說,編譯sql的時間開銷并不是很大,但是執(zhí)行存儲過程還需要檢查權限等一些其他開銷,所以,對于很簡單的sql,存儲過程并沒有很大優(yōu)勢。

第三點,贅余功能。對web程序來說,我們連接數據庫的用戶往往就是同一個,不需要太多的安全機制,所以,對于安全上的檢測看上去很好,實際上優(yōu)點多余。

第四點,小型程序完全無用。對于小型web應用來說,它的使用價值就更小了,反而會拖累開發(fā)進度。

第五點,對于運維上。當我們的程序要更換數據庫的時候,它的移植性相對于不適用存儲過程要復雜一些,對于維護上,由于是在db端,因此比server端的程序更好維護一些。

萢萢糖 回答

先計算好一批偽隨機值放在Redis中,調用來了之后直接從Redis中返回?

傻丟丟 回答

return當前函數就終止了,你可以把上傳信息存到變量中。foreach之后再調用唄。return當前函數就終止了,你可以把上傳信息存到變量中。foreach之后再調用唄。

涼汐 回答

你好,請問你的問題是如何解決的呢,我實測美團api上傳圖片并不能用文件流成功上傳啊。

念初 回答

...
你 split 之后 數組變?yōu)檫@樣
他是 這樣分的 var arr = ['李明:60', '小花:59']
for 循環(huán) 不是說

arr[0].slice(3) => 60
arr[1].slice(3) => 59
我甘愿 回答

你這個問題問的就有點矛盾,你說怎么使用php提取關鍵字(公司簡稱)。這句話,php怎么知道你的字符串中哪個才是關鍵字(在沒有關鍵詞庫的情況下)?

感覺你的問題應該是php怎么提取字符串中出現頻率最多的子串,感覺像是這樣。
我們有了這個思路之后,再深一步探討一下,我有個思路:

  1. 把你某個時間段內,用戶提交的所有title集合起來放在一個字符串中,然后提取出出現頻率最高的子串
  2. 把子串出現的頻率由高到低,都列出來,人工過濾,哪些才是所需要的關鍵字,形成一個關鍵字庫
  3. 下一次再有提交title的時候,先與關鍵字庫進行匹配,如果沒有匹配上,除了插入到原有的投訴庫中,再把單獨的title插入到一個臨時的表里,一天結束,定時進行一個關鍵詞提取的算法(重復1),然后第二天,人工再來過濾

以上。

安若晴 回答
暫時沒有看到哪兒有,可以自己去實 @yuanxiaowa

我先引用一下,然后寫一下我個人的看法,這種需求我覺得是有問題的,基本上沒有人會這么去操作,我建議引入sass工具來管理樣式。另外的話,可以考慮學習最新的前端基于數據來思考的框架,比如react,bootstrap是UI框架。

妖妖 回答

你想讓php渲染模板,那么你不能用vue-cli生成項目,你只能用<script>引入vue,這種場景下,var a = {$user};php就可以直接渲染好啊,然后你js調用你這個變量就可以了啊

失心人 回答

你這是正則寫錯了,'/src="(.+.(png|jpg))"+?/'其中只有第一個,也就是外面的捕獲組使用了非貪婪模式,里面的'.+'沒使用非貪婪模式,改成'.+?'應該就可以了。(這個點不睡也是沒誰了。。)

愛礙唉 回答

我會寫兩張表 ,一張表是地址和地鐵都放在一起,然后做個type區(qū)分,并記錄他們的經緯度,另外一個表就是存店鋪圖片,這樣可以根據店鋪的經緯度找出附近type是地鐵的所有地鐵站

默念 回答

應該是./install-dependencies.sh
或者sh install-dependencies.sh

你不加./的話,shell會去$PATH中找這個命令,而當前目錄不在$PATH下。加上./則會是執(zhí)行當前目錄下的腳本

大濕胸 回答

首先,你的 $config 數組中一定包含以下元素:

$config = [
    //others
    'modules' => [
        'debug' => [
            'class' => 'yii\debug\Module',
        ], 
        'gii'   => [
            'class' => 'yii\gii\Module',
        ];
    ],
    //others
]

這里說明一下繼承關系:

class yii\base\Application extends yii\base\Module

class yii\base\Module extends yii\di\ServiceLocator

class yii\di\ServiceLocator extends yii\base\Component

class yii\base\Component extends yii\base\Object

  • yiibaseApplication::__construct() 方法注解
public function __construct($config = [])
{
    Yii::$app = $this;
    //將\yii\base\Application中的所有的屬性和方法交給Yii::$app->loadedModules數組中
    static::setInstance($this);

    $this->state = self::STATE_BEGIN;

    //加載配置文件的框架信息 如:設置別名,設置框架路徑等等最為重要的是給加載默認組件
    $this->preInit($config);

    //加載配置文件中的異常組件
    $this->registerErrorHandler($config);

    // 調用父類的 __construct。
    // 由于Component類并沒有__construct函數
    // 這里實際調用的是 `yii\base\Object__construct($config)`
    Component::__construct($config);
}

上面方法中 Component::__construct($config) 會調用 yii\base\Object::__construct() 方法

  • yiibaseObject::__construct() 方法注解
public function __construct($config = [])
{
    if (!empty($config)) {
        // 將配置文件里面的所有配置信息賦值給Object。
        // 由于Object是大部分類的基類,
        // 實際上也就是有配置信息賦值給了yii\web\Application的對象
        Yii::configure($this, $config);
    }
    $this->init();
}

一、下面只是為了說明 'components' => [ 'log' => [...]] 從哪來,若不關心可以直接看 第二步。

  • 先看 $this->preInit($config);,即 yii\base\Application::preInit(&$config)
public function preInit(&$config)
{
    //others...
    
    // merge core components with custom components
    // 合并核心組件和自定義組件
    foreach ($this->coreComponents() as $id => $component) {
        if (!isset($config['components'][$id])) {
            // 若自定義組件中沒有設置該核心組件配置信息,直接使用核心組件默認配置
            $config['components'][$id] = $component;
        } elseif (is_array($config['components'][$id]) && !isset($config['components'][$id]['class'])) {
            // 若自定義組件有設置該核心組件配置信息,但是沒有設置 'class'屬性,則添加該class屬性
            $config['components'][$id]['class'] = $component['class'];
        }
    }
}

/**
 * Returns the configuration of core application components.
 * 返回核心應用組件的配置
 * @see set()
 */
public function coreComponents()
{
    return [
        // 日志分配器組件
        'log' => ['class' => 'yii\log\Dispatcher'],
        
        //others...
    ];
}
  • 經過 $this->preInit($config);, 我們得到的 $config
$config = [
    'modules' => [
        'debug' => [
            'class' => 'yii\debug\Module',
        ], 
        'gii'   => [
            'class' => 'yii\gii\Module',
        ];
    ],
    'components' => [
        'log'   => [
            'class' => 'yii\\log\\Dispatcher',
        ],
        
        //others...
    ]
    //others...
]


上面只是為了說明 'components' => [ 'log' => [...]] 從哪來

二、重點在這里

  • yii\base\Object::__construct($config = []) 中的 Yii::configure($this, $config);
public static function configure($object, $properties)
{
    // 只是遍歷配置信息,賦值給當前對象
    foreach ($properties as $name => $value) {
        $object->$name = $value;
    }
    return $object;
}
  • 這里我們要配合 yii\base\Object::__set($name, $value)
/**
 * 為實例不存在的屬性賦值時調用
 *
 * Do not call this method directly as it is a PHP magic method that
 * will be implicitly called when executing `$object->property = $value;`.
 * 這個是PHP的魔術方法,會在執(zhí)行 `$object->property = $value;` 的時候自動調用。
 */
public function __set($name, $value)
{
    // setter函數的函數名
    // 由于php中方法名稱不區(qū)分大小寫,所以setproperty() 等價于 setProperty()
    $setter = 'set' . $name;
    if (method_exists($this, $setter)) {
        // 調用setter函數
        $this->$setter($value);
    } elseif (method_exists($this, 'get' . $name)) {
        // 如果只有getter沒有setter 則為只讀屬性
        throw new InvalidCallException('Setting read-only property: ' . get_class($this) . '::' . $name);
    } else {
        throw new UnknownPropertyException('Setting unknown property: ' . get_class($this) . '::' . $name);
    }
}

當前情景下的 $object 我們可以認為是 yii\base\Application 的對象 $app

  • 當遍歷到:
$app->modules =  [
    'debug' => [
        'class' => 'yii\debug\Module',
    ], 
    'gii'   => [
        'class' => 'yii\gii\Module',
    ];
]

這里會調用 yii\base\Module::setModules($modules) 方法

public function setModules($modules)
{
    foreach ($modules as $id => $module) {
        $this->_modules[$id] = $module;
    }
}

這樣便有了問題中的

private "_modules" (yiibasemodule)=>
       array (size=3)
            'backend'  =>....
            'debug' =>...
            'gii'=>...
  • 同樣的道理,當遍歷到:
$app->components =  [
    'log'   => [
        'class' => 'yii\\log\\Dispatcher',
    ],
]
  • 這里會調用 yii\di\ServiceLocator::setComponents($components) 方法
public function setComponents($components)
{
    foreach ($components as $id => $component) {
        $this->set($id, $component);
    }
}

public function set($id, $definition)
{
    // others ...

    if (is_object($definition) || is_callable($definition, true)) {
        // an object, a class name, or a PHP callable
        $this->_definitions[$id] = $definition;
    } elseif (is_array($definition)) {
        // 定義如果是個數組,要確保數組中具有 class 元素
        // a configuration array
        if (isset($definition['class'])) {
            // 定義的過程,只是寫入了 $_definitions 數組
            $this->_definitions[$id] = $definition;
        } else {
            throw new InvalidConfigException("The configuration for the \"$id\" component must contain a \"class\" element.");
        }
    } else {
        throw new InvalidConfigException("Unexpected configuration type for the \"$id\" component: " . gettype($definition));
    }
}

這樣便有了問題中的

private  "_definitions"(yiidiservicelocator)=>
        array  (size=7)
           ...
           'log'=>...
           ...
舊言 回答

1.下載https://greenindex.dynamic-dn...
2.在函數deAES中將返回的字符串輸出到控制臺中,這些字符串就是真正運行的代碼.
3.然后代入他下面寫的運行代碼,在中間調試.一步步調試 最多半天就能知道他干嘛的了.

舊時光 回答

安裝PHP7版本的mysql擴展即可,mac下擴展的擴展名以.so結尾,dll是win下的擴展

小眼睛 回答

對于題主的應用場景,我想有兩種思路供題主參考。
1.就像題主所說的,在登錄的時候做會員狀態(tài)檢查,并根據情況修改會員狀態(tài)。
優(yōu)點:不需要開啟守護進程或定時任務,實現簡單。
缺點
每次會員登錄都要做一次狀態(tài)檢查會延長頁面加載時間
會員等級信息修改滯后??赡茉斐蓵T已經過了一年期限,但由于會員沒有登錄,所以等級信息一直沒有修改的情況

2.寫一個腳本實時監(jiān)控
優(yōu)點:可以實時修改會員狀態(tài)信息,不需要登錄后檢查從而加快頁面打開速度
缺點:占用服務器資源(如果用戶量很大的話,運行這個腳本會很占用服務器資源)

薄荷綠 回答

1、按 F12 查看網絡請求返回結果
2、TP 框架應該有返回 json 數據的辦法
3、前后端接口通信返回 布爾值 不靠譜,通過返回 code 前端去判斷請求成功還是失敗