热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php把数组保存数据库程序代码

我们在做缓存文件时经常会要把php代码或数组转换成字符串保存到数据库中,下面我来介绍两种把数组保存到数据库的方法。方法一:用serialize

我们在做缓存文件时经常会要把php代码或数组转换成字符串保存到数据库中,下面我来介绍两种把数组保存到数据库的方法。

方法一:用serialize写入,再用unserialize输出

serialize()就是将PHP中的变量如对象(object),数组(array)等等的值序列化为字符串后存储起来.序列化的字符串我们可以 存储在其他地方如数据库、Session、COOKIE等,序列化的操作并不会丢失这些值的类型和结构。这样这些变量的数据就可以在PHP页面、甚至是不 同PHP程序间传递了。

而unserialize()就是把序列化的字符串转换回PHP的值。返回的是转换之后的值,可为 integer、float、string、array 或 object如果传递的字符串不可解序列化,则返回 FALSE,代码如下:

  1. class db { 
  2.  private $host
  3.  private $user
  4.  private $pwd
  5.  private $dbname
  6.  private $Mysqli
  7.  function __construct($host$user$pwd$dbname) { 
  8.   $this->host = $host
  9.   $this->user = $user
  10.   $this->pwd = $pwd
  11.   $this->dbname = $dbname
  12.   $this->db(); 
  13.  } 
  14.  function db() { 
  15.   $this->mysqli = new mysqli ( $this->host, $this->user, $this->pwd, $this->dbname ); 
  16.  } 
  17.  function select() { 
  18.   $this->mysqli->query("SET CHARSET GBK"); 
  19.   $sql = "SELECT id,cname FROM hdw_channel"
  20.   $result = $this->mysqli 
  21.    ->query ( $sql ); 
  22.   $rows = array (); 
  23.   while ( $row = $result->fetch_assoc () ) { 
  24.    $rows [] = $row
  25.   } 
  26.   ECHO "
    "
  27.   print_r ( $rows ); 
  28.  } 
  29.  function __wakeup(){   //反序列化, 
  30.   $this->db(); 
  31.  } 
  32. $chanel = new db("localhost",'root','','hdcms'); 
  33. //$chanel->select(); 
  34. session_start(); 
  35. $_SESSION['channel_obj'] = serialize($chanel);   //将对象序列化,保存的是对象的属性,没有方法,所以要用__wakeup() 
  36.  
  37. class ren{ 
  38.  private $name
  39.  private $age
  40.  function __construct($name,$age){ 
  41.   $this->name =$name
  42.   $this->age = $age
  43.  } 
  44.  function show(){ 
  45.   echo "姓名是:{$this->name}  年龄是:{$this->age}"
  46.  } 
  47.  function __sleep(){ 
  48.   return array_keys(get_object_vars($this));  //或得数组里边的键名,序列化某些变量 
  49.  } 
  50. $zao = new ren("赵六",44); 
  51. echo serialize($zao);       //序列化(指定哪个变量序列化) 
  52. ==================================== 
  53. session_start(); 
  54. include '59.php'
  55. $channel_obj=unserialize($_SESSION['channel_obj']);  //反序列化类对象 
  56. $channel_obj->select();  //有了__wakeup方法才可以起作用 

方法二:用json_encode写入,再用json_decode输出

json_encode之前,把所有数组内所有内容都用urlencode()处理一下,然用json_encode()转换成json字符串,最后再用urldecode()将编码过的中文转回来,代码如下:

  1. /************************************************************** 
  2.  * 
  3.  * 使用特定function对数组中所有元素做处理 
  4.  * @param string &$array  要处理的字符串 
  5.  * @param string $function 要执行的函数 
  6.  * @return boolean $apply_to_keys_also  是否也应用到key上 
  7.  * @access public 
  8.  * 
  9.  *************************************************************/ 
  10. function arrayRecursive(&$array$function$apply_to_keys_also = false) 
  11.     static $recursive_counter = 0; 
  12.     if (++$recursive_counter > 1000) { 
  13.         die('possible deep recursion attack'); 
  14.     } 
  15.     foreach ($array as $key => $value) { 
  16.         if (is_array($value)) { 
  17.             arrayRecursive($array[$key], $function$apply_to_keys_also); 
  18.         } else { 
  19.             $array[$key] = $function($value); 
  20.         } 
  21.  
  22.         if ($apply_to_keys_also && is_string($key)) { 
  23.             $new_key = $function($key); 
  24.             if ($new_key != $key) { 
  25.                 $array[$new_key] = $array[$key]; 
  26.                 unset($array[$key]); 
  27.             } 
  28.         } 
  29.     } 
  30.     $recursive_counter--; 
  31.  
  32. /************************************************************** 
  33.  * 
  34.  * 将数组转换为JSON字符串(兼容中文) 
  35.  * @param array $array  要转换的数组 
  36.  * @return string  转换得到的json字符串 
  37.  * @access public 
  38.  * 
  39.  *************************************************************/ 
  40. function JSON($array) { 
  41.  arrayRecursive($array'urlencode', true); 
  42.  $json = json_encode($array); 
  43.  return urldecode($json); 
  44. $array = array 
  45.        ( 
  46.           'Name'=>'希亚'
  47.           'Age'=>20 
  48.        ); 
  49.  
  50. echo JSON($array); 
  51. ?>

推荐阅读
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • 本文探讨了适用于Spring Boot应用程序的Web版SQL管理工具,这些工具不仅支持H2数据库,还能够处理MySQL和Oracle等主流数据库的表结构修改。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
author-avatar
mobiledu2502883647
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有