记录wubin.work开发中遇到的问题

7882次阅读 406人点赞 作者: WuBin 发布时间: 2021-02-18 16:33:02
扫码到手机查看

第一次全栈开发难免会遇到很多问题,在这里特意记录下,随时想到随时更新。

关于环境的问题

开发环境与生产环境

        开发的时候没有考虑到这个问题,导致线上、线下的环境不统一,引起了很多调试的问题,在开发的时候,最好设置一个变量,只修改一下,即可切换开发/生产的环境。

对于静态资源路径

        本地开发静态资源获取的都很快,但是到线上就受到带宽等影响,问题被无限放大,特别是使用腾讯的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实体 &lt;
    $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不支持数组{}写法,字符串与数组统一为数组[]写法。

点赞 支持一下 觉得不错?客官您就稍微鼓励一下吧!
关键词:记录wubin.work开发中遇到的问题
推荐阅读
  • uniapp实现被浏览器唤起的功能

    当用户打开h5链接时候,点击打开app若用户在已经安装过app的情况下直接打开app,若未安装过跳到应用市场下载安装这个功能在实现上主要分为两种场景,从普通浏览器唤醒以及从微信唤醒。

    10049次阅读 659人点赞 发布时间: 2022-12-14 16:34:53 立即查看
  • Vue

    盘点Vue2和Vue3的10种组件通信方式

    Vue中组件通信方式有很多,其中Vue2和Vue3实现起来也会有很多差异;本文将通过选项式API组合式API以及setup三种不同实现方式全面介绍Vue2和Vue3的组件通信方式。

    4677次阅读 346人点赞 发布时间: 2022-08-19 09:40:16 立即查看
  • JS

    几个高级前端常用的API

    推荐4个前端开发中常用的高端API,分别是MutationObserver、IntersectionObserver、getComputedstyle、getBoundingClientRect、requ...

    14754次阅读 967人点赞 发布时间: 2021-11-11 09:39:54 立即查看
  • PHP

    【正则】一些常用的正则表达式总结

    在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。了解一些常用的正则表达式,能大大提高你的工作效率。

    13961次阅读 525人点赞 发布时间: 2021-10-09 15:58:58 立即查看
  • 【中文】免费可商用字体下载与考证

    65款免费、可商用、无任何限制中文字体打包下载,这些字体都是经过长期验证,经得住市场考验的,让您规避被无良厂商起诉的风险。

    12705次阅读 1023人点赞 发布时间: 2021-07-05 15:28:45 立即查看
  • Vue

    Vue3开发一个v-loading的自定义指令

    在vue3中实现一个自定义的指令,有助于我们简化开发,简化复用,通过一个指令的调用即可实现一些可高度复用的交互。

    16940次阅读 1357人点赞 发布时间: 2021-07-02 15:58:35 立即查看
  • JS

    关于手机上滚动穿透问题的解决

    当页面出现浮层的时候,滑动浮层的内容,正常情况下预期应该是浮层下边的内容不会滚动;然而事实并非如此。在PC上使用css即可解决,但是在手机端,情况就变的比较复杂,就需要禁止触摸事件才可以。

    15465次阅读 1257人点赞 发布时间: 2021-05-31 09:25:50 立即查看
  • Vue

    Vue+html2canvas截图空白的问题

    在使用vue做信网单页专题时,有海报生成的功能,这里推荐2个插件:一个是html2canvas,构造好DOM然后转canvas进行截图;另外使用vue-canvas-poster(这个截止到2021年3月...

    30556次阅读 2403人点赞 发布时间: 2021-03-02 09:04:51 立即查看
  • Vue

    vue-router4过度动画无效解决方案

    在初次使用vue3+vue-router4时候,先后遇到了过度动画transition进入和退出分别无效的情况,搜遍百度没没找到合适解决方法,包括vue-route4有一些API都进行了变化,以前的一些操...

    26527次阅读 2041人点赞 发布时间: 2021-02-23 13:37:20 立即查看
交流 收藏 目录