php_0

1. session和cookie的区别

1、cookie数据存放在客户的浏览器上,session数据放在服务器上。
2、cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗 考虑到安全应当使用session。
3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能 考虑到减轻服务器性能方面,应当使用COOKIE。
4、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。
5、所以个人建议: 将登陆信息等重要信息存放为SESSION 其他信息如果需要保留,可以放在COOKIE中

2. MySQL优化

当MySQL数据量达到千万级,并发量大时,即使是简单的查询,MySQL的相应也会变慢,可以通过以下方式处理:
  1. 更换性能更好的硬件,加大内存
  2. 增加MySQL查询缓存与key缓存
  3. 使用第三方如memcache等NoSQL技术
  4. 数据库进行分区处理,减小表大小
  5. 其他:避免SQL语句中使用NULL判断避免Where中使用Mysql函数操作避免使用like ‘%%’形式数据比较两边类型要一致,如 name=1,如果name为字符类型将进行全表搜索在常用的列上增加索引对文本字段使用“前缀索引”,减少索引文件大小经常使用 explain 分析sql执行效率使用Mysql慢查询机制监控查询状态

3. Memcache和redis,MongoDB的异同

从以下几个维度,对 redis、memcache、mongoDB 做了对比。

1、性能
都比较高,性能对我们来说应该都不是瓶颈。
总体来讲,TPS 方面 redis 和 memcache 差不多,要大于 mongodb。
2、操作的便利性
memcache 数据结构单一。(key-value)
redis 丰富一些,数据操作方面,redis 更好一些,较少的网络 IO 次数,同时还提供 list,set,
hash 等数据结构的存储。
mongodb 支持丰富的数据表达,索引,最类似关系型数据库,支持的查询语言非常丰富。
3、内存空间的大小和数据量的大小
redis 在 2.0 版本后增加了自己的 VM 特性,突破物理内存的限制;可以对 key value 设置过
期时间(类似 memcache)
memcache 可以修改最大可用内存,采用 LRU 算法。Memcached 代理软件 magent,比如建立
10 台 4G 的 Memcache 集群,就相当于有了 40G。 magent -s 10.1.2.1 -s 10.1.2.2:11211 -b
10.1.2.3:14000 mongoDB 适合大数据量的存储,依赖操作系统 VM 做内存管理,吃内存也比较厉害,服务
不要和别的服务在一起。
4、可用性(单点问题)
对于单点问题,
redis,依赖客户端来实现分布式读写;主从复制时,每次从节点重新连接主节点都要依赖整
个快照,无增量复制,因性能和效率问题,
所以单点问题比较复杂;不支持自动 sharding,需要依赖程序设定一致 hash 机制。
一种替代方案是,不用 redis 本身的复制机制,采用自己做主动复制(多份存储),或者改成
增量复制的方式(需要自己实现),一致性问题和性能的权衡
Memcache 本身没有数据冗余机制,也没必要;对于故障预防,采用依赖成熟的 hash 或者环
状的算法,解决单点故障引起的抖动问题。
mongoDB 支持 master-slave,replicaset(内部采用 paxos 选举算法,自动故障恢复),auto sharding 机制,对客户端屏蔽了故障转移和切分机制。
5、可靠性(持久化)
对于数据持久化和数据恢复,
redis 支持(快照、AOF):依赖快照进行持久化,aof 增强了可靠性的同时,对性能有所影

memcache 不支持,通常用在做缓存,提升性能;
MongoDB 从 1.8 版本开始采用 binlog 方式支持持久化的可靠性
6、数据一致性(事务支持)
Memcache 在并发场景下,用 cas 保证一致性redis 事务支持比较弱,只能保证事务中的每个操作连续执行
mongoDB 不支持事务
7、数据分析
mongoDB 内置了数据分析的功能(mapreduce),其他不支持
8、应用场景
redis:数据量较小的更性能操作和运算上
memcache:用于在动态系统中减少数据库负载,提升性能;做缓存,提高性能(适合读多写
少,对于数据量比较大,可以采用 sharding)
MongoDB:主要解决海量数据的访问效率问题。
表格比较:
memcache redis 类型 内存数据库 内存数据库
数据类型 在定义 value 时就要固定数据类型 不需要
有字符串,链表,集 合和有序集合
虚拟内存 不支持 支持
过期策略 支持 支持
分布式 magent master-slave,一主一从或一主多从
存储数据安全 不支持 使用 save 存储到 dump.rdb 中
灾难恢复 不支持 append only file(aof)用于数据恢复
性能
1、类型——memcache 和 redis 都是将数据存放在内存,所以是内存数据库。当然,memcache 也可用于缓存其他东西,例如图片等等。
2、 数据类型——Memcache 在添加数据时就要指定数据的字节长度,而 redis 不需要。
3、 虚拟内存——当物理内存用完时,可以将一些很久没用到的 value 交换到磁盘。
4、 过期策略——memcache 在 set 时就指定,例如 set key1 0 0 8,即永不过期。Redis 可以通
过例如 expire 设定,例如 expire name 10。
5、 分布式——设定 memcache 集群,利用 magent 做一主多从;redis 可以做一主多从。都可
以一主一从。
6、 存储数据安全——memcache 断电就断了,数据没了;redis 可以定期 save 到磁盘。
7、 灾难恢复——memcache 同上,redis 丢了后可以通过 aof 恢复。

4. 递归写一个数的阶乘,递归列出文件夹的文件和文件夹

阶乘递归
<?php 
header('Content-type:text/html;charset=utf-8');
function jc($num){
    if($num <0 ){
        die('不能输入负数!'); 
    }
    if($num==0||1){
        $re = 1;
    }
    if($num>1){
        $re= $num * jc($num - 1);
    }
    return $re;
}
echo jc(10);
 ?>
递归显示文件夹下所有目录和文件
header('Content-type:text/html;charset=utf-8');
function showDir($dirName){
    //如果不是目录返回false
    if(!is_dir($dirName)) return false;
    //输出父级目录
    echo  '<span style="color:red">' . $dirName . '</span><br/>';
    //扫描目录
    $scDir = glob($dirName . '/*');
    //循环目录下面所有的文件和录
    foreach ($scDir as $v) {
        //是目录,则递归
        if(is_dir($v)) showDir($v);
        //是文件,则输出文件名
        if(is_file($v)) echo $v . '<br/>';
    }
}
showDir('./');

5. js,php写出9×9乘法表

js写九九乘法表的效果图

 js代码:
    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>js写九九乘法表</title>
            <style>
                table {
                    width: 800px;
                    height: 300px;
                    border-collapse: collapse;
                }
                table td {
                    border: 1px solid #069;
                }
                body {
                    text-align: center;
                }
                h1 {
                    font-family: "微软雅黑", Verdana, sans-serif, "宋体";
                    color: #666;
                    font-weight: bold;
                    margin-bottom: 30px;
                }
            </style>
            <script type="text/javascript">
                document.write("<table>");
                var str = "js写九九乘法表";
                document.write("<h1>" + str + "</h1>");
                for ( var i = 1; i <= 9; i++) {
                    document.write("<tr>");
                    for ( var j = 1; j <= i; j++) {
                        document.write("<td>" + i + "×" + j + "=" + (i * j) + "</td>");
                    }
                    document.write("</tr>");
                }
                document.write("</table>");
            </script>
        </head>
        <body>
        </body>
    </html>

php写九九乘法表代码:

<?php 
header('Content-type:text/html;charset=utf-8');
echo "<h1>php写九九乘法表</h1>";
for($i=1;$i<=9;$i++){
    for($j=1;$j<=$i;$j++){
        echo $i.'×'.$j.'='.$i*$j.'   ';
    }
    echo '<br>';
}
 echo "<hr>";
//倒着
for($i=9;$i>=1;$i--){
    for($j=1;$j<=$i;$j++){
        echo $i.'×'.$j.'='.$i*$j.'   ';
    }
    echo '<br>';
}
?>

6. include和require的区别

require()语句的性能与include()相类似,都是包括并运行指定文件。不同之处在于:对include()语句来说,在执行文件时每次都要进行读取和评估;而对于require()来说,文件只处理一次(实际上,文件内容替换require()语句)。这就意味着如果可能执行多次的代码,则使用require()效率比较高。另外一方面,如果每次执行代码时是读取不同的文件,或者有通过一组文件迭代的循环,就使用include()语句。需要注意的是,require和include要引入的文件的路径要写正确,如果出错,include会报一个警告错误,程序会继续运行,而require则会报一个致命错误,程序就此停止。

7. 获取一个文件的扩展名

# 方法1:
function get_extension($file) { 
    return substr($file, strrpos($file, '.')+1); 
} 
$file = './123/a/f/abc.txt.rar';
echo get_extension($file);//输出rar 
# 注释:
echo strrpos("You love php, I love php too!","php");//结果是21.查找 "php" 在字符串中最后一次出现的位置:
echo substr("Hello world",6);//输出world.注意是从0开始,第6个字母是w

# 方法2:
function get_extension($file){ 
    return end(explode('.', $file));//把$file这个字符串以.炸开成数组,取其最后一个元素
} 
# 注释:
$people = array("Bill", "Steve", "Mark", "David");
echo end($people);//输出David
# 方法3:
function get_extension($file) { 
    $info = pathinfo($file); //获取文件信息的数组
    return $info['extension']; //获取文件信息数组的扩展名的值
} 
# 方法4:
function get_extension($file){ 
    return pathinfo($file, PATHINFO_EXTENSION); 
}

8. js和php的正则验证邮箱和手机号

验证130-139,150-159,180-189号码段的手机号码:
<script type="text/javascript">
var myreg = /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/; 
if(!myreg.test($("#phone").val())) 
{ 
    alert('请输入有效的手机号码!'); 
    return false; 
} 
</script>
写成函数形式:
function validatemobile(mobile) 
   { 
       if(mobile.length==0) 
       { 
          alert('请输入手机号码!'); 
          document.form1.mobile.focus(); 
          return false; 
       }     
       if(mobile.length!=11) 
       { 
           alert('请输入有效的手机号码!'); 
           document.form1.mobile.focus(); 
           return false; 
       } 
        
       var myreg = /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/; 
       if(!myreg.test(mobile)) 
       { 
           alert('请输入有效的手机号码!'); 
           document.form1.mobile.focus(); 
           return false; 
       } 
   } 

9. js和php实现字符串和数组的转换

js参考手册

<script type="text/javascript">
//字符串转数组,使用split()函数
var str="How are you doing today?"
document.write(str.split(" ") + "<br />");//输出['How','are','you','doing','today?']
document.write(str.split("") + "<br />");
document.write(str.split(" ",3));
</script>
<hr />
<script type="text/javascript">
//数组转字符串,用join()
var arr = new Array(3);
arr[0] = "George"
arr[1] = "John"
arr[2] = "Thomas"
document.write(arr.join());
document.write("<br />");
document.write(arr.join("."));
</script>

10. php如何连接MySQL?

<?php 
$dsn='mysql:host=127.0.0.1;dbname=c65';//dsn是数据源,包括数据库类型(IBM的DB2、甲骨文的Oracle、微软的SQL和Access、Sybase的Sybase、MySQL AB公司的MySQL等),主机地址host(本地是localhost或者127.0.0.1,也可以连接远程服务器地址),数据库名dbname
$username='root';//用户名
$password='';//此root用户没有密码
try {//
    $pdo=new PDO($dsn,$username,$password);//实例化PDO,通过PDO连接数据库
} catch (PDOException $e) {//如果连接出错,会抛出异常。然后被catch接到
    echo '<span style="color: red;">'.$e->getMessage().'</span>';//输出错误信息
}
?>

11. 解析php数组函数array_filter,array_push,in_array的用法。

array_filter用法链接
array_push用法链接
in_array用法链接

<?php
$a=array("red","green");
array_push($a,"blue","yellow");
print_r($a);
?>
#注释:array_push() 函数向第一个参数的数组尾部添加一个或多个元素(入栈),然后返回新数组的长度。
#该函数等于多次调用 $array[] = $value。

12. echo,print(),print_r(),var_dump()的用法

13. Ajax有哪些方法可以实现跨域?它们有哪些局限性?

14. 硬件加速是什么?如何开启设备的硬件加速?

15. <canvas>标签的用法

参考链接 请查看源码

16. Mysql数据库千万级数据处理优化

17. php用最简单的代码写一个获取3个数中最大值的函数

18. js中window.onload和JQ中的ready有何不同?

1.执行时间
window.onload必须等到页面内包括图片的所有元素加载完毕后才能执行。
$(document).ready()是DOM结构绘制完毕后就执行,不必等到加载完毕。
2.编写个数不同
window.onload不能同时编写多个,如果有多个window.onload方法,只会执行一个
$(document).ready()可以同时编写多个,并且都可以得到执行
3.简化写法
window.onload没有简化写法
$(document).ready(function(){})可以简写成$(function(){});

19. 如何不使用sumit按钮来提交表单?

20. 怎样抓取远程图片到本地?

21. 怎么获取一个文件的扩展名?

第1种方法:
function get_extension($file){ 
    substr(strrchr($file, '.'), 1); 
} 
第2种方法:
function get_extension($file){ 
    $info = pathinfo($file); //返回文件信息的数组
    return $info['extension']; //返回文件扩展名
} 
第3种方法(推荐)
function get_extension($file){ 
    return pathinfo($file, PATHINFO_EXTENSION); 
} 

22. 抽奖活动的php程序。

23. 1万个过滤词,像微博这样的网站是如何过滤的?

24. 简述Ajax原理

25. MySQL运算和MySQL函数

26. mysql_fetch_row()和mysql_fetch_array()的用法和区别

27. MySQL指令和MySQL优化提升课程

28. Linux 各种shell命令,vi命令

29. shell 命令:删除文件名包含'abc'的所有文件

30. 什么是事务,它是如何实现的

31. 翻转字符串

<?php
$str = 'abcde';
for ($i=0, $j = strlen($str)-1; $i < $j; $i++, $j--) {
    $tmp = $str[$j];
    $str[$j] = $str[$i];
    $str[$i] = $tmp;
}
echo $str;

$str = 'abcdef';
function demo($str){
  $arr=array();
  $newStr='';
  $arr=str_split($str);
  for($i=count($arr)-1;$i>=0;$i--){
    $newStr.=$arr[$i];
  }
  return $newStr;
}
echo demo($str);

$str = 'abcdef';
echo strrev($str);

32. 列出几个php中的全局函数和全局变量

33. 写出你知道的魔术方法并简述其功能

34. 递归转换数组的键名为大写

35. php中json_decode()和json_encode()的使用方法

36. Rbac的作用,实现方法和原理

37. MySQL分区

38. PHP写链式营销的思路

39. 网页提示401和404是什么情况?

40. Linux下memcached配置

41. 常用的加密函数。

42. $_GET和$_POST的区别:

通过 GET 方法从表单发送的信息对任何人都是可见的(所有变量名和值都显示在 URL 中)。GET 对所发送信息的数量也有限制。限制在大于 2000 个字符。不过,由于变量显示在 URL 中,把页面添加到书签中也更为方便。
GET 可用于发送非敏感的数据。


通过 POST 方法从表单发送的信息对其他人是不可见的(所有名称/值会被嵌入 HTTP 请求的主体中),并且对所发送信息的数量也无限制。
此外 POST 支持高阶功能,比如在向服务器上传文件时进行 multi-part 二进制输入。

不过,由于变量未显示在 URL 中,也就无法将页面添加到书签。

43. 不通过submit提交表单的方法。

44. PHP - 验证 E-mail

$email = test_input($_POST["email"]);
$preg = "/([\w\-]+\@[\w\-]+\.[\w\-]+)/";
if (!preg_match($preg,$email)) {
    $emailErr = "无效的 email 格式!"; 
}
注释:preg_match() 函数检索字符串的模式,如果模式存在则返回 true,否则返回 false。

45. PHP - 验证 URL

$website = test_input($_POST["website"]);
if (!preg_match("/\b(?:(?:https?|ftp):\/\/|www\.)[-a-z0-9+&@#\/%?=~_|!:,.;]*[-a-z0-9+&@#\/%
=~_|]/i",$website)) {
  $websiteErr = "无效的 URL"; 
}

46. SVN版本控制用法

47. PHP的意思:

PHP(外文名:PHP: Hypertext Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言。

49. 把日期字符串07/26/2016转换成2016/07/26格式

<?php
$date = '07/26/2016';
echo preg_replace('/(\d+)\/(\d+)\/(\d+)/', '$3/$1/$2', $date);//输出2016/07/26
# 注释:3个()所匹配的内容分别是$1,$2,$3.替换成$3/$1/$2的格式。

如果这篇文章对你有帮助,不妨点个赞哦 (˙˘˙)ᓂ--♡

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容

  • 1、memcache的概念? Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨...
    桖辶殇阅读 2,232评论 2 12
  • 一、MemCache简介 session MemCache是一个自由、源码开放、高性能、分布式的分布式内存对象缓存...
    李伟铭MIng阅读 3,796评论 2 13
  • 个人学习批处理的初衷来源于实际工作;在某个迭代版本有个BS(安卓手游模拟器)大需求,从而在测试过程中就重复涉及到...
    Luckykailiu阅读 4,712评论 0 11
  • 更改ip和dnsVi /etc/sysconfig/network-scripts/ifcfg-eth0vi /...
    Xwei_阅读 1,810评论 0 3
  • 第一次发烧,宝宝4个多月,下午量体温超过38度,爷爷奶奶很着急,催着赶紧去医院打针,只有先生比较镇定,认为先采取物...
    惜萌阅读 674评论 0 0