在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問答/ 網(wǎng)絡(luò)安全問答
真難過 回答

到控制臺提交工單,讓阿里云技術(shù)團隊幫忙處理

任她鬧 回答

位移,你應(yīng)該學習一下計算機原理

例 100>>>2

100的二進制是

01100100

向右移2位后為

00011001

最后結(jié)果為25
詆毀你 回答

你認為那些是常用漢字?

  1. 把你認為是常用的漢字存儲到字典中。
  2. 去網(wǎng)上找這么個字典。
初心 回答

vscode version 1.21(目前最新):
圖片描述

其他編輯器就不太清楚了……

寫榮 回答

1.反向遍歷全局符號表
2.對符號表中的每一個元素應(yīng)用zval_call_destructor函數(shù)
3.判斷符號表中值的類型,如果是對象,則將其zval置為IS_UNDEF
4.遍歷對象棧,逐個執(zhí)行對象的析構(gòu)函數(shù)

判斷符號表中的元素的類型,如果是對象,則返回ZEND_HASH_APPLY_REMOVE,后續(xù)清理相應(yīng)的zval,有相應(yīng)的析構(gòu)函數(shù)則執(zhí)行
static int zval_call_destructor(zval *zv) /* {{{ */
{
    if (Z_TYPE_P(zv) == IS_INDIRECT) {
        zv = Z_INDIRECT_P(zv);
    }
    if (Z_TYPE_P(zv) == IS_OBJECT && Z_REFCOUNT_P(zv) == 1) {
        return ZEND_HASH_APPLY_REMOVE;
    } else {
        return ZEND_HASH_APPLY_KEEP;
    }
}

更新---------------------------------------------
在symbol的上一段,設(shè)置了符號表的析構(gòu)函數(shù)

if (CG(unclean_shutdown)) {
    EG(symbol_table).pDestructor = zend_unclean_zval_ptr_dtor;
}

在反向遍歷符號表的過程中,如果引用計數(shù)減為0,對其存儲的zval執(zhí)行析構(gòu)函數(shù)
這個函數(shù)又調(diào)用了zend_objects_store_del
功能是先執(zhí)行對象的析構(gòu)函數(shù),然后釋放對象占用的內(nèi)存

拼未來 回答

目前我是這么解決的。要是有更好的方案希望能告知。

  1. 文件都放到statics下面。
  2. index.template.html引入css

    <link rel="stylesheet" type="text/css" href="statics/css/iconfont.css">
  3. <q-icon class="iconfont" name="icon-name" />
舊時光 回答

go get -v看看哪個資源沒下載下來,再把哪個資源加進代理

裸橙 回答

大致流程如下:

視圖層

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<form action="/test" method="post">
    {:token()}
    username:
    <input type="text" name="username">
    email:
    <input type="email" name="email">
    <input type="submit" value="submit">
</form>
</body>
</html>

驗證器User

<?php

namespace app\index\validate;

use think\Validate;

class User extends Validate
{
    protected $rule = [
        'username'  => 'require|max:25|token',
        'email'     => 'email',
    ];
}

Controller層

<?php

namespace app\index\controller;

use think\Controller;
use think\Request;

class Index extends Controller
{
    public function index()
    {
        return view('index');
    }

    public function test(Request $request)
    {
        $result = $this->validate(
            [
                '__token__' => $request->param('__token__'),
                'username'  => $request->param('username'),
                'email'     => $request->param('email'),
            ],
            'app\index\validate\User'
        );
        if ($result !== true) {
            dump($result);
        } else {
            dump($request->param());
        }
    }
}
夢若殤 回答
 fetch:
      src: /tmp/{{ inventory_hostname }}.txt
      dest: /tmp/ss-{{ inventory_hostname }}
      flat: yes
//fetch 是調(diào)用這個模塊
 fetch:
 //src 是遠程服務(wù)器的路徑,這里的 inventory_hostname 就是填在 /etc/ansible/hosts 文件里面的內(nèi)容。比如說 hosts 文件你填的是 192.168.1.3
// 那這里的 {{inventory_hostname}}.txt 就是 192.168.1.3.txt
      src: /tmp/{{ inventory_hostname }}.txt
      dest: /tmp/ss-{{ inventory_hostname }}
      flat: yes
執(zhí)念 回答

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

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

這里說明一下繼承關(guān)系:

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數(shù)組中
    static::setInstance($this);

    $this->state = self::STATE_BEGIN;

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

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

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

上面方法中 Component::__construct($config) 會調(diào)用 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' => [...]] 從哪來,若不關(guān)心可以直接看 第二步。

  • 先看 $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])) {
            // 若自定義組件中沒有設(shè)置該核心組件配置信息,直接使用核心組件默認配置
            $config['components'][$id] = $component;
        } elseif (is_array($config['components'][$id]) && !isset($config['components'][$id]['class'])) {
            // 若自定義組件有設(shè)置該核心組件配置信息,但是沒有設(shè)置 'class'屬性,則添加該class屬性
            $config['components'][$id]['class'] = $component['class'];
        }
    }
}

/**
 * Returns the configuration of core application components.
 * 返回核心應(yīng)用組件的配置
 * @see set()
 */
public function coreComponents()
{
    return [
        // 日志分配器組件
        'log' => ['class' => 'yii\log\Dispatcher'],
        
        //others...
    ];
}
  • 經(jīng)過 $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)
/**
 * 為實例不存在的屬性賦值時調(diào)用
 *
 * Do not call this method directly as it is a PHP magic method that
 * will be implicitly called when executing `$object->property = $value;`.
 * 這個是PHP的魔術(shù)方法,會在執(zhí)行 `$object->property = $value;` 的時候自動調(diào)用。
 */
public function __set($name, $value)
{
    // setter函數(shù)的函數(shù)名
    // 由于php中方法名稱不區(qū)分大小寫,所以setproperty() 等價于 setProperty()
    $setter = 'set' . $name;
    if (method_exists($this, $setter)) {
        // 調(diào)用setter函數(shù)
        $this->$setter($value);
    } elseif (method_exists($this, 'get' . $name)) {
        // 如果只有g(shù)etter沒有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',
    ];
]

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

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

這樣便有了問題中的

["_modules":"yii\base\Module":private]=>
    array(3) {
        ["debug"]=> object(yii\debug\Module)#33 (28) {
            ......
        }
        ["gii"]=> object(yii\gii\Module)#113 (21) {
            ......
        }
        ...
    }
  • 同樣的道理,當遍歷到:
$app->components =  [
    'log'   => [
        'class' => 'yii\\log\\Dispatcher',
    ],
]
  • 這里會調(diào)用 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)) {
        // 定義如果是個數(shù)組,要確保數(shù)組中具有 class 元素
        // a configuration array
        if (isset($definition['class'])) {
            // 定義的過程,只是寫入了 $_definitions 數(shù)組
            $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));
    }
}

這樣便有了問題中的

["_definitions":"yii\di\ServiceLocator":private]=>
        array(24) {
            ["errorHandler"]=> .....
            ["request"]=> ......
            ["log"]=> ......
            ......
        }
呆萌傻 回答

你都用mb_detect_encoding了,為啥不用mb_convert_encoding呢?

朕略傻 回答

我一般選擇用命令的方式設(shè)置,并且將這兩個文件夾配置在其他盤符防止權(quán)限問題

npm config set prefix "D:\nodejs\node_global" //設(shè)置全局包目錄
npm config set cache "D:\nodejs\node_cache" //設(shè)置緩存目錄
你的瞳 回答

在查看對比這個PNG解壓源碼與題主的操作流程,發(fā)現(xiàn)問題在于少了undo_filter這一步。

在源碼png.py中

...
            while len(a) >= rb + 1:
                filter_type = a[0]
                scanline = a[1:rb+1]
                del a[:rb+1]
                recon = self.undo_filter(filter_type, scanline, recon)
...

可以看出,每行的第一個字節(jié)是代表filter_type, 不是行號?。ㄒ驗橐膊恍枰。?br>00eb6100ff22ac38ffea68a2ff0122ac38ffc8bc6a0001f95e00
這里的00是沒有用濾波器,01是指用了減法濾波器

減法濾波器的定義:

 def sub():
            """Undo sub filter."""

            ai = 0
            # Loops starts at index fu.  Observe that the initial part
            # of the result is already filled in correctly with
            # scanline.
            for i in range(fu, len(result)):
                x = scanline[i]
                a = result[ai]
                result[i] = (x + a) & 0xff
                ai += 1

c8bc6a00+22ac38ff=ea68a2ff (注意忽略字節(jié)進位,即 &ff的作用)

悶油瓶 回答

樓主解決了碼,我也遇到了

雅痞 回答

ali-oss庫 應(yīng)該是跑在后端的(不是跑在瀏覽器里的),前端不能直接調(diào)用

替身 回答

更改下語言為英文,你應(yīng)該是中文或者其他的,或者是安裝一款字體,否則顯示的確會不正常

你好胸 回答

按你的使用場景,推送數(shù)據(jù)必須得在數(shù)據(jù)創(chuàng)建事務(wù)成功之后執(zhí)行,這里必須有個先后。你可以將推送這個操作異步執(zhí)行,消息隊列有一搬有ack機制,確保消息沒丟失。這時候監(jiān)聽消息隊列的程序會執(zhí)行推送,如果推送成功做標記。如果推送失敗也標記記錄時間,也可以推到另一個消息隊列約定多少分鐘重試。實在不行就徹底標記失敗,或者回滾之前創(chuàng)建的數(shù)據(jù)。這個才是最終一致性。
如果是并行的操作,就得使用消息隊列的confirm機制了。

綰青絲 回答

改用 FileZilla 更加方便

萌二代 回答

https://s3.pstatp.com/toutiao...
第818行:e = TAC.sign(userInfo.id + '' + c.params.max_behot_time)
第823行:_signature: e