作者: Mr.Li

  • PHP数组面试题8道以及答案

     

    1.写函数创建长度为10的数组,数组中的元素为递增的奇数,首项为1.
    代码:
    function arrsort($first,$length){
    $arr = array();
    for($i=$first;$i<=$length;$i++){ $arr[] = $i*2-1; } return $arr; } $arr1 = arrsort(1,10); print_r($arr1);

    输出:
    Array ( [0] => 1 [1] => 3 [2] => 5 [3] => 7 [4] => 9 [5] => 11 [6] => 13 [7] => 15 [8] => 17 [9] => 19 )

    2.创建长度为10的数组,数组中的数为递增的等比数,比值为3,首项为1.
    代码:
    //$num为比值
    function arrsort($first,$length,$num){
    $arr= array();
    for($i=$first;$i<=$length;$i++){ //pow($num,$i-2);返回$num的($i-2)次方 $arr[] = $num*pow($num,$i-2); } return $arr; } $arr1 = arrsort(1,10,3); print_r($arr1);

    输出:Array ( [0] => 1 [1] => 3 [2] => 9 [3] => 27 [4] => 81 [5] => 243 [6] => 729 [7] => 2187 [8] => 6561 [9] => 19683 )

    3.求数组中最大数的下标.
    代码:function maxkey($arr){
    $maxval = max($arr);
    foreach($arr as $key=>$val){
    if($maxval == $val){
    $maxkey = $key;
    }
    }
    return $maxkey;
    }
    $arr = array(0,-1,-2,5,"b"=>15,3);
    echo maxkey($arr);

    输入:b

    4.创建一个长度为10的数组,数组中的元素满足斐波拉契数列的规律.
    ( 斐波那契数列,又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n>=2,n∈N*). 特别指出:第0项是0,第1项是第一个1。)
    代码:function arrFibo($len){
    $arr[0] = 0;
    $arr[1] = 1;
    for($i=2;$i<$len;$i++){ $arr[$i] = $arr[$i-1]+$arr[$i-2]; } return $arr; } echo ""; print_r(arrFibo(10)); echo "";

    输出:Array
    (
    [0] => 0
    [1] => 1
    [2] => 1
    [3] => 2
    [4] => 3
    [5] => 5
    [6] => 8
    [7] => 13
    [8] => 21
    [9] => 34
    )

    5.计算数组中最大数和最小数的差.
    两种方法:
    ①max/min
    输出:102
    ②sort把元素按从小到大排序/rsort吧元素按从大到小排序
    function arrsub($arr){
    sort($arr);
    $min = $arr[0];
    rsort($arr);
    $max = $arr[0];
    $sub = $max - $min;
    return $sub;
    }
    $arr = array(-1,-2,100);
    echo arrsub($arr);

    输出:102

    6.写一个方法,将一个长度超过10的数组最后5项直接截取,不改变顺序变为前5项,如{1,2,3,4,5,6,7,8,9,10}变为{6,7,8,9,10,1,2,3,4,5}.
    思路:先把数组截取相应的长度( array_slice ),再把2段数组拼接( array_merge )
    代码:function arrsort($arr){
    $num = count($arr);
    if($num > 10){
    //array_slice($arr,起始位置,截取长度,保留索引(默认为false))
    $arr_firstpart = array_slice($arr,0,$num-5,true);
    $arr_lastpart = array_slice($arr,($num-5),5,true);
    }else{
    echo "数组不超过10个元素,请重新输入";
    exit();
    }
    //拼接
    $arr_new = array_merge($arr_lastpart,$arr_firstpart);
    return $arr_new;
    }
    $arr = array("a"=>1,2,3,8,9,6,"b"=>5,-1,"c"=>8,0,7);
    echo "";
    print_r($arr);
    echo "
    = = = = = 拼接后 = = = =

    ";
    print_r(arrsort($arr));
    echo "";

    输出:Array
    (
    [a] => 1
    [0] => 2
    [1] => 3
    [2] => 8
    [3] => 9
    [4] => 6
    [b] => 5
    [5] => -1
    [c] => 8
    [6] => 0
    [7] => 7
    )

    拼接后:
    Array
    (
    [b] => 5
    [0] => -1
    [c] => 8
    [1] => 0
    [2] => 7
    [a] => 1
    [3] => 2
    [4] => 3
    [5] => 8
    [6] => 9
    [7] => 6
    )

    当数组不满足长度为10时:
    代码:$arr = array("a"=>1,2,3);
    输出:Array
    (
    [a] => 1
    [0] => 2
    [1] => 3
    )

    拼接后:数组不超过10个元素,请重新输入

    7.将两个数组连接成一个新数组.
    方法①使用array_merge()函数
    array_merge($arr1,$arr2);
    方法②使用array_merge_recursive()函数递归追加数组
    ( array_merge_recursive() 函数与 array_merge() 函数 一样,将一个或多个数组的元素的合并起来,一个数组中的值附加在前一个数组的后面。并返回作为结果的数组。
    但是,与 array_merge() 不同的是,当有重复的键名时,值不会被覆盖,而是将多个相同键名的值递归组成一个数组。)
    代码:$arr = array("a"=>1,"b"=>2,3);
    $arr2 = array("a"=>Dee,3,5);

    $arr3 = array_merge($arr,$arr2);
    $arr4 = array_merge_recursive($arr,$arr2);
    echo "";
    print_r($arr3);
    echo "
    = = = = =

    ";
    print_r($arr4);
    echo "";

    输出:Array
    (
    [a] => Dee
    [b] => 2
    [0] => 3
    [1] => 3
    [2] => 5
    )

    Array
    (
    [a] => Array
    (
    [0] => 1
    [1] => Dee
    )
    [b] => 2
    [0] => 3
    [1] => 3
    [2] => 5
    )

    第一个输出的数组中索引为"a"的值1被索引被第二个数组中索引为"a"的值Dee覆盖了。
    方法③
    代码:function arrsort($arr1,$arr2){
    $arr_new = $arr1;

    foreach($arr2 as $key=>$val){

    $arr_new[] = $val;
    }
    return $arr_new;
    }
    $arr1 = array("a"=>1,"b"=>2,3);
    $arr2 = array("a"=>Dee,"c"=>3,5);
    echo "";
    print_r(arrsort($arr1,$arr2));
    echo "";

    输出:Array
    (
    [a] => 1
    [b] => 2
    [0] => 3
    [1] => Dee
    [2] => 3
    [3] => 5
    )

    如果是索引数组而且有重复的索引,则第二个数组中的这个重复的索引会被修改成新的索引。

    8.数组逆序( 不能使用rsort函数,不能生成新数组 )
    使用array_reverse()函数会创建新的数组,所以不能使用。
    $arr = array("a","b","c",1,10);
    $i = "";//要替换位置的数的下标
    $j = "";//临时变量
    $k = "";//被替换位置的数的下标
    $len = count($arr);
    $half_len = floor($len/2);//向下取整,取整的值是循环的次数
    for($i=0;$i<$half_len;$i++){ $j = $arr[$i]; //判断数组个数奇偶 if($len%2!=0){ //奇数 $k = $half_len*2-$i; }else{ //偶数 $k = $half_len*2-$i-1; } $arr[$i] = $arr[$k]; $arr[$k] = $j; } echo ""; print_r($arr); echo "";

    输出:
    Array
    (
    [0] => 10
    [1] => 1
    [2] => c
    [3] => b
    [4] => a
    )

     

  • 2019PHP面试题网发布35道面试题

     

    一:OOP简介及OOP的特点

    OOP是面向对象编程,面向对象编程是一种计算机编程架构,OOP的一条基本原则是计算机程序是由单个能够起到子程序作用的单元或对象组合而成。

    OOP的特点:
    1、封装性:也称为信息隐藏,就是将一个类的使用和实现分开,只保留部分接口和方法与外部联系,或者说只公开了一些供开发人员使用的方法。于是开发人员只 需要关注这个类如何使用,而不用去关心其具体的实现过程,这样就能实现MVC分工合作,也能有效避免程序间相互依赖,实现代码模块间松藕合。

    2、继承性:就是子类自动继承其父级类中的属性和方法,并可以添加新的属性和方法或者对部分属性和方法进行重写。继承增加了代码的可重用性。PHP只支持单继承,也就是说一个子类只能有一个父类。

    3、多态性:子类继承了来自父级类中的属性和方法,并对其中部分方法进行重写。于是多个子类中虽然都具有同一个方法,但是这些子类实例化的对象调用这些相同的方法后却可以获得完全不同的结果,这种技术就是多态性。多态性增强了软件的灵活性。

    二:laravel的特点

    laravel框架引入了门面、依赖注入、Ioc模式以及各种各样的设计模式,另外,laravel的特点有:
    1.强大的rest router:用简单的回调函数就可以调用,快速绑定controller和router
    2.artisan:命令行工具,很多手动的工作都自动化
    3.可继承的模板,简化view的开发和管理
    4.blade模板:渲染速度更快
    5.ORM操作数据库
    6.migration:管理数据库和版本控制
    7.测试功能也很强大
    8.composer也是亮点

    三:简述数据库优化的几个方面

    数据库的优化可以从四个方面来优化:
    1.从结构层: web服务器采用负载均衡服务器,mysql服务器采用主从复制,读写分离;
    2.从储存层: 采用合适的存储引擎,采用三范式;
    3.从设计层: 采用分区分表、索引、表的字段采用合适的字段属性,适当的采用逆范式,开启mysql缓存;
    4.sql语句层:结果一样的情况下,采用效率高,速度快节省资源的sql语句执行;

    四:权限管理(RBAC)的实现

    1.首先创建一张用户表:id name auto(保存格式为:控制器-方法)
    2.然后在后台中创建一个基类控制器,控制器里封装一个构造方法,当用户登陆成功后,使用TP框架中封装好的session函数获取保存在服务器中的session id,然后实例化模型,通过用户id获取保存在数据表中的auth数据,使用explode函数分割获取到的数据,并使用一个数组保存起来,然后使用TP框架中封装好的常量获取当前控制器和方法,然后把他们组装成字符串,使用in_array函数进行判断该数组中是否含有当前获取到的控制器和方法,如果没有,就提示该用户没有权限,如果有就进行下一步操作

    五:thinkPHP框架有哪些优点

    thinkPHP框架是我们中国人自己开发的框架,各种资料比较齐全,国内用的比较多,比较简单和方便,而且是免费开源的。

    六:thinkPHP的特性有哪些

    1.多表查询非常方便,在model中几句代码就可以完成对多表的关联操作
    2.融合了smarty模板,使前后台分离
    3.支持多种缓存技术,尤其对memcache技术支持非常好
    4.命名规范,模型,视图,控制器严格遵循命名规则,通过命名一一对应
    5.支持多种url模式
    6.内置ajax返回方法,包括xml,json,html等
    7.支持应用扩展,类库扩展,驱动扩展等

    七:简述cookie及cookie特点

    cookie是由服务器产生,存储在客户端的一段信息。它定义了一种Web服务器在客户端存储和返回信息的机制,cookie文件它包含域、路径、生存期、和由服务器设置的变量值等内容。当用户以后访问同一个Web服务器时,浏览器会把cookie原样发送给服务器。通过让服务器读取原先保存到客户端的信息,网站能够为浏览者提供一系列的方便,例如在线交易过程中标识用户身份、安全要求不高的场合避免用户重复输入名字和密码、门户网站的主页定制、有针对性地投放广告等等。利用cookie的特性,大大扩展了WEB应用程序的功能,不仅可以建立服务器与客户机的联系,因为cookie可以由服务器定制,因此还可以将购物信息生成cookie值存放在客户端,从而实现购物车的功能。用基于cookie的方式实现服务器与浏览器之间的会话或购物车,有以下特点:
    1、cookie存储在客户端,且占用很少的资源,浏览器允许存放300个cookie,每个cookie的大小为4KB,足以满足购物车的要求,同时也减轻了服务器的负荷;
    2、cookie为浏览器所内置,使用方便。即使用户不小心关闭了浏览器窗口,只要在cookie定义的有效期内,购物车中的信息也不会丢失;
    3、cookie不是可执行文件,所以不会以任何方式执行,因此也不会带来病毒或攻击用户的系统;
    4、基于cookie的购物车要求用户浏览器必须支持并设置为启用cookie,否则购物车则失效;
    5、存在着关于cookie侵犯访问者隐私权的争论,因此有些用户会禁止本机的cookie功能。

    八:简述session及session特点

    session是实现购物车的另一种方法。session提供了可以保存和跟踪用户的状态信息的功能,使当前用户在session中定义的变量和对象能在页面之间共享,但是不能为应用中其他用户所访问,它与cookie最重大的区别是,session将用户在会话期间的私有信息存储在服务器端,提高了安全性。在服务器生成session后,客户端会生成一个sessionid识别号保存在客户端,以保持和服务器的同步。这个sessionid是只读的,如果客户端禁止cookie功能,session会通过在URL中附加参数,或隐含在表单中提交等其他方式在页面间传送。因此利用session实施对用户的管理则更为安全、有效。

    同样,利用session也能实现购物车,这种方式的特点是:
    1、session用新的机制保持与客户端的同步,不依赖于客户端设置;
    2、与cookie相比,session是存储在服务器端的信息,因此显得更为安全,因此可将身份标示,购物等信息存储在session中;
    3、session会占用服务器资源,加大服务器端的负载,尤其当并发用户很多时,会生成大量的session,影响服务器的性能;
    4、因为session存储的信息更敏感,而且是以文件形式保存在服务器中,因此仍然存在着安全隐患。

    九:thinkPHP框架中的大字母函数

    U:对url的组装
    A:内部实例化控制器
    S:缓存处理
    R:调用某个控制器的操作方法
    D:实例化自定义模型类
    M:实例化基础模型类
    I:获取参数
    L:设置或者获取当前语言
    C:设置或获取,保存配置

    十:怎么定义接口的

    接口分为两种:一种是数据型接口,一种是应用型接口。
    数据型接口:是比抽象类更抽象的某种“结构”——它其实不是类,但是跟类一样的某种语法结构,是一种结构规范,规范我们类要以什么格式进行定义,一般用于团队比较大,分支比较多的情况下使用。
    应用型接口: API(application interface) 数据对外访问的一个入口
    我主要是参与的APP开发中接口的编写,客户端需要什么样的数据,我们就给他们提供相应的数据,数据以json/xml的格式返回,并且配以相应的接口文档。

     

     

     

  • 2020PHP经典面试题汇总

    2020PHP经典面试题汇总,包括PHP基础部分、数据库部分、面向对象部分、ThinkPHP部分部分、smarty模板引擎、二次开发系统(DEDE、ecshop)、微信公众平台开发、对于自身掌握的技术描述等几部分PHP面试题。

    更新日期:2020年1月16日

    目录:
    一:PHP基础部分
    二:数据库部分
    三:面向对象部分
    四:ThinkPHP部分
    五:smarty模板引擎
    六、二次开发系统(DEDE、ecshop)
    七、微信公众平台开发
    八、对于自身掌握的技术描述

    一:PHP基础部分

    返回顶部

    1、PHP语言的一大优势是跨平台,什么是跨平台?

    PHP的运行环境最优搭配为Apache+MySQL+PHP,此运行环境可以在不同操作系统(例如windows、Linux等)上配置,不受操作系统的限制,所以叫跨平台

    2、WEB开发中数据提交方式有几种?有什么区别?百度使用哪种方式?

    Get与post两种方式
    区别:
    1. Get从服务器获取数据,post向服务器传送数据
    2. Get传值在url中可见,post在url中不可见
    3. Get传值一般在2KB以内,post传值大小可以在php.ini中进行设置
    4. get安全性非低,post安全性较高,执行效率却比Post高
    建议:
    1、get式安全性较Post式要差些包含机密信息建议用Post数据提交式;
    2、做数据查询建议用Get式;做数据添加、修改或删除建议用Post方式;
    百度使用的get方式,因为可以从它的URL中看出

    3、掌握PHP的哪些框架、模板引擎、系统等

    框架:框架有很多,例如zendframe、CI、Yii等等,咱们学过的是thinkphp
    模板引擎:也有很多,在课本中有,咱们学过的是smarty
    系统:有很多,例如:康盛的产品(uchome、supesite、discuzX等),帝国系统、DEDE(织梦)、ecshop等,咱们学过的是DEDECMS、Ecshop

    4、说一下你所掌握的网页前端技术有哪些?

    熟练掌握DIV+CSS网页布局,JavaScript、jQuery框架、photoshop图片处理

    5、AJAX的优势是什么?

    ajax是异步传输技术,可以通过javascript实现,也可以通过JQuery框架实现,实现局部刷新,减轻了服务器的压力,也提高了用户体验

    6、安全对一套程序来说至关重要,请说说在开发中应该注意哪些安全机制?

    ①防远程提交;②防SQL注入,对特殊代码进行过滤;③防止注册机灌水,使用验证码;

    7、在程序的开发中,如何提高程序的运行效率?

    ①优化SQL语句,查询语句中尽量不使用select *,用哪个字段查哪个字段;少用子查询可用表连接代替;少用模糊查询;②数据表中创建索引;③对程序中经常用到的数据生成缓存;

    8、PHP可否与其它的数据库搭配使用?

    PHP与MYSQL数据库是最优搭配,当然PHP也可以去其它的数据库搭配使用,例如MSSQL等,PHP中预留了操作MSSQL的函数,只要开启就可以使用

    9、现在编程中经常采取MVC三层结构,请问MVC分别指哪三层,有什么优点?

    MVC三层分别指:业务模型、视图、控制器,由控制器层调用模型处理数据,然后将数据映射到视图层进行显示,优点是:①可以实现代码的重用性,避免产生代码冗余;②M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式

    10、对json数据格式的理解?

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,json数据格式固定,可以被多种语言用作数据的传递
    PHP中处理json格式的函数为json_decode( string $json [, bool $assoc ] ) ,接受一个 JSON格式的字符串并且把它转换为PHP变量,参数json待解码的json string格式的字符串。assoc当该参数为TRUE时,将返回array而非object;
    Json_encode:将PHP变量转换成json格式

    11、Print、echo、print_r有什么区别?

    ① echo和print都可以做输出,不同的是,echo不是函数,没有返回值,而print是一个函数有返回值,所以相对而言如果只是输出echo会更快,而print_r通常用于打印变量的相关信息,通常在调试中使用。
    ② print 是打印字符串
    ③ print_r 则是打印复合类型 如数组 对象

    12、SESSION与COOKIE的区别?

    ①存储位置:session存储于服务器,cookie存储于浏览器
    ②安全性:session安全性比cookie高
    ③session为‘会话服务’,在使用时需要开启服务,cookie不需要开启,可以直接用

    13、PHP处理数组的常用函数?(重点看函数的‘参数’和‘返回值’)

    array()创建数组;②count()返回数组中元素的数目;③array_push()将一个或多个元素插入数组的末尾(入栈);④array_column()返回输入数组中某个单一列的值;⑤array_combine()通过合并两个数组来创建一个新数组;⑥array_reverse()以相反的顺序返回数组;⑦array_unique()删除数组中的重复值;⑧in_array()检查数组中是否存在指定的值;

    14、PHP处理字符串的常用函数?(重点看函数的‘参数’和‘返回值’)

    trim()移除字符串两侧的空白字符和其他字符;
    substr_replace()把字符串的一部分替换为另一个字符串;
    substr_count()计算子串在字符串中出现的次数;
    substr()返回字符串的一部分;
    strtolower()把字符串转换为小写字母;
    strtoupper()把字符串转换为大写字母;
    strtr()转换字符串中特定的字符;
    strrchr()查找字符串在另一个字符串中最后一次出现;
    strstr()查找字符串在另一字符串中的第一次出现(对大小写敏感);strrev()反转字符串;strlen()返回字符串的长度;str_replace()替换字符串中的一些字符(对大小写敏感);print()输出一个或多个字符串;explode()把字符串打散为数组;is_string()检测变量是否是字符串;strip_tags()从一个字符串中去除HTML标签;mb_substr()用来截中文与英文的函数

    15、PHP处理时间的常用函数?(重点看函数的‘参数’和‘返回值’)

    date_default_timezone_get()返回默认时区。
    date_default_timezone_set()设置默认时区。
    date()格式化本地时间/日期。
    getdate()返回日期/时间信息。
    gettimeofday()返回当前时间信息。
    microtime()返回当前时间的微秒数。
    mktime()返回一个日期的 Unix时间戳。
    strtotime()将任何英文文本的日期或时间描述解析为 Unix时间戳。
    time()返回当前时间的 Unix时间戳。

    16、PHP处理数据库的常用函数?(重点看函数的‘参数’和‘返回值’)

    请参照php手册,认真查看,此项非常重要

    17、PHP操作文件的常用函数?(重点看函数的‘参数’和‘返回值’)

    ①打开文件;②删除文件;③读取文件;④写入文件;⑤修改文件;⑥关闭文件;⑦创建文件等等,此项非常重要,在工作中经常用来生成缓存或者静态文件,请参照php手册,认真查看

    18、PHP操作目录(文件夹)的常用函数?(重点看函数的‘参数’和‘返回值’)

    ①打开目录;②删除目录;③读取目录;④创建目录;⑤修改目录;⑥关闭目录等等,此项非常重要,在工作中经常用来创建或者删除上传文件的目录,创建或者删除缓存、静态页面的目录,请参照php手册,认真查看

    二:数据库部分

    返回顶部

    1. 常见的关系型数据库管理系统产品有?

    答:Oracle、SQL Server、MySQL、Sybase、DB2、Access等。

    2. SQL语言包括哪几部分?每部分都有哪些操作关键字?

    答:SQL语言包括数据定义(DDL)、数据操纵(DML),数据控制(DCL)和数据查询(DQL)四个部分。
    数据定义:Create Table,Alter Table,Drop Table, Craete/Drop Index等
    数据操纵:Select ,insert,update,delete,
    数据控制:grant,revoke
    数据查询:select

    3. 完整性约束包括哪些?

    答:数据完整性(Data Integrity)是指数据的精确(Accuracy)和可靠性(Reliability)。
    分为以下四类:
    1) 实体完整性:规定表的每一行在表中是惟一的实体。
    2) 域完整性:是指表中的列必须满足某种特定的数据类型约束,其中约束又包括取值范围、精度等规定。
    3) 参照完整性:是指两个表的主关键字和外关键字的数据应一致,保证了表之间的数据的一致性,防止了数据丢失或无意义的数据在数据库中扩散。
    4) 用户定义的完整性:不同的关系数据库系统根据其应用环境的不同,往往还需要一些特殊的约束条件。用户定义的完整性即是针对某个特定关系数据库的约束条件,它反映某一具体应用必须满足的语义要求。
    与表有关的约束:包括列约束(NOT NULL(非空约束))和表约束(PRIMARY KEY、foreign key、check、UNIQUE)

    4. 什么是事务?及其特性?

    答:事务:是一系列的数据库操作,是数据库应用的基本逻辑单位。
    事务特性:
    (1)原子性:即不可分割性,事务要么全部被执行,要么就全部不被执行。
    (2)一致性或可串性。事务的执行使得数据库从一种正确状态转换成另一种正确状态
    (3)隔离性。在事务正确提交之前,不允许把该事务对数据的任何改变提供给任何其他事务,
    (4) 持久性。事务正确提交后,其结果将永久保存在数据库中,即使在事务提交后有了其他故障,事务的处理结果也会得到保存。
    或者这样理解:
    事务就是被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就被失败,以后操作就会回滚到操作前状态,或者是上有个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。

    5. 什么是锁?

    答:数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。
    加锁是实现数据库并发控制的一个非常重要的技术。当事务在对某个数据对象进行操作前,先向系统发出请求,对其加锁。加锁后事务就对该数据对象有了一定的控制,在该事务释放锁之前,其他的事务不能对此数据对象进行更新操作。
    基本锁类型:锁包括行级锁和表级锁

    6. 什么叫视图?游标是什么?

    答:视图是一种虚拟的表,具有和物理表相同的功能。可以对视图进行增,改,查,操作,视图通常是有一个表或者多个表的行或列的子集。对视图的修改不影响基本表。它使得我们获取数据更容易,相比多表查询。
    游标:是对查询出来的结果集作为一个单元来有效的处理。游标可以定在该单元中的特定行,从结果集的当前行检索一行或多行。可以对结果集当前行做修改。一般不使用游标,但是需要逐条处理数据的时候,游标显得十分重要。

    7. 什么是存储过程?用什么来调用?

    答:存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。可以用一个命令对象来调用存储过程。

    8. 索引的作用?和它的优点缺点是什么?

    答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。索引可以是唯一的,创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。

    9. 如何通俗地理解三个范式?

    答:第一范式:1NF是对属性的原子性约束,要求属性具有原子性,不可再分解;
    第二范式:2NF是对记录的惟一性约束,要求记录有惟一标识,即实体的惟一性; 第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来,它要求字段没有冗余。。

    10. 什么是基本表?什么是视图?

    答:基本表是本身独立存在的表,在 SQL 中一个关系就对应一个表。 视图是从一个或几个基本表导出的表。视图本身不独立存储在数据库中,是一个虚表

    11. 试述视图的优点?

    答:(1) 视图能够简化用户的操作 (2) 视图使用户能以多种角度看待同一数据; (3) 视图为数据库提供了一定程度的逻辑独立性; (4) 视图能够对机密数据提供安全保护。

    12. NULL是什么意思

    答:NULL这个值表示UNKNOWN(未知):它不表示“”(空字符串)。对NULL这个值的任何比较都会生产一个NULL值。您不能把任何值与一个 NULL值进行比较,并在逻辑上希望获得一个答案。
    使用IS NULL来进行NULL判断

    13. 主键、外键和索引的区别?

    主键、外键和索引的区别
    定义:
    主键–唯一标识一条记录,不能有重复的,不允许为空
    外键–表的外键是另一表的主键, 外键可以有重复的, 可以是空值
    索引–该字段没有重复值,但可以有一个空值
    作用:
    主键–用来保证数据完整性
    外键–用来和其他表建立联系用的
    索引–是提高查询排序的速度
    个数:
    主键–主键只能有一个
    外键–一个表可以有多个外键
    索引–一个表可以有多个唯一索引

    14. 你可以用什么来确保表格里的字段只接受特定范围里的值?

    答:Check限制,它在数据库表格里被定义,用来限制输入该列的值。
    触发器也可以被用来限制数据库表格里的字段能够接受的值,但是这种办法要求触发器在表格里被定义,这可能会在某些情况下影响到性能。

    15. 说说对SQL语句优化有哪些方法?(选择几条)

    (1)Where子句中:where表之间的连接必须写在其他Where条件之前,那些可以过滤掉最大数量记录的条件必须写在Where子句的末尾.HAVING最后。
    (2)用EXISTS替代IN、用NOT EXISTS替代NOT IN。
    (3) 避免在索引列上使用计算
    (4)避免在索引列上使用IS NULL和IS NOT NULL
    (5)对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。
    (6)应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描
    (7)应尽量避免在 where 子句中对字段进行表达式操作,这将导致引擎放弃使用索引而进行全表扫描

    16. SQL语句中‘相关子查询’与‘非相关子查询’有什么区别?

    答:子查询:嵌套在其他查询中的查询称之。
    子查询又称内部,而包含子查询的语句称之外部查询(又称主查询)。
    所有的子查询可以分为两类,即相关子查询和非相关子查询
    (1)非相关子查询是独立于外部查询的子查询,子查询总共执行一次,执行完毕后将值传递给外部查询。
    (2)相关子查询的执行依赖于外部查询的数据,外部查询执行一行,子查询就执行一次。
    故非相关子查询比相关子查询效率高

    17. char和varchar的区别?

    答:是一种固定长度的类型,varchar则是一种可变长度的类型,它们的区别是:
    char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).

    18. Mysql 的存储引擎,myisam和innodb的区别。

    答:简单的表达:
    MyISAM 是非事务的存储引擎;适合用于频繁查询的应用;表锁,不会出现死锁;适合小数据,小并发
    innodb是支持事务的存储引擎;合于插入和更新操作比较多的应用;设计合理的话是行锁(最大区别就在锁的级别上);适合大数据,大并发。

    19. 数据表类型有哪些

    答:MyISAM、InnoDB、HEAP、BOB,ARCHIVE,CSV等。
    MyISAM:成熟、稳定、易于管理,快速读取。一些功能不支持(事务等),表级锁。
    InnoDB:支持事务、外键等特性、数据行锁定。空间占用大,不支持全文索引等。

    20. MySQL数据库作发布系统的存储,一天五万条以上的增量,预计运维三年,怎么优化?

    a. 设计良好的数据库结构,允许部分数据冗余,尽量避免join查询,提高效率。
    b. 选择合适的表字段数据类型和存储引擎,适当的添加索引。
    c. mysql库主从读写分离。
    d. 找规律分表,减少单表中的数据量提高查询速度。
    e.添加缓存机制,比如memcached,apc等。
    f. 不经常改动的页面,生成静态页面。
    g. 书写高效率的SQL。比如

     

    21. 对于大流量的网站,您采用什么样的方法来解决各页面访问量统计问题?

    答:
    a. 确认服务器是否能支撑当前访问量。
    b. 优化数据库访问。
    c. 禁止外部访问链接(盗链), 比如图片盗链。
    d. 控制文件下载。
    e. 使用不同主机分流。
    f. 使用浏览统计软件,了解访问量,有针对性的进行优化。

    三:面向对象部分

    返回顶部

    1、什么是面向对象?(理解着回答)

    答:面向对象OO = 面向对象的分析OOA + 面向对象的设计OOD + 面向对象的编程OOP;通俗的解释就是“万物皆对象”,把所有的事物都看作一个个可以独立的对象(单元),它们可以自己完成自己的功能,而不是像C那样分成一个个函数。

    现在纯正的OO语言主要是Java和C#,PHP、C++也支持OO,C是面向过程的。

    2、简述 private、 protected、 public修饰符的访问权限。

    答:private : 私有成员, 在类的内部才可以访问。

    protected : 保护成员,该类内部和继承类中可以访问。

    public : 公共成员,完全公开,没有访问限制。

    3、堆和栈的区别?

    答:栈是编译期间就分配好的内存空间,因此你的代码中必须就栈的大小有明确的定义;

    堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小。

    4、XML 与 HTML 的主要区别

    答:(1) XML是区分大小写字母的,HTML不区分。
    (2) 在HTML中,如果上下文清楚地显示出段落或者列表键在何处结尾,那么你可以省略
    或者
    之类的结束 标记。在XML中,绝对不能省略掉结束标记。
    (3) 在XML中,拥有单个标记而没有匹配的结束标记的元素必须用一个 / 字符作为结尾。这样分析器就知道不用 查找结束标记了。
    (4) 在XML中,属性值必须分装在引号中。在HTML中,引号是可用可不用的。
    (5) 在HTML中,可以拥有不带值的属性名。在XML中,所有的属性都必须带有相应的值。

    5、面向对象的特征有哪些方面?

    答:主要有封装,继承,多态。如果是4个方面则加上:抽象。
    下面的解释为理解:
    封装:
    封装是保证软件部件具有优良的模块性的基础,封装的目标就是要实现软件部件的高内聚,低耦合,防止程序相互依赖性而带来的变动影响.
    继承:
    在定义和实现一个类的时候,可以在一个已经存在的类的基础之上来进行,把这个已经存在的类所定义的内容作为自己的内容,并可以加入若干新的内容,或修改原来的方法使之更适合特殊的需要,这就是继承。继承是子类自动共享父类数据和方法的机制,这是类之间的一种关系,提高了软件的可重用性和可扩展性。
    多态:
    多态是指程序中定义的引用变量所指向的具体类型和通过该引用变量发出的方法调用在编程时并不确定,而是在程序运行期间才确定,即一个引用变量倒底会指向哪个类的实例对象,该引用变量发出的方法调用到底是哪个类中实现的方法,必须在由程序运行期间才能决定。
    抽象:
    抽象就是找出一些事物的相似和共性之处,然后将这些事物归为一个类,这个类只考虑这些事物的相似和共性之处,并且会忽略与当前主题和目标无关的那些方面,将注意力集中在与当前目标有关的方面。例如,看到一只蚂蚁和大象,你能够想象出它们的相同之处,那就是抽象。

    6、抽象类和接口的概念以及区别?

    答:抽象类:它是一种特殊的,不能被实例化的类,只能作为其他类的父类使用。使用abstract关键字声明。
    它是一种特殊的抽象类,也是一个特殊的类,使用interface声明。
    (1)抽象类的操作通过继承关键字extends实现,而接口的使用是通过implements关键字来实现。
    (2)抽象类中有数据成员,可以实现数据的封装,但是接口没有数据成员。
    (3)抽象类中可以有构造方法,但是接口没有构造方法。
    (4)抽象类的方法可以通过private、protected、public关键字修饰(抽象方法不能是private),而接口中的方法只能使用public关键字修饰。
    (5)一个类只能继承于一个抽象类,而一个类可以同时实现多个接口。
    (6)抽象类中可以有成员方法的实现代码,而接口中不可以有成员方法的实现代码。

    7、什么是构造函数,什么是析构函数,作用是什么?

    答:构造函数(方法)是对象创建完成后第一个被对象自动调用的方法。它存在于每个声明的类中,是一个特殊的成员方法。作用是执行一些初始化的任务。Php中使用__construct()声明构造方法,并且只能声明一个。
    析构函数(方法)作用和构造方法正好相反,是对象被销毁之前最后一个被对象自动调用的方法。是PHP5中新添加的内容作用是用于实现在销毁一个对象之前执行一些特定的操作,诸如关闭文件和释放内存等。

    8、如何重载父类的方法,举例说明

    答:重载,即覆盖父类的方法,也就是使用子类中的方法替换从父类中继承的方法,也叫方法的重写。
    覆盖父类方法的关键是在子类中创建于父类中相同的方法包括方法的名称、参数和返回值类型。PHP中只要求方法的名称相同即可。

    9、常用的魔术方法有哪些?举例说明

    答:php规定以两个下划线(__)开头的方法都保留为魔术方法,所以建议大家函数名最好不用__开头,除非是为了重载已有的魔术方法。
    __construct() 实例化类时自动调用。
    __destruct() 类对象使用结束时自动调用。
    __set() 在给未定义的属性赋值的时候调用。
    __get() 调用未定义的属性时候调用。
    __isset() 使用isset()或empty()函数时候会调用。
    __unset() 使用unset()时候会调用。
    __sleep() 使用serialize序列化时候调用。
    __wakeup() 使用unserialize反序列化的时候调用。
    __call() 调用一个不存在的方法的时候调用。
    __callStatic()调用一个不存在的静态方法是调用。
    __toString() 把对象转换成字符串的时候会调用。比如 echo。
    __invoke() 当尝试把对象当方法调用时调用。
    __set_state() 当使用var_export()函数时候调用。接受一个数组参数。
    __clone() 当使用clone复制一个对象时候调用。

    10、$this和self、parent这三个关键词分别代表什么?在哪些场合下使用?

    答:$this 当前对象
    self 当前类
    parent 当前类的父类
    $this在当前类中使用,使用->调用属性和方法。
    self也在当前类中使用,不过需要使用::调用。
    parent在类中使用。

    11、类中如何定义常量、如何类中调用常量、如何在类外调用常量。

    答:类中的常量也就是成员常量,常量就是不会改变的量,是一个恒值。
    定义常量使用关键字const.
    例如:const PI = 3.1415326;
    无论是类内还是类外,常量的访问和变量是不一样的,常量不需要实例化对象,
    访问常量的格式都是类名加作用域操作符号(双冒号)来调用。
    即:类名 :: 类常量名;

    12、作用域操作符::如何使用?都在哪些场合下使用?

    答:调用类常量
    调用静态方法

    13、__autoload()方法的工作原理是什么?

    答:使用这个魔术函数的基本条件是类文件的文件名要和类的名字保持一致。
    当程序执行到实例化某个类的时候,如果在实例化前没有引入这个类文件,那么就自动执行__autoload()函数。
    这个函数会根据实例化的类的名称来查找这个类文件的路径,当判断这个类文件路径下确实存在这个类文件后
    就执行include或者require来载入该类,然后程序继续执行,如果这个路径下不存在该文件时就提示错误。
    使用自动载入的魔术函数可以不必要写很多个include或者require函数。

    四:ThinkPHP部分

    返回顶部

    1、常见的PHP框架

    答:thinkPHP、yii、ZendFramework、CakePhp、sy

    2、如何理解TP中的单一入口文件?

    答:ThinkPHP采用单一入口模式进行项目部署和访问,无论完成什么功能,一个项目都有一个统一(但不一定是唯一)的入口。应该说,所有项目都是从入口文件开始的,并且所有的项目的入口文件是类似的,入口文件中主要包括:
    定义框架路径、项目路径和项目名称(可选)
    定义调试模式和运行模式的相关常量(可选)
    载入框架入口文件(必须)

    3、ThinkPHP中的MVC分层是什么?(理解)

    答:MVC 是一种将应用程序的逻辑层和表现层进行分离的方法。ThinkPHP 也是基于MVC设计模式的。MVC只是一个抽象的概念,并没有特别明确的规定,ThinkPHP中的MVC分层大致体现在:
    模型(M):模型的定义由Model类来完成。
    控制器(C):应用控制器(核心控制器App类)和Action控制器都承担了控制器的角色,Action控制器完成业务过程控制,而应用控制器负责调度控制。
    视图(V):由View类和模板文件组成,模板做到了100%分离,可以独立预览和制作。
    但实际上,ThinkPHP并不依赖M或者V ,也就是说没有模型或者视图也一样可以工作。甚至也不依赖C,这是因为ThinkPHP在Action之上还有一个总控制器,即App控制器,负责应用的总调度。在没有C的情况下,必然存在视图V,否则就不再是一个完整的应用。
    总而言之,ThinkPHP的MVC模式只是提供了一种敏捷开发的手段,而不是拘泥于MVC本身。

    4、如何进行SQL优化?(关于后边的解释同学们可以进行理解,到时根据自己的理解把大体意思说出来即可)

    答:(1)选择正确的存储引擎
    以 MySQL为例,包括有两个存储引擎 MyISAM 和 InnoDB,每个引擎都有利有弊。
    MyISAM 适合于一些需要大量查询的应用,但其对于有大量写操作并不是很好。甚至你只是需要update一个字段,整个表都会被锁起来,而别的进程,就算是读进程都无法操作直到读操作完成。另外,MyISAM 对于 SELECT COUNT(*) 这类的计算是超快无比的。
    InnoDB 的趋势会是一个非常复杂的存储引擎,对于一些小的应用,它会比 MyISAM 还慢。但是它支持“行锁” ,于是在写操作比较多的时候,会更优秀。并且,他还支持更多的高级应用,比如:事务。
    (2)优化字段的数据类型
    记住一个原则,越小的列会越快。如果一个表只会有几列罢了(比如说字典表,配置表),那么,我们就没有理由使用 INT 来做主键,使用 MEDIUMINT, SMALLINT 或是更小的 TINYINT 会更经济一些。如果你不需要记录时间,使用 DATE 要比 DATETIME 好得多。当然,你也需要留够足够的扩展空间。
    (3)为搜索字段添加索引
    索引并不一定就是给主键或是唯一的字段。如果在你的表中,有某个字段你总要会经常用来做搜索,那么最好是为其建立索引,除非你要搜索的字段是大的文本字段,那应该建立全文索引。
    (4)避免使用Select *从数据库里读出越多的数据,那么查询就会变得越慢。并且,如果你的数据库服务器和WEB服务器是两台独立的服务器的话,这还会增加网络传输的负载。即使你要查询数据表的所有字段,也尽量不要用*通配符,善用内置提供的字段排除定义也许能给带来更多的便利。
    (5)使用 ENUM 而不是 VARCHAR
    ENUM 类型是非常快和紧凑的。在实际上,其保存的是 TINYINT,但其外表上显示为字符串。这样一来,用这个字段来做一些选项列表变得相当的完美。例如,性别、民族、部门和状态之类的这些字段的取值是有限而且固定的,那么,你应该使用 ENUM 而不是 VARCHAR。
    (6)尽可能的使用 NOT NULL
    除非你有一个很特别的原因去使用 NULL 值,你应该总是让你的字段保持 NOT NULL。 NULL其实需要额外的空间,并且,在你进行比较的时候,你的程序会更复杂。 当然,这里并不是说你就不能使用NULL了,现实情况是很复杂的,依然会有些情况下,你需要使用NULL值。
    (7)固定长度的表会更快
    如果表中的所有字段都是“固定长度”的,整个表会被认为是 “static” 或 “fixed-length”。 例如,表中没有如下类型的字段: VARCHAR,TEXT,BLOB。只要你包括了其中一个这些字段,那么这个表就不是“固定长度静态表”了,这样,MySQL 引擎会用另一种方法来处理。
    固定长度的表会提高性能,因为MySQL搜寻得会更快一些,因为这些固定的长度是很容易计算下一个数据的偏移量的,所以读取的自然也会很快。而如果字段不是定长的,那么,每一次要找下一条的话,需要程序找到主键。
    并且,固定长度的表也更容易被缓存和重建。不过,唯一的副作用是,固定长度的字段会浪费一些空间,因为定长的字段无论你用不用,他都是要分配那么多的空间。

    5、如何理解 ThinkPHP 3.0 架构三(核心 + 行为 + 驱动)中的行为?

    答:核心 + 行为 + 驱动
    TP官方简称为:CBD
    核心(Core):就是框架的核心代码,不可缺少的东西,TP本身是基于MVC思想开发的框架。
    行为(Behavior) :行为在新版ThinkPHP的架构里面起着举足轻重的作用,在系统核心之上,设置了很多标签扩展位,而每个标签位置可以依次执行各自的独立行为。行为扩展就因此而诞生了,而且很多系统功能也是通过内置的行为扩展完成的,所有行为扩展都是可替换和增加的,由此形成了底层框架可组装的基础。
    驱动( Driver ):数据库驱动、缓存驱动、标签库驱动和模板引擎驱动,以及外置的类扩展。
    框架,即framework。其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。而且,框架一般是成熟的,不断升级的软件。

    6、什么是惯例配置?

    答:惯例配置上一页下一页惯例重于配置是系统遵循的一个重要思想,系统内置有一个惯例配置文件(位于系统目录下面的Conf\convention.php),按照大多数的使用对常用参数进行了默认配置。所以,对应用项目的配置文件,往往只需要配置和惯例配置不同的或者新增的配置参数,如果你完全采用默认配置,甚至可以不需要定义任何配置文件。
    惯例配置文件会被系统自动加载,无需在项目中进行加载。

    7、什么是SQL注入?(理解)

    答:SQL注入攻击是黑客对数据库进行攻击的常用手段之一。一部分程序员在编写代码的时候,没有对用户输入数据的合法性进行判断,注入者可以在表单中输入一段数据库查询代码并提交,程序将提交的信息拼凑生成一个完整sql语句,服务器被欺骗而执行该条恶意的SQL命令。注入者根据程序返回的结果,成功获取一些敏感数据,甚至控制整个服务器,这就是SQL注入。

    8、ThinkPHP如何防止SQL注入?(理解)

    答:(1)查询条件尽量使用数组方式,这是更为安全的方式;
    (2)如果不得已必须使用字符串查询条件,使用预处理机制;
    (3)开启数据字段类型验证,可以对数值数据类型做强制转换;(3.1版本开始已经强制进行字段类型验证了)
    (4)使用自动验证和自动完成机制进行针对应用的自定义过滤;
    (5)使用字段类型检查、自动验证和自动完成机制等避免恶意数据的输入。

    9、如何开启调试模式?调试模式有什么好处?

    答:开启调试模式很简单,只需要在入口文件中增加一行常量定义代码:

     

     

     

    开启调试模式

     

     

     

     
     

     

     

     

    开启调试模式

    在完成开发阶段部署到生产环境后,只需要删除调试模式定义代码即可切换到部署模式。开启调试模式后,系统会首先加载系统默认的调试配置文件,然后加载项目的调试配置文件,调试模式的优势在于: 开启日志记录,任何错误信息和调试信息都会详细记录,便于调试; 关闭模板缓存,模板修改可以即时生效; 记录SQL日志,方便分析SQL; 关闭字段缓存,数据表字段修改不受缓存影响; 严格检查文件大小写(即使是Windows平台),帮助你提前发现Linux部署问题; 可以方便用于开发过程的不同阶段,包括开发、测试和演示等任何需要的情况,不同的应用模式可以配置独立的项目配置文件。

    10、TP中支持哪些配置模式?优先级?

    答:ThinkPHP在项目配置上面创造了自己独有的分层配置模式,其配置层次体现在: 惯例配置->项目配置->调试配置->分组配置->扩展配置->动态配置
    以上是配置文件的加载顺序,因为后面的配置会覆盖之前的同名配置(在没有生效的前提下),所以优先顺序从右到左。

    11、TP中的URL模式有哪几种?默认是哪种?

    答:ThinkPHP支持四种URL模式,可以通过设置URL_MODEL参数来定义,包括普通模式、PATHINFO、REWRITE和兼容模式。
    默认模式为:PATHINFO模式,设置URL_MODEL 为1

    12、TP中系统变量有哪些?如何获取系统变量?

    答:获取系统变量的方法:
    只需要在Action中调用下面方法:
    $this->方法名(“变量名”,[“过滤方法”],[“默认值”])

    13、ThinkPHP框架中D函数与M函数的区别是什么?

    答:M方法实例化模型无需用户为每个数据表定义模型类,D方法可以自动检测模型类,如果存在自定义的模型类,则实例化自定义模型类,如果不存在,则会自动调用M方法去实例化Model基类。同时对于已实例化过的模型,不会重复去实例化(单例模式)。

    五:smarty模板引擎

    返回顶部

    1、编译和缓存区别?

    smarty的编译过程就是把模板拿过来,把里面的标签替换成相应php代码,这就是smarty的编译, 其实就是php和html混合的过程
    smarty的缓存需要手动开启,smarty的缓存就是把编译好的文件执行后,同时生成一份静态的html页面,再次访问的时候,你访问的就是是html文件了,所以就效率来说,要高一些

    2、什么是smarty? Smarty的优点是什么?

    Smarty是一个使用PHP写出来的PHP模板引擎,目的是要使用PHP程序同美工分离,使的程序员改变程序的逻辑内容时不会影响到美工的页面设计,美工重新修改页面时不会影响到程序的程序逻辑,这在多人合作的项目中显的尤为重要。(也易于程序的多样式开发)
    Smarty优点
    1. 速度快:相对其他模板引擎。
    2. 编译型:采用smarty编写的程序在运行时要编译成一个非模板技术的PHP文件
    3. 缓存技术:它可以将用户最终看到的HTML文件缓存成一个静态的HTML页
    4. 插件技术:smarty可以自定义插件。
    不适合使用smarty的地方
    1. 需要实时更新的内容。例如像股票显示,它需要经常对数据进行更新
    2. 小项目。小项目因为项目简单而美工与程序员兼于一人的项目

    3、在模板中使用{$smarty}保留变量

     

     

    4. 在模板中访问php中的变量

    在php脚本中有系统常量和自定义常量两种,同样这两种常量在Smarty模板中也可以被访问,而且不需要从php中分配,只要通过{$smarty}保留变量就可以直接输出常量的值。在模板中输出常量的示例:

     

     

    5、变量调解器

     

     

     

    变量调解器

     

     

     

     
     

     

     

     

    变量调解器

    6、php查询mysql数据库时,查询中文结果时出现的乱码。怎么解决?

    1. 文件属性(另存为)
    2.文件meta(设置浏览器解析的时候)
    3. 连接数据库时编码设定
    4. PHP文件中使用header函数确定编码

    7、缓存机制

    如果开启了缓存,smarty同时生成一份静态的html页面,如果在设定的时间没有过期,再次访问的时候,你访问的就是是html文件了,减少了读取数据库,所以就效率来说,要高一些。

    8、smarty的赋值和载入模板

     

     

    9、marty模板技术的用途是什么?

    为了php与html分开,美工和程序员各司其职,互不干扰。

    10、smarty配置主要有哪几项?

    1. 引入smarty.class.php;
    2. 实例化smarty对象;
    3. 重新修改默认的模板路径;
    4. 重新修改默认的编译后文件的路径;
    5. 重新修改默认的配置文件的路径;
    6. 重新修改默认的cache的路径。
    7. 可以设置是否开启cache。
    8. 可以设置左侧和右侧定界符。

    11、smarty在使用过程中需要注意哪些细节?

    Smarty是基于MVC概念的一种模板引擎,它将一个页面程序分成了两部分来实现:即视图层和控制层,
    也就是说smarty技术将用户UI与php代码分离开。
    这样程序员和美工各司其职,互不干扰。

    12、smarty运用过程中要注意以下几个问题:

    1.正确配置smarty。主要要实例化smarty对象,配置smarty模板文件的路径;
    2.php页面中使用assign赋值 和display显示页面;
    3.smarty模板文件中不允许出现php代码段,所有的注释,变量,函数都要包含在定界符内。
    A.{}
    B. foreach
    C. if else
    D. include
    E. Literal

    六、二次开发系统(DEDE、ecshop)

    返回顶部

    1、对二次开发的理解

    二次开发,简单的说就是在现有的软件上进行定制修改,功能的扩展,然后达到自己想要的功能,一般来说都不会改变原有系统的内核。

    2、MVC

    Model(模型)数据处理。
    View(视图) 模板显示。
    Controller(控制器) 控制流程。
    MVC的概念是什么?各层主要做什么工作?
    MVC(即模型-视图-控制器)是一种软件设计模式或者说编程思想。
    M指Model模型层,V是View视图层(显示层或者用户界面),C是Controller控制器层。
    使用mvc的目的是实现M和V分离,从而使得一个程序可以轻松使用不同的用户界面。
    在网站开发中,
    模型层一般负责对数据库表信息进行增删改查,
    视图层负责显示页面内容,
    控制器层在M和V之间起到调节作用,控制器层决定调用哪个model类的哪个方法,
    执行完毕后由控制器层决定将结果assign到哪个view层。

    3、二次开发程序安装后访问时候出现一些警告以及错误

    根据错误,来修改服务器配置参数以及百度

    4、功能,模板的更换,功能的添加修改

    其实也就是面向对象的应用 用,以及模板的更换类似smarty的使用

    5、用过哪些二次开发的东西?

    Dedecms phpcms ecshop,基本这些的东西如果基础好了 学习起来都是没问题的。

    6、像php做一次开发好,还是二次开发好?

    一般中小企业都用cms系统二次开发,都是为了效率。当然如果想一次开发也行,会用框架而且时间充足的话就可以了,大企业都是团队来开发的,杜绝版权问题。

    7、二次开发过程中很多类与类之间进行之间的方法访问,是通过什么方式传递的?

    不是类继承而是对象组合,把实例化好的对象通过global传递进去

    8、dedecms如果更换目录,后台某项就进不去了如何解决?

    后台核心设置中修改成现在的 项目目录名称

    9、dedecms中自定义模型的理解?

    在织梦系统中有内容模型这个概念,不同内容模型可以用来构建不同内容形式的站点,在系统中自带了以下几种模型:普通文章、图集、软件、商品、分类信息、专题。通过系统自带的模型,我们可以用来构建不同类型的站点,例如:使用图集可以做一个图片站,用软件模型构建一个软件下载站点。
    当然以上随系统附带的模型被称为系统模型,用户可以自己定义一些模型,比如图书、音乐专辑等,自定义了这些模型才可以构建更多内容形式的站点。
    相当于我们自动添加了表结构,适应现在当前需求的变化

    10、dede中概念,设计和使用模板,必须要理解下面几个概念

    1. 板块(封面)模板:
    指网站主页或比较重要的栏目封面频道使用的模板,一般用“index_识别ID.htm”命名,此外,用户单独定义的单个页面或自定义标记,也可选是否支持板块模板标记,如果支持,系统会用板块模板标记引擎去解析后才输出内容或生成特定的文件。
    2. 列表模板:
    指网站某个栏目的所有文章列表的模板,一般用 “list_识别ID.htm” 命名。
    3. 档案模板:
    表示文档查看页的模板,如文章模板,一般用 “article_识别ID.htm” 命名。
    4. 其它模板:
    一般系统常规包含的模板有:主页模板、搜索模板、RSS、JS编译功能模板等,此外用户也可以自定义一个模板创建为任意文件。

    11、dede中几种标签的使用?

    列表 内容 等标签 只能在其本范围内使用,列表标签只能在列表中使用,内容标签只能在内容标签中使用。
    全局标签能在所有页面中使用

    12、熟悉常用类库

    (例如:dedesql.class.php);熟悉系统函数库(common.func.php);熟悉自定义函数库(extend.func.php);熟悉前台入口文件(common.inc.php)

    七、微信公众平台开发

    返回顶部

    1、微信运行机制

    公众号与php之间用什么语言通信:Xml
    Weixin.php中是如何接收公众号数据的:

     

     

    2、消息类型

    微信目前提供了7种基本消息类型,分别为:
    (1)文本消息(text);
    (2)图片消息(image);
    (3)语音(voice)
    (4)视频(video)
    (5)地理位置(location);
    (6)链接消息(link);
    (7)事件推送(event)
    类型。掌握不同的消息类型发送时的数据传递格式

    3、将整个文件读入一个字符串的函数是

    File_get_contents

    4、常用函数

    把xml数据解析成对象的函数是
    simplexml_load_string( )
    将字符串转换为数组的函数是___ explode_________,将数组转化为字符串的函数是____implode________.
    编码 URL 字符串的字符串是____urlencode________.

    5、Sprintf函数的作用

    这个都是可以查手册的。

    6、微信公众号出现无法提供服务的原因?

    (1)网络原因 ,数据接口原因
    (2)代码错误,怎么推测原因
    修改的哪里检查一下,如果代码没错
    可以输出数据 看一下。用php操作文件

     

     

    7、自定义菜单的事件推送

    单击
    单击跳转链接
    扫码推事件
    扫码推且弹出
    弹出系统拍照发图的事件
    弹出微信相册发图器的事件
    弹出地理位置选择器的事件

    8、token的作用

    安全机制验证,用于微信服务器与PHP服务器之间的安全验证

    9、Appid与secrect的作用

    请求api接口(例如菜单的操作)时需要传appid与secrect两个值,用来获取应用的授权码

    八、对于自身掌握的技术描述

    返回顶部
    1、以PHP+MYSQL为方向,熟练掌握smarty模板引擎、ThinkPHP框架、微信公众平台开发、DEDE、ecshop等二次开发系统,对面向对象有一定的理解;数据库方面,熟练掌握MYSQL、MSSQL等数据库;熟悉在linux下的PHP开发
    2、前端技术:熟练掌握DIV+CSS网页布局,javascript,JQuery框架、AJAX技术、photoshop图片处理
    3、一年的项目开发经验,使用smarty开发过‘XXXXXXXX’,ThinkPHP开发过‘XXXXXXXX’,使用微信公众平台开发过‘就业服务网’的公众号,使用织梦系统开发过企业站等

     

     

     

  • 怎么书写高质量 SQL ?

    1.查询SQL尽量不要使用select ,而是select具体字段。

    2. where子句比较符号左侧避免函数

    尽量避免在where条件子句中,比较符号的左侧出现表达式、函数等操作。因为这会导致数据库引擎进行全表扫描,从而增加运行时间。

    举个例子,下图是10名学生的成绩表,老师突然发现因为参考答案出错,给所有人都少加了5分,现在需要查询:给每人加5分后,成绩依然在90分以上的同学的学号。

    按照题目的思路直接书写,“给每人加5分后,成绩90分以上”的条件很多人会这样写:

    where 成绩 + 5 > 90 (表达式在比较符号的左侧)

    优化方法:

    where 成绩 > 90 – 5(表达式在比较符号的右侧)

    所以,为了提高效率,where子句中遇到函数或加减乘除的运算,应当将其移到比较符号的右侧。

    3.尽量避免使用or

    or同样会导致数据库进项全表搜索。在工作中,如果你只想用or从几十万语句中取几条出来,是非常划不来的,怎么办呢?下面的方法可替代or。

    从成绩表中选出成绩是是88分或89分学生的学号:

    select 学号

    from 成绩表

    where 成绩 = 88 or 成绩 = 89

    优化后:

    select 学号 from 成绩表 where 成绩 = 88

    union

    select 学号 from 成绩表 where 成绩 = 89

    语句虽然变长了一点,但处理大量数据时,可以省下很多时间,是非常值得的。

    4.优化limit分页

    //方案一 :返回上次查询的最大记录(偏移量)
    select id,name from employee where id>10000 limit 10.
    
    //方案二:orderby + 索引
    select id,name from employee order by id limit 10000,10
    

    5、优化你的like语句

    select userId,name from user where userId like'123%';
    

    6、使用where条件限定要查询的数据,避免返回多余的行

    Long userId = sqlMap.queryObject("select userId from user where userId='userId' and isVip='1'")
    boolean isVip = userId!=null;
    

    7.尽量避免在索引列上使用mysql的内置函数

    explain select userId,loginTime from loginuser where  loginTime >= Date_ADD(NOW(),INTERVAL - 7DAY);
    

    8.应尽量避免在 where 子句中对字段进行表达式操作,这将导致系统放弃使用索引而进行全表扫

    select * from user where age =11;
    

    9.Inner join 、left join、right join,优先使用Inner join,如果是left join,左边表结果尽量小

    • Inner join 内连接,在两张表进行连接查询时,只保留两张表中完全匹配的结果集
    • left join 在两张表进行连接查询时,会返回左表所有的行,即使在右表中没有匹配的记录。
    • right join 在两张表进行连接查询时,会返回右表所有的行,即使在左表中没有匹配的记录。
    select * from (select * from tab1 where id >2) t1 left join tab2 t2 on t1.size = t2.size;
    

    10、如果插入数据过多,考虑批量插入。

    //一次500批量插入,分批进行
    insert into user(name,age) values
    <foreach collection="list" item="item" index="index" separator=",">
        (#{item.name},#{item.age})
    </foreach>
    

    11、不要有超过5个以上的表连接

    • 连表越多,编译的时间和开销也就越大。
    • 把连接表拆开成较小的几个执行,可读性更高。
    • 如果一定需要连接很多表才能得到数据,那么意味着糟糕的设计了。

    12、尽可能使用varchar/nvarchar 代替 char/nchar。

    `deptName` varchar(100) DEFAULT NULL COMMENT '部门名称'
    

    13、如何字段类型是字符串,where时一定用引号括起来,否则索引失效

    select * from user where userid ='123';
    

    14.使用explain 分析你SQL的计划

    explain select * from user where userid =10086 or age =18;
    

    15、使用联合索引时,注意索引列的顺序,一般遵循最左匹配原则。

    16、避免频繁创建和删除临时表,以减少系统表资源的消耗。

    17、临时表并不是不可使用,适当地使用它们可以使某些例程更有效,例如,当需要重复引用大型表或常用表中的某个数据集时。但是,对于一次性事件,最好使用导出表。    

    18、在新建临时表时,如果一次性插入数据量很大,那么可以使用 select into 代替 create table,避免造成大量 log ,以提高速度;如果数据量不大,为了缓和系统表的资源,应先 create table,然后 insert。

    19、如果使用到了临时表,在存储过程的最后务必将所有的临时表显式删除,先 truncate table ,然后 drop table ,这样可以避免系统表的较长时间锁定。

    20、尽量避免使用游标,因为游标的效率较差,如果游标操作的数据超过 1 万行,那么就应该考虑改写。       

    21、使用基于游标的方法或临时表方法之前,应先寻找基于集的解决方案来解决问题,基于集的方法通常更有效。

    22、与临时表一样,游标并不是不可使用。对小型数据集使用 FAST_FORWARD 游标通常要优于其他逐行处理方法,尤其是在必须引用几个表才能获得所需的数据时。在结果集中包括“合计”的例程通常要比使用游标执行的速度快。如果开发时间允许,基于游标的方法和基于集的方法都可以尝试一下,看哪一种方法的效果更好。

    23、尽量避免大事务操作,提高系统并发能力。

    24、尽量避免向客户端返回大数据量,若数据量过大,应该考虑相应需求是否合理。

  • 电商系统产品上架素材分类素材,适用系统演示

    分享一份电商系统产品上架素材图,含一级二级分类(分类图片随便截取的,不喜勿喷哈)。
    PS:素材图来源于天猫,淘宝。请勿商用,以免引起商业纠纷。

    素材获取方式:扫码关注 百讯生活馆 ,回复关键字‘商品素材’即可获取。如遇到图片不显示,请将地址栏https改为http 后访问。

    如果素材不满足你的需求,可以关注后回复关键字‘产品采集’获取产品主图采集器。

    采集器示例:

    素材示例:





  • MySQL5.6 执行sql报错:[Err] 1293 – Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause

    [Err] 1293 – Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause
    字面翻译:不正确的表定义;在DEFAULT或ON UPDATE子句中只能有一个带有CURRENT_TIMESTAMP的时间戳列

    执行如下sql:报错

     CREATE TABLE `tb_itemcode_list` (
      `tbid` int(11) unsigned NOT NULL AUTO_INCREMENT,
      `itemcode` varchar(100) NOT NULL COMMENT '商品编码',
      `number` int(20) NOT NULL DEFAULT '0' COMMENT '数量',
      `remark` text COMMENT '备注',
      `createtime` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP,
      `edit_time` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
      `warehouse_id` int(10) DEFAULT NULL,
      `position_id` int(10) DEFAULT NULL,
      PRIMARY KEY (`tbid`)
    ) ENGINE=InnoDB AUTO_INCREMENT=456 DEFAULT CHARSET=utf8;
    

    表中出现多个timestamp并设置为current_timestamp的时候报错

     Incorrect table definition; there can be only oneTIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATEclause

    原因是当你给一个timestamp设置为on updatecurrent_timestamp的时候,其他的timestamp字段需要显式设定default值

    但是如果你有两个timestamp字段,但是只把第一个设定为current_timestamp而第二个没有设定默认值,MySQL能成功建表,但是反过来就不行。

     修改后:成功执行

     CREATE TABLE `tb_itemcode_list` (
      `tbid` int(11) unsigned NOT NULL AUTO_INCREMENT,
      `itemcode` varchar(100) NOT NULL COMMENT '商品编码',
      `number` int(20) NOT NULL DEFAULT '0' COMMENT '数量',
      `remark` text COMMENT '备注',
      `createtime` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP,
      `edit_time` timestamp NULL DEFAULT NULL,  -- 去除了 ON UPDATE CURRENT_TIMESTAM
      `warehouse_id` int(10) DEFAULT NULL,
      `position_id` int(10) DEFAULT NULL,
      PRIMARY KEY (`tbid`)
    ) ENGINE=InnoDB AUTO_INCREMENT=456 DEFAULT CHARSET=utf8;
    
    或:
    CREATE TABLE `tb_itemcode_list` (
      `tbid` int(11) unsigned NOT NULL AUTO_INCREMENT,
      `itemcode` varchar(100) NOT NULL COMMENT '商品编码',
      `number` int(20) NOT NULL DEFAULT '0' COMMENT '数量',
      `remark` text COMMENT '备注',
      `createtime` datetime NOT NULL COMMENT '创建时间',
      `edit_time` timestamp not null default CURRENT_TIMESTAMP COMMENT '编辑时间', 
      `warehouse_id` int(10) DEFAULT NULL,
      `position_id` int(10) DEFAULT NULL,
      PRIMARY KEY (`tbid`)
    ) ENGINE=InnoDB AUTO_INCREMENT=456 DEFAULT CHARSET=utf8;
    
    
  • 2009年至2019年中级软件设计师考题真题汇总

    点击以下链接下载真题

    历年 软件设计师 一星级试题[真题]( 2018年 至 2014年 )

    资料来源:软考在线   参考答案请在 软考在线 智能真题库 免费开通题库 查看   点我登录  

    2009年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2009年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2010年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2010年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2011年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2011年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2012年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2012年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2013年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2013年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2014年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2014年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2015年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2015年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2016年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2016年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2017年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2017年下半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2018年上半年 软件设计师 上午试卷 综合知识[真题](标准版)
    2018年下半年 软件设计师 上午试卷 综合知识[真题](标准版)

    资料来源:软考在线   参考答案请在 软考在线 智能真题库 免费开通题库 查看   点我登录  

    2009年上半年 软件设计师 下午试卷 案例[真题]
    2009年下半年 软件设计师 下午试卷 案例[真题]
    2010年上半年 软件设计师 下午试卷 案例[真题]
    2010年下半年 软件设计师 下午试卷 案例[真题]
    2011年上半年 软件设计师 下午试卷 案例[真题]
    2011年下半年 软件设计师 下午试卷 案例[真题]
    2012年上半年 软件设计师 下午试卷 案例[真题]
    2012年下半年 软件设计师 下午试卷 案例[真题]
    2013年上半年 软件设计师 下午试卷 案例[真题]
    2013年下半年 软件设计师 下午试卷 案例[真题]
    2014年上半年 软件设计师 下午试卷 案例[真题]
    2014年下半年 软件设计师 下午试卷 案例[真题]
    2015年上半年 软件设计师 下午试卷 案例[真题]
    2015年下半年 软件设计师 下午试卷 案例[真题]
    2016年上半年 软件设计师 下午试卷 案例[真题]
    2016年下半年 软件设计师 下午试卷 案例[真题]
    2017年上半年 软件设计师 下午试卷 案例[真题]
    2017年下半年 软件设计师 下午试卷 案例[真题]
    2018年上半年 软件设计师 下午试卷 案例[真题]
    2018年下半年 软件设计师 下午试卷 案例[真题]
    2019年上半年 软件设计师 下午试卷 案例[真题]

    资料来源:软考在线   参考答案请在 软考在线 智能真题库 免费开通题库 查看   点我登录  

     

  • 使用FlashFXP和FileZilla下载文件后出现代码换行的问题解决方案

    解决问题的核心关键词“二进制”

    能造成代码换行的问题其实是因为这两款问题里的传输模式导致的,跟你的服务器以及控制面板是WDCP或者宝塔一点关系也没有!

    FlashFXP的解决步骤

    • 打开FlashFXP > 选项 > 参数选择 > 传输 > 传输模式选择“二进制(图像)” > 应用and确定

    为了保全起见,把文件传输规则(也在选项的下拉)里的【只有续传文件才以二进制模式传输】前的勾取消掉

    FileZilla的解决步骤

    • 打开FileZilla,设置 > 传输 > FTP:文件类型 > 默认传输模式 > 二进制(B) > 确定
      原先FileZilla是把这些重要文件用ASCII 模式传输的,就会唇出现换行问题。

    FTP有ASCII和Binary(二进制)两种传输模式:
    Binary模式不会对数据进行任何处理。
    Ascii模式会将回车换行转换为本机的回车字符。

    转载:https://blog.csdn.net/weilapls/article/details/82185443
  • PHP判断是否在微信内部浏览器访问

    <?php

    if(is_weixin()){

    echo "这是微信内部浏览器";

    }else{

    echo "这是微信外部浏览器";

    }

    function is_weixin(){ 
       if ( strpos($_SERVER[‘HTTP_USER_AGENT’], 'MicroMessenger') !== false ) {

            return true;

       }else{

            return false;

      }

    }

    ?>

  • PHP实现的敏感词过滤方法示例[转]

     

    本文实例讲述了PHP实现的敏感词过滤方法。分享给大家供大家参考,具体如下:

    1、敏感词过滤方法

    /** 
     * @todo 敏感词过滤,返回结果 
     * @param array $list  定义敏感词一维数组 
     * @param string $string 要过滤的内容 
     * @return string $log 处理结果 
     */
    function sensitive($list, $string){ 
      $count = 0; //违规词的个数 
      $sensitiveWord = '';  //违规词 
      $stringAfter = $string;  //替换后的内容 
      $pattern = "/".implode("|",$list)."/i"; //定义正则表达式 
      if(preg_match_all($pattern, $string, $matches)){ //匹配到了结果 
        $patternList = $matches[0];  //匹配到的数组 
        $count = count($patternList); 
        $sensitiveWord = implode(',', $patternList); //敏感词数组转字符串 
        $replaceArray = array_combine($patternList,array_fill(0,count($patternList),'*')); //把匹配到的数组进行合并,替换使用 
        $stringAfter = strtr($string, $replaceArray); //结果替换 
      } 
      $log = "原句为 [ {$string} ]<br/>"; 
      if($count==0){ 
        $log .= "暂未匹配到敏感词!"; 
      }else{ 
        $log .= "匹配到 [ {$count} ]个敏感词:[ {$sensitiveWord} ]<br/>". 
          "替换后为:[ {$stringAfter} ]"; 
      } 
      return $log; 
    }

    2、调用方法

    function testAction(){ 
      $string = 'likeyou小白喜欢小黑爱着的大黄'; //要过滤的内容 
      $list = ['小明', '小红', '大白', '小白', '小黑', 'me', 'you'];  //定义敏感词数组 
      $result = $this->sensitive($list, $string); 
      echo ($result); 
      die; 
      //打印结果: 
      /* 
      原句为 [ likeyou小白喜欢小黑爱着的大黄 ] 
      匹配到 [ 3 ]个敏感词:[ you,小白,小黑 ] 
      替换后为:[ like**喜欢*爱着的大黄 ] 
        */
    }