鍍金池/ 問答/ PHP問答
陪妳哭 回答

你先點開wamp,看具體是哪個服務沒有啟動[php,apache,mysql],然后在相對應的服務里面找到錯誤日志,看報錯信息。

抱緊我 回答

墻內(nèi)找了很長時間都沒找到,最終還是在google里找到了答案。
文檔的描述不是很清楚,其實問題在于使用javascript 接入api 認證方式應該使用默認的用戶認證 和 web中間件,而不是用passport提供的登錄方式以及 auth:api中間件

  1. 使用laravel默認的用戶認證,

    php artisan make:auth
  2. 配置文件 config/auth.php 中授權看守器 guards 的 api 的 driver 選項改為 passport(估計不改也行,沒有試過,使用javascript接入api的目的是多套應用程序公用一套api,所以還是改了)

    'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
    
        'api' => [
            'driver' => 'passport',
            'provider' => 'users',
        ],
    ],
  3. 將 CreateFreshApiToken 中間件添加到 web 中間件組

        protected $middlewareGroups = [
            'web' => [
                ...
                \Laravel\Passport\Http\Middleware\CreateFreshApiToken::class,
            ],
    
            'api' => [
                'throttle:60,1',
                'bindings',
            ],
        ];
  4. 訪問 域名/login 登錄
    圖片描述
  5. 登錄成功之后打開控制臺發(fā)現(xiàn)cookie中會有l(wèi)aravel_token
    圖片描述
  6. 請求其他接口Header中需要攜帶該cookie 與 X-CSRF-TOKEN,默認axios幫我做了這些,下面是postman的示例
    圖片描述
脾氣硬 回答
http://localhost/play?make=movie&id=fqvnYxH4QnH1UB.html

http://localhost/play?movie/fqvnYxH4QnH1UB.html
RewriteRule ^\/play\?([^\/]+)\/([^\/]+)\.html$ /play?make=$1&id=$2
            
空白格 回答

沒有遇到過同樣的問題

解決方案之一的話,可以直接在表單里把文件名一起傳遞過去

六扇門 回答

你選擇圖片插入的時候,圖片已經(jīng)通過接口上傳了,后臺返回給你圖片的路徑,就是你圖片中的/img/bVbcfKU

萌小萌 回答

經(jīng)過一個下午的折騰,上周五還是發(fā)現(xiàn)出現(xiàn)該異常情況的原因。概括來說還是中文轉編碼的問題,即utf-8轉gbk出現(xiàn)的小部分行缺少空格或者雙引號的問題。
出現(xiàn)問題的原因:
在進行導出的過程中,接收其他程序傳過來的數(shù)組參數(shù),均為utf-8編碼,我這邊在調(diào)用fwrite或者fputcvs寫入文件的過程中并沒有進行 iconv("UTF-8", "GB2312//IGNORE", $header),而是將文件保存在了 export目錄下,然后由vuejs做的后臺調(diào)用位于同application下的一個共用類的 export方法,該方法是這樣的:

public function export()
{
    $file = \Request::get('file');
    header('Content-Type: application/vnd.ms-excel');
    header('Content-Disposition: attachment;filename=export.csv');
    header('Cache-Control: max-age=0');
    $contents = file_get_contents(\Env::get('runtime_path') . '/export/' . $file);
    echo iconv("UTF-8", "GB2312//IGNORE", $contents);
    @unlink(RUNTIME_PATH . '/export/' . $filename);
    exit;
}

問題就出在 echo iconv("UTF-8", "GB2312//IGNORE", $contents); 這句代碼上面,這里看到是對傳入的整個文件進行轉編碼的,這里未進行測試到底多少行的數(shù)據(jù)會出現(xiàn)缺少逗號引號的問題。
最終的解決思路是,把共用類中對整個文件的轉編碼放到寫入方法中,逐條轉編碼就解決了該問題。

更改后的代碼:

public static function createCsv($data, $header = [], $filename = '')
{
    // 參數(shù)判斷
    $data = is_object($data) ? $data->toArray() : $data;
    $header = is_array($header) ? $header : [];
    $filename = (1 > strlen(trim($filename))) ? 'csv-' : trim($filename);
    if (empty($data)) {
        return false;
    }

    // 文件名/目錄
    $filename = $filename . date("YmdHis", time()) . rand(1000, 9999) . ".csv";
    $dir = Env::get('runtime_path') . '/export/';
    if (!is_dir($dir) && !mkdir($dir)) {
        return false;
    }

    // 打開文件指針資源
    $handle = fopen($dir . $filename, 'w+');
    if (!$handle) {
        return false;
    }

    // 寫入文件header頭
    if (!empty($header)) {
        foreach ($header as $key => $item) {
            $header[$key] = iconv("UTF-8", "GB2312//IGNORE", $item);
        }
        $res = fputcsv($handle, $header);
        if (!$res) {
            return false;
        }
    }

    // 判斷header是索引數(shù)組還是關聯(lián)數(shù)組
    $is_assoc = array_keys($header) !== range(0, count($header) - 1);

    // 寫入文件內(nèi)容
    $frequency = 0; // 頻率
    $limit = 100000;
    foreach ($data as $datum) {
        $frequency++;
        if ($limit == $frequency) {
            // 刷新輸出buffer
            ob_flush();
            flush();
            $frequency = 0;
        }
        // 如果是關聯(lián)數(shù)組,則獲取內(nèi)容中和頭部key相對應的值
        if ($is_assoc) {
            $csv = "";
            foreach(array_keys($header) as $item) {
                $datum[$item] = iconv("UTF-8", "GB2312//IGNORE", $item);
                $val = str_replace('"', '""', $datum[$item]); // 將單個雙引號替換為兩個雙引號
                $csv .= '"' . $val . '",'; // 為每個字符增加雙引號,并添加逗號分割符
            }
            $csv = substr($csv, 0, -1); // 去掉每行最后一個逗號
            $csv .= "\n"; // 添加換行符
            $res = @fwrite($handle, $csv);
        } else {
            $res = fputcsv($handle, $datum);
        }

        if (!$res) {
            return false;
        }
    }

    // 關閉指針資源
    fclose($handle);
    return Url::build('erp/Common/export', 'file=' . $filename);
}


public function export()
{
    $file = \Request::get('file');
    header('Content-Type: application/vnd.ms-excel');
    header('Content-Disposition: attachment;filename=export.csv');
    header('Cache-Control: max-age=0');
    $contents = file_get_contents(\Env::get('runtime_path') . '/export/' . $file);
    echo $contents;
    exit;
}

調(diào)用步驟:

先調(diào)用createCsv生成文件,再調(diào)用export下載。

———————————————————————分割線——————————————————————

另外一種解決思路:

csv文件直接存儲 UTF-8 編碼:
即不需要進行 iconv 轉編碼,這樣會有個小問題就是MacOS中的Excel無法自動識utf-8編碼,中文會出現(xiàn)亂碼的情況。

原因:

Excel在讀取csv的時候是通過讀取文件頭上的bom來識別編碼的,如果文件頭無bom信息,則默認按照unicode編碼讀取。(這個bom是微軟自己定義的一種文件頭部協(xié)定,顧名思義存儲在文件頭部,存儲內(nèi)容就是標識文件編碼的信息。)而我們生成csv的平臺不一定遵循微軟的bom協(xié)議,導致如果輸出非unicode編碼的csv文件(例如utf-8),并且沒有生成bom信息的話,Excel自動按照unicode編碼讀取,就會出現(xiàn)亂碼問題了。

作者:李蛟 鏈接:https://www.zhihu.com/questio...
來源:知乎 著作權歸作者所有。商業(yè)轉載請聯(lián)系作者獲得授權,非商業(yè)轉載請注明出處。

根據(jù)知乎查到的答案,原來是這里未遵循微軟的bom協(xié)議。原因找到了,解決方案就能出了。

解決方法:
fopen 方法下寫入bom頭,這里簡單寫一下步驟

function createCsv($filename, $header, $data) {
    $handle = fopen($filename, 'w+');
    // 添加BOM,標識為UTF-8格式
    fwrite($handle, chr(0xEF).chr(0xBB).chr(0xBF));
    // 寫入頭部
    fputcsv($handle, $header);
    // 逐行寫入內(nèi)容
    foreach ($data as $datum) {
        fputcsv($handle, $datum);
    }
    // 關閉指針資源
    fclose($handle);
}

另外再補充一下 Bom 簡介

  • 在UCS 編碼中有一個叫做”ZERO WIDTH NO-BREAKSPACE”的字符,它的編碼是FEFF。
  • FFFE在UCS中是不存在的字符,所以不應該出現(xiàn)在實際傳輸中。
  • UCS規(guī)范建議我們在傳輸字節(jié)流前,先傳輸字符”ZERO WIDTH NO-BREAK SPACE”。
  • 這樣如果接收者收到FEFF,就表明這個字節(jié)流是Big-Endian的;
  • 如果收到FFFE,就表明這個字節(jié)流是Little-Endian的。
  • 因此字符”ZERO WIDTH NO-BREAK SPACE”又被稱作BOM。
  • UTF-8不需要BOM來表明字節(jié)順序,但可以用BOM來表明編碼方式。
  • 字符”ZERO WIDTH NO-BREAK SPACE”的UTF-8編碼是EF BB BF。
  • 所以如果接收者收到以EF BB BF開頭的字節(jié)流,就知道這是UTF-8編碼了。
  • Windows就是使用BOM來標記文本文件的編碼方式的。

該內(nèi)容來自 http://blog.csdn.net/chaozhi_... 這篇博客

疚幼 回答

https://prettier.io/playgroun...

可以搜索 prettier 這個插件,上面試提供的在線測試網(wǎng)址

凝雅 回答

靜態(tài)編譯刪除不了,動態(tài)的去 ext 目錄覆蓋就行

任她鬧 回答

這應該是一個變量污染的bug
我猜測timezone是私有屬性
所以有個get方法public DateTimeZone getTimezone ( void )
var_dumpprint_r之后timezonepublic屬性了

https://bugs.php.net/bug.php?...

淚染裳 回答

可以參考 阿里云提供的文檔 https://help.aliyun.com/knowl...

也可以是試試
http://blog.163.com/liwei1987...

厭惡我 回答

你可以用alarmmanager+pendingintend來實現(xiàn)該功能,當定時結束時發(fā)送一個廣播?;蛘吣憧梢栽谀愕暮笈_播放服務中自己開啟一個線程,來代替alarmmanager

囍槑 回答

.env 配置文件里面不是 DB_DATABASE=test 嗎?

浪婳 回答

@Perla
clipboard.png 如這圖
搜鯊魚 顯示訂單號在加下面的商品

心癌 回答

我的安裝流程:
下載:https://github.com/swoole/swo...
生產(chǎn)configure腳本(建立拓展骨架):phpize
配置:configure –witch-php-config=xxx
安裝:make && make install
配置php.ini:extension=swoole.so

是否漏了某個步驟?

墨沫 回答

file_get_contents()是專門用來獲取文件數(shù)據(jù)流的,要么拿到,要么報錯,你的目的如果只是想要請求,試試curl,可以設置請求時長

雨蝶 回答
但是這種情況如果多了會不會造成大量廢棄的接口同時在生產(chǎn)環(huán)境

首先這里其實是3件事,一件叫兼容以前的版本,一件叫新增一個功能,一件叫廢棄之前的版本。

  1. 如果你要兼容,那不叫廢棄的接口,當然這里不符合題主需求。
  2. 樓主這里其實是新增一個功能(盡管他跟原有的功能可能很相似),直接新加就行了。
  3. 而如果你要廢棄,則可以屏蔽掉舊版本代碼(一般是幾次迭代之后,有足夠的警告說明你要廢棄此接口,而通常還不是很好用)

這是比較沒有辦法的事情。主要寫好文檔,每個系統(tǒng)版本的文檔里寫清楚接口的支持和廢棄。