Month: 2 月 2020

php处理CSV文件乱码之mb_detect_encoding

2020年2月29日 PHP

PHP在处理csv在数据导入导出方面,要比.xls高效很多。

实现一上传csv文件导入功能时,遇到上传文件编码不是UTF-8的情况,导致读取的数据乱码。如果csv文件是utf-8文件,可能导致excel不能正常识别,所以就遇到的问题。

搜索后发现mb_detect_encoding可以检测字符串编码,不一定百分百识别,至少能满足我的需求

代码片断:

            $tmp_row = array();
            foreach ($csv_val as $k => $v) {
                $row_value = ltrim($row[$k], '`');
                $encode = mb_detect_encoding($row_value, array("UTF-8", "GB2312", "CP936", "GBK"));
                if( $encode!="UTF-8" ){
                    $tmp_row[$v] = trim(iconv($encode,'UTF-8', $row_value));
                }else{
                    $tmp_row[$v] = trim($row_value);
                }
            }
            $data[] = $tmp_row;

debian9手动安装nodejs和npm

2020年2月27日 nodejs

1. nodejs官网,找linux64版本,

#wget https://nodejs.org/dist/v12.16.1/node-v12.16.1-linux-x64.tar.xz

2.解压下载后的压缩文件并拷贝到opt

#tar xvf node-v12.16.1-linux-x64.tar.xz

#mv xvf node-v12.16.1-linux-x64/ /opt/

3.添加到全局path里面

在/etc/profile中添加环境变量(在export PATH的上一行添加就可以)

#vi /etc/profile

PATH=$PATH:/opt/node-v12.16.1-linux-x64/bin

使profile立即生效

#source /etc/profile

4.检查node和npm 版本

#node -v

#npm -v

php artisan config:cache使env函数读取环境变量为null

2020年2月8日 未分类

在 Laravel 项目中,如果执行了

php artisan config:cache

命令把配置文件缓存起来后,在 Tinker 中(Tinker 是 Laravel 自带的一个交互式命令行界面),使用

env

函数读取环境变量的值为

null

,只有执行

php artisan config:clear

清除配置缓存后就可以读取了

在 Laravel 中,如果执行

php aritisan config:cache

命令,Laravel 将会把 app/config 目录下的所有配置文件“编译”整合成一个缓存配置文件到  bootstrap/cache/config.php,每个配置文件都可以通过

env

函数读取环境变量,这里是可以读取的。但是一旦有了这个缓存配置文件,在其他地方使用

env

函数是读取不到环境变量的,所以返回

null

.

如果存在缓存配置文件,就不会去设置环境变量了,配置都读缓存配置文件,而不会再读环境变量了。

因此,在配置文件即 app/config 目录下的其他地方,读取配置不要使用

env

函数去读环境变量,这样你一旦执行

 php artisan config:cache

之后,

env

函数就不起作用了。所有要用到的环境变量,在 app/config 目录的配置文件中通过 env 读取,其他地方要用到环境变量的都统一读配置文件而不是使用

env

函数读取。