记录wubin.work开发中遇到的问题
第一次全栈开发难免会遇到很多问题,在这里特意记录下,随时想到随时更新。
关于环境的问题
开发环境与生产环境
开发的时候没有考虑到这个问题,导致线上、线下的环境不统一,引起了很多调试的问题,在开发的时候,最好设置一个变量,只修改一下,即可切换开发/生产的环境。
对于静态资源路径
本地开发静态资源获取的都很快,但是到线上就受到带宽等影响,问题被无限放大,特别是使用腾讯的1M宽带,JS会卡的怀疑人生,这时候我使用了gitee进行静态资源的托管,一些预览图使用了图床。那么修改静态资源路径的时候麻烦多多,特别是<img> 所以应设置一个静态资源路径的变量,这样在更换的时候,只要更换变量就行。如
$base = $is_local ? '..' : 'https://gitee....';
img src="{$base}/img/xx.jpg"
对于字体图标路径
这个尤其需要注意,因为字体会有跨域的问题,比如字体文件放在gitee上,在本站获取会提示获取不到,放在m.qdxin上,会提示woff2(体积小适合浏览器显示)资源不允许跨域,而本站的带宽有限,字体请求的很慢,会显示明显的框框,所以最终将原来完全版的Font Awesome字体换为提交较小的且开源的4.7版的字体放在本地引用,所以如果项目对图标要求不高时候,尽量选用开源的,避免后续很多问题。
# 在字体存放服务器上进行配置!让字体没有跨域的提示方便引用!允许跨域引用(apache可以放在htaccess文件中)
<FilesMatch "\.(ttf|otf|eot|woff|woff2)$">
<IfModule mod_headers.c>
Header set Access-Control-Allow-Origin "*"
</IfModule>
</FilesMatch>
或者将字体文件以base64编码的方式引入内嵌到样式文件中。字体转base64方法
@font-face {
font-family: 'icon-tb';
Src : url("data:application/x-font-ttf;charset=utf-8;base64,XXXXXXXXXXXX") format("ttf");
}
关于开发环境与生产环境
需要设置一个全局变量,用于区分各种环境,比如一个变量控制各种JS路径的引用,否则等上线调试会很麻烦。JS中也应该有这么一个变量。
$local = true;
// 比如在Smarty-tpl文件中
{if $local}
<script src="/assets/js/..."></script>
{else}
<script src="https://634174214.gitee.io/...></script>
{/if}
关于PHP版本的问题
关于get_magic_quotes_gpc()
由于开始开发的时候,使用的是PHP5.4版本,在过滤获取到的$_GET处理的时候使用了这么一个函数:
function daddslashes($str)
{
// 判断magic_quotes_gpc是否为打开
$str = (!get_magic_quotes_gpc()) ? addslashes($str) : $str;
$str = str_replace("_", "\_", $str); // 把 '_'过滤掉
$str = str_replace("%", "\%", $str); // 把 '%'过滤掉
$str = nl2br($str); // 回车转换
// html标记转换 转换为HTML实体 <
$str = htmlspecialchars($str, ENT_QUOTES);
return $str;
}
而服务器的环境是7.4,已经吧get_magic_quotes_gpc()这个函数废弃了!官方说明
先来简单描述一下这个函数的作用:
在php的配置文件中,有个布尔值的设置,就是magic_quotes_runtime,当它打开时,php的大部分函数自动的给从外部引入的(包括数据库或者文件)数据中的溢出字符加上反斜线。 当然如果重复给溢出字符加反斜线,那么字符串中就会有多个反斜线,所以这时就要用set_magic_quotes_runtime()与get_magic_quotes_runtime()设置和检测php.ini文件中magic_quotes_runtime状态。为了使自己的程序不管服务器是什么设置都能正常执行。可以在程序开始用get_magic_quotes_runtime检测该设置的状态决定是否要手工处理,或者在开始(或不需要自动转义的时候)用set_magic_quotes_runtime(0)关掉该设置。
magic_quotes_gpc设置是否自动为GPC(get,post,cookie)传来的数据中的\'\"\\加上反斜线。可以用get_magic_quotes_gpc()检测系统设置。如果没有打开这项设置,可以使用addslashes()函数添加,它的功能就是给数据库查询语句等的需要在某些字符前加上了反斜线。这些字符是单引号(\')、双引号(\")、反斜线(\\)与 NUL(NULL 字符)。
// 一般用法如下;
if(!get_magic_quotes_gpc())
{
addslashes($prot);
}
由于已经废弃了,无论使用function_exists检测,都会报错:
Function get_magic_quotes_gpc() is deprecated
解决办法就是定义一个常量去替代原来的函数判断!
// 在核心文件或者报错的文件里面加一行定义常量就可以了
define('MAGIC_QUOTES_GPC', ini_set("magic_quotes_runtime", 0) ? True : False);
// 在函数中使用常量替换函数判断
$str = (!MAGIC_QUOTES_GPC) ? addslashes($str) : $str;
php7.4废弃了:str{num}这种语法
// 生成随机密码字符串,默认生成10-20之间的随机数
function getRandomPassword($min_length = 16, $max_length = 20) {
$pattern = '1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLOMNOPQRSTUVWXYZ';
$key = '';
// 生成一个min-max间的随机数,用来决定位数,循环几次就生成几位数的字符串
$rand = rand($min_length, $max_length);
for($i = 0; $i < $rand; $i++) {
$key .= $pattern[mt_rand(0,35)]; //生成php随机数
}
return $key;
}
其中原来的$pattern{ mt_rand(0,35) } 替换为了$pattern[mt_rand(0,35)] 因为php7.4以后废弃了这种写法,原来那么写会报错:
Array and string offset access syntax with curly braces is deprecated
PHP7.4不再支持使用大括号访问数组以及字符串的偏移,php7.4不支持数组{}写法,字符串与数组统一为数组[]写法。