企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持知识库和私有化部署方案 广告
**1.** **什么事面向对象?主要特征是什么?** 面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰。主要特征:封装、继承、多态。 **2.** **SESSION** **与** **COOKIE的区别是什么,请从协议,产生的原因与作用说明?** 1、http无状态协议,不能区分用户是否是从同一个网站上来的,同一个用户请求不同的页面不能看做是同一个用户。 2、SESSION存储在服务器端,COOKIE保存在客户端。Session比较安全,cookie用某些手段可以修改,不安全。Session依赖于cookie进行传递。 禁用cookie后,session不能正常使用。\*\*Session\*\*\*\*的缺点:\*\*保存在服务器端,每次读取都从服务器进行读取,对服务器有资源消耗。Session保存在服务器端的文件或数据库中,默认保存在文件中,文件路径由php配置文件的session.save\_path指定。Session文件是公有的。 **3.** **HTTP** **状态中302、403、** **500\*\*\*\*代码含义?** 一二三四五原则: 一. 消息系列  二成功系列      三. 重定向系列四. 请求错误系列      五. 服务器端错误系列 302:临时转移成功,请求的内容已转移到新位置403:禁止访问 500:服务器内部错误 401代表未授权。 **4.** **Linux\*\*\*\*下建立压缩包,解压缩包的命令** Tar.gz: 打包:tar czf file.tar.gz file.txt 解压:tar xzf file.tar.gz Bz2: 打包:bzip2 \[-k\]  文件 解压:bunzip2 \[-k\] 文件 Gzip(只对文件,不保留原文件) 打包:gzip file1.txt 解压:gunzip file1.txt.gz Zip: -r 对目录 打包:zip file1.zip file1.txt 解压:unzip file1.zip **5.** **请写出数据类型**\*\*(int char varchar datetime text)**的意思;请问 varchar 和 char\*\*有什么区别?** Int 整数char 定长字符 Varchar 变长字符 Datetime 日期时间型Text 文本型 **Varchar与char\*\*\*\*的区别** char是固定长度的字符类型,分配多少空间,就占用多长空间。Varchar是可变长度的字符类型,内容有多大就占用多大的空间,能有效节省空间。由于varchar类型是可变的,所以在数据长度改变的时,服务器要进行额外的操作,所以效率比char类型低。 **6.** **MyISAM\*\*\*\*和** **InnoDB** **的基本区别?索引结构如何实现?** MyISAM类型不支持事务,表锁,易产生碎片,要经常优化,读写速度较快,而InnoDB类型支持事务,行锁,有崩溃恢复能力。读写速度比MyISAM慢。 创建索引:alerttable tablename add index (`字段名`) **7.** **不使用cookie向客户端发送一个\*\*\*\*cookie.** 理解:session\_start()开启时,生成一个常量 SID,当COOKIE开启时,这个常量为空,当COOKIE关闭时,这个常量中存储了PHPSESSID的值。通过在URL后加一个SID参数来传递SESSIONID的值,从而使客户端页面可以使用SESSION里面的值。当客户端开启COOKIE和服务器端开启SESSION时。浏览器第一次请求,服务器会向浏览器端发送一个COOKIE里面存储SESSIONID.当浏览器第二次请求时,会把已存在 8\. **isset()** **和** **empty()** **区别** Isset判断变量是否存在,可以传入多个变量,若其中一个变量不存在则返回假,empty判断变量是否为空为假,只可传一个变量,如果为空为假则返回真。 9\. **如何在页面之间传递变量**\*\*(**至少两种方式**) ?   \*\*GET,POST,COOKIE,SESSION,隐藏表单 **1.** **写出匹配URL的正则表达式**\*\*.\*\* ‘/^(https?|ftps?):\\/\\/(www)\\.(\[^\\.\\/\]+)\\.(com|cn|org)(\\/\[\\w-\\.\\/\\?\\%\\&\\=\]\*)?/i’ **2.** **请写出常见的排序算法,并用PHP实现冒泡排序,将数组**\*\*$a = array()\*\***按照从小到大的方式进行排序。** 常见的排序算法: 冒泡排序法、快速排序法、简单选择排序法、堆排序法、直接插入排序法、希尔排序法、合并排序法。 冒泡排序法的基本思想是:对待排序记录关键字从后往前(逆序)进行多遍扫描,当发现相邻两个关键字的次序与排序要求的规则不符时,就将这两个记录进行交换。这样,关键字较小的记录将逐渐从后面向前面移动,就象气泡在水中向上浮一样,所以该算法也称为气泡排序法。 // 冒泡排序法 Function mysort($arr){ For($i=0;$i<count($arr); $i++){ For($j=0; $j<count($arr)-1-$i; $j++){ If($arr\[$j\]> $arr\[$j+1\]){ $tmp=$arr\[$j\]; $arr\[$j\]=$arr\[$j+1\]; $arr\[$j+1\]=$tmp; } } } Return$arr; } $arr=array(3,2,1); print\_r(mysort($arr)); 3\. **请说明** **PHP** **中传值与传引用的区别。什么时候传值什么时候传引用?**         按值传递:函数范围内对值的任何改变在函数外部都会被忽略 按引用传递:函数范围内对值的任何改变在函数外部也能反映出这些修改 优缺点:按值传递时,php必须复制值。特别是对于大型的字符串和对象来说,这将会是一个代价很大的操作。按引用传递则不需要复制值,对于性能提高很有好处。 **在PHP中error\_reporting这个函数有什么作用?**         设置 PHP的报错级别并返回当前级别。 **请用正则表达式(Regular Expression)写一个函数验证电子邮件的格式是否正确。**if(isset($\_POST\['action'\]) && $\_POST\['action'\]==’submitted’){         $email=$\_POST\['email'\];         if(!preg\_match(“/^\[0-9a-zA-Z-\]+@\[0-9a-zA-Z-\]+(\\.\[0-9a-zA-Z-\]+){1,3}$/”,$email)){                  echo“电子邮件检测失败”;         }else{                  echo“电子邮件检测成功”;         }} **写一个二维数组排序算法函数,能够具有通用性,可以调用php内置函数**\*\*(array\_multisort())\*\* //二维数组排序, $arr是数据,$keys是排序的健值,$order是排序规则,1是升序,0是降序 function array\_sort($arr, $keys, $order=0) { if(!is\_array($arr)) { return false; } $keysvalue =array(); foreach($arr as$key => $val) { $keysvalue\[$key\] = $val\[$keys\]; } if($order == 0){ asort($keysvalue); }else { arsort($keysvalue); } reset($keysvalue); foreach($keysvalueas $key => $vals) { $keysort\[$key\] = $key; } $new\_array =array(); foreach($keysortas $key => $val) { $new\_array\[$key\] = $arr\[$val\]; } return $new\_array; } **请以空格作为间隔,拆分字符串**\*\*’**Apple Orange BananaStrawberry**’**,组成数组$fruit**,\*\* **\*** **数组中所有元素都用小写字母,并按照字母先后次序排序** class sort { private $str; public function\_\_construct($str) { $this->str=strtolower($str); } private functionexplodes() { if(empty($this->str)) returnarray(); $arr=explode("",$this->str); return is\_array($arr)?$arr:array($arr); } public functionsort() { $explode=$this->explodes(); sort($explode); return $explode; } } $str='Apple Orange Banana Strawberry'; $sortob=new sort($str); var\_dump($sortob->sort()); **对于用户输入一串字符串**\*\*$string,**要求**$string**中只能包含大于**0**的数字和英文逗号,请用正则**表达式验证,对于不符合要求的\*\*\*\*$string\*\*\*\*返回出错信息\*\* class regx { public staticfunction check($str) { if(preg\_match("/^(\[1-9,\])+$/",$str)){ return true; } return false; } } $str="12345,6"; if(regx::check($str)) { echo "suc"; } else { echo "fail"; } **windows平台, Apache Http Server启动失败,** **排错思路是什么**\*\*?\*\* 检查apache使用的80端口是否被占用,如果被占用,先停止占用80端口的服务,然后启动apache服务器 **PHP session扩展默认将session数据储存在哪里? D** A)  SQLite Database B)  MySQL Database C)  Shared Memory D)  File System E)  Session Server **如果你想要自动加载类,下面哪种函数声明是正确的\*\*\*\*C** A)  function autoload($class\_name) B)  function \_\_autoload($class\_name, $file) C)  function \_\_autoload($class\_name) D)  function \_autoload($class\_name) E)  function autoload($class\_name, $file) **PHP程序使用utf-8编码,** **以下程序输出结果是什么**\*\*? B\*\* <?php $str = ’hello你好世界’; echo strlen($str); ?> A) 9           B) 13(gbk) C) 18                   D) 17(utf8) **你所知道的php数组相关的函数?** array()----创建数组 array\_combine()----通过合并两个数组来创建一个新数组 range()----创建并返回一个包含指定范围的元素的数组 compact()----建立一个数组 array\_chunk()----将一个数组分割成多个 array\_merge()----把两个或多个数组合并成一个数组 array\_slice()----在数组中根据条件取出一段值 array\_diff()----返回两个数组的差集数组 array\_intersect()----计算数组的交集 array\_search()----在数组中搜索给定的值 array\_splice()----移除数组的一部分且替代它 array\_key\_exists()----判断某个数组中是否存在指定的key shuffle()----把数组中的元素按随机顺序重新排列 array\_flip()----交换数组中的键和值 array\_reverse()----将原数组中的元素顺序翻转,创建新的数组并返回 array\_unique()----移除数组中重复的值 **php\*\*\*\*读取文件内容的几种方法和函数?** 打开文件,然后读取。Fopen()fread() 打开读取一次完成file\_get\_contents() **以下程序,变量str什么值的情况下输入\*\*\*\*111?** **if( ! $str ) { echo 111; }** 在$str值为:0,’0′,false,null,”" **你所知道的PHP的一些技术(smarty等)?** Smarty,jquery,ajax,memcache,div+css,js,mysqli,pdo,svn,thinkphp,brophp,yii **你所熟悉的PHP论坛系统 有哪些?** Discuz **你所熟悉的PHP商城系统 有哪些?** Ecshop **你所熟悉的PHP开发框架 有哪些?** Brophp,thinkphp **说说你对缓存技术的了解?** 1、缓存技术是将动态内容缓存到文件中,在一定时间内访问动态页面直接调用缓存文件,而不必重新访问数据库。 2、使用memcache可以做缓存。 **你所知道的设计模式有哪些?** 工厂模式、策略模式、单元素模式、观察者模式、命令链模式 \*\*说说你对代码管理的了解?\*\***常使用那些代码版本控制软件?** 通常一个项目是由一个团队去开发,每个人将自己写好的代码提交到版本服务器,由项目负责人按照版本进行管理,方便版本的控制,提高开发效率,保证需要时可以回到旧版本。 常用的版本控制器:SVN **说说你对SVN的了解?优缺点?** SVN是一种版本控制器,程序员开发的代码递交到版本服务器进行集中管理。 SVN的优点:代码进行集中管理,版本控制容易,操作比较简单,权限控制方便。 缺点:不能随意修改服务器项目文件夹。 **怎么找到PHP.ini的路径?** 一般都在php的安装目录下,或者window系统的windows目录下。 **PHP加速模式/扩展? \*\*PHP调试模式**/\*\***工具?** Zend Optimizer加速扩展 调试工具:xdebug **你常用到的mysql命令?** Show databases Show tables Insert into 表名()values() Update 表名 set字段=值 where ... Delete from 表名where ... Select \* from 表名where 条件 order by ... Desc/asc limit ... Group by ... Having ... **进入mysql管理命令行的命令?** Mysql -uroot -p回车密码 **show databases;** **这个命令的作用?** 显示当前mysql服务器中有哪些数据库 **show create database mysql;** **这个命令的作用?** 显示创建数据库的sql语句 **show create table user;** **这个命令的作用?** 显示创建表的sql语句 **desc user;** **这个命令的作用?** 查询user表的结构 **explain select \* from user;** **这个命令的作用?** 获取select相关信息 **show processlist;** **这个命令的作用?** 显示哪些线程正在运行 **SHOW VARIABLES;** **这个命令的作用?** 显示系统变量和值 **SHOW VARIABLES like ’%conn%’;** **这个命令的作用?** 显示系统变量名包含conn的值 **LEFT JOIN** **写一个SQL语句?** [SELECTA.id](http://SELECTA.id),A.class FROM A LEFT JOIN B ON [A.cid=B.id](http://A.cid=B.id) **in, not ni, exist, not exist\*\*\*\*的作用和区别?** in在什么中 Not in 不在什么中 Exists 存在 Not exists 不存在 **怎么找到数据库的配置文件路径?** 在数据库安装目录下,my.ini **简述Linux下安装PHP的过程?** 安装软件之前先安装编译工具gcc、gcc-c++ 拷贝源码包,解包解压缩 Cd /lamp/php进入php目录 ./configure–prefix=/usr/local/php –with-config-file-path=/usr/local/php/etc指定安装目录和配置文件目录 Make 编译 Make install安装 **简述Linux下安装Mysql的过程?** Groupadd mysql 添加一个用户组mysql Useradd -gmysql mysql 添加一个mysql用户指定分组为mysql Cd /lamp/mysql 进入mysql目录 ./configure–prefix=/usr/local/mysql/ –with-extra-charsets=all Make Make all **简述Linux下安装apache的过程?** Cd /lamp/httpd 进去apache软件目录 ./configure–prefix=/usr/local/apache2/ –sysconfdir=/etc/httpd/ –with-included-apr Make Make all **HTML/CSS/DIV/Javascritp**\*\*:\*\* **1.** **设计一个页面**\*\*(4**个\*\* div \*\*第一个**div\*\* **宽\*\*\*\*960px** **居中**\*\*;**第**2-4**个**div  3**等分**960px;)\*\* Body{Text-align:center; Margin:0; Padding:0; } #box{Width:960px; Margin:0 auto; } .small{Width:320px; Float:left; } **用javascript取得一个input的值?取得一个input的属性?** document.getElementById(‘name’).value; document.getElementById(‘name’).type; **用Jquery取得一个input的值?取得一个input的属性?** $(“input\[name='aa'\]“).val(); $(“input\[name='aa'\]“).attr(‘type’); **请您写一段ajax提交的js代码,或者写出ajax提交的过程逻辑。** var xmlhttp; if(window.XMLHttpRquest){ xmlhttp=newXMLHttpRequest(); }elseif(window.ActiveXObject){ xmlhttp=newActiveXObject(‘Microsoft.XMLHTTP’); } xmlhttp.open(‘GET’,’1.php?aa=name’,true); xmlhttp.onreadystatechange=function(){ if(xmlhttp.readyState==4){ if(xmlhttp.status==200){ var text=xmlhttp.responseText; } } } xmlhttp.send(null); **简述Cookie的设置及获取过程** 设置COOKIE的值: Setcookie(名称,值,保存时间,有效域); 获取值:$\_COOKIE\['名称'\]; **面向对象中接口和抽象类的区别及应用场景**\*\*?\*\* 1、有抽象方法的类叫做抽象类,抽象类中不一定只有抽象方法,抽象方法必须使用abstract关键字定义。 2、接口中全部是抽象方法,方法不用使用abstract定义。 3、当多个同类的类要设计一个上层,通常设计为抽象类,当多个异构的类要设计一个上层,通常设计为接口。 **用面向对象来实现A对象继承B和C对象** Interface B{... } Interface C{... } Class Aimplements B,C{ ... }